用Python写一个SQLBuilder。Java版能够从 http://www.java2s.com/Code/Java/Database-SQL-JDBC/SQLBuilder.htm 看到。

附上代码:

演示样例代码(一):

class SQLDirector:
@classmethod
def buildSQL(cls, builder):
sql = ""
sql += builder.getCommand()
sql += builder.getTable()
sql += builder.getWhat()
sql += builder.getCriteria()
return sql class SQLBuilder:
def __init__(self): pass
def __del__(self): pass def getCommand(self): pass
def getTable(self): pass
def getWhat(self): pass
def getCriteria(self): pass class InsertBuilder(SQLBuilder): def __init__(self):
self._table = ""
self._columnsAndData = dict()
self._criteria = "" def setTable(self, table):
self._table = table def getCommand(self):
return "INSERT INTO " def getTable(self):
return self._table def getWhat(self):
columns = list()
values = list()
what = "" for columnName in self._columnsAndData:
columns.append(columnName)
values.append(self._columnsAndData[columnName]) columns_str = string.join( map(lambda x: str(x), columns), "," )
values_str = string.join( map(lambda x: str(x), values), "," ) what += " ("
what += columns_str
what += ") VALUES ("
what += values_str
what += ") " return what def getCriteria(self):
return "" def addColumnAndData(self, columnName, value):
if value:
self._columnsAndData[columnName] = value def main():
builder = InsertBuilder()
builder.setTable("employees")
builder.addColumnAndData("employee_id", int(221))
builder.addColumnAndData("first_name", "'Shane'")
builder.addColumnAndData("last_name", "'Grinnell'")
builder.addColumnAndData("email", "'al@yahoo.com'") sql = SQLDirector.buildSQL(builder)
print sql if __name__ == '__main__':
main()

更有意思的玩法。

代码演示样例(二):

#!/usr/bin/env python

import string

class SQLDirector:
def __init__(self, builder):
self._builder = builder def construct(self):
self._builder.buildSQL()
return self._builder.getSQL() class SQLBuilder:
def __init__(self): self._sql = ''
def buildSQL(self): return self
def getSQL(self): return self._sql class InsertBuilder(SQLBuilder):
def __init__(self):
self._columns = list()
self._values = list() def buildSQL(self):
columns_str = string.join( map(lambda x: "`%s`" % str(x), self._columns), "," )
values_str = string.join( map(lambda x: "'%s'" % str(x), self._values), "," ) self._sql = "INSERT INTO "
self._sql += self._table
self._sql += " (%s) VALUES (%s) " % (columns_str, values_str) return self def table(self, table):
self._table = table
return self def column(self, columnName, value):
self._columns.append(columnName)
self._values.append(value)
return self def main():
insertBuilder = InsertBuilder()
insertBuilder.table("dt_process") \
.column("attr_key","foo").column("attr_val", "bar") sqlDirector = SQLDirector(insertBuilder)
print sqlDirector.construct() if __name__ == "__main__":
main()

演示样例代码(三):

#!/usr/bin/env python

import string

def main():
insertBuilder = InsertBuilder()
insertBuilder.table("dt_process") \
.column("attr_key","foo").column("attr_val", "bar") sqlDirector = SQLDirector(insertBuilder)
print sqlDirector.construct() createBuilder = CreateBuilder()
createBuilder.table("newTable").ifnotexists() \
.column("id").col_type("INTEGER").col_autoincrement() \
.column("name").col_type("VARCHAR(40)").col_nullable(False).col_default("empty") sqlDirector = SQLDirector(createBuilder)
print sqlDirector.construct() # -----------------------------------------------------------------------------
# Libraries
# ----------------------------------------------------------------------------- class SQLDirector:
def __init__(self, builder):
self._builder = builder def construct(self):
self._builder.buildSQL()
return self._builder.getSQL() class SQLBuilder:
def __init__(self): self._sql = ''
def buildSQL(self): return self
def getSQL(self): return self._sql class CreateBuilder(SQLBuilder):
def __init__(self):
self._columns = list() # item: dict => 'name', 'nullable', 'default'
self._column_context = None
self._table = ""
self._ifnotexists = ""
self._criteria = "" def _map_column(self, column):
sql = ""
if column.has_key('name'): sql += " `%s`"%column['name']
if column.has_key('type'): sql += " %s"%column['type']
if column.has_key('nullable'): sql += "%s"%column['nullable']
if column.has_key('default'): sql += "%s"%column['default']
if column.has_key('auto_increment'): sql += "%s"%column['auto_increment']
return sql def _reduce_column(self, left, right):
return left + ", " + right def buildSQL(self):
columns_str = reduce(self._reduce_column, map( self._map_column, self._columns )) self._sql = "CREATE TABLE "
self._sql += self._ifnotexists
self._sql += self._table
self._sql += " (%s)" % columns_str return self def ifnotexists(self):
self._ifnotexists = " IF NOT EXISTS "
return self def table(self, table):
self._table = table
return self def column(self, columnName):
column = dict()
column['name'] = columnName
self._columns.append(column)
self._column_context = column
return self def col_type(self, type):
self._column_context['type'] = type
return self def col_nullable(self, nullable=True):
if nullable:
self._column_context['nullable'] = ""
else:
self._column_context['nullable'] = " NOT NULL"
return self def col_default(self, default):
self._column_context['default'] = " DEFAULT %s" % default
return self def col_autoincrement(self, autoincrement=True):
self._column_context['auto_increment'] = " AUTO_INCREMENT"
return self def primary(self, primary=True):
self._primary_key.append(self._column_context['name'])
return self #
# INSERT INTO
#
class InsertBuilder(SQLBuilder):
def __init__(self):
self._columns = list()
self._values = list()
self._table = "" def buildSQL(self):
columns_str = string.join( map(lambda x: "`%s`" % str(x), self._columns), "," )
values_str = string.join( map(lambda x: "'%s'" % str(x), self._values), "," ) self._sql = "INSERT INTO "
self._sql += self._table
self._sql += " (%s) VALUES (%s) " % (columns_str, values_str) return self def table(self, table):
self._table = table
return self def column(self, columnName, value):
self._columns.append(columnName)
self._values.append(value)
return self if __name__ == "__main__":
main()

[Python] SQLBuilder 演示样例代码的更多相关文章

  1. java 线程、线程池基本应用演示样例代码回想

    java 线程.线程池基本应用演示样例代码回想 package org.rui.thread; /** * 定义任务 * * @author lenovo * */ public class Lift ...

  2. java文件夹相关操作 演示样例代码

    java文件夹相关操作 演示样例代码 package org.rui.io; import java.io.File; import java.io.FilenameFilter; import ja ...

  3. 10分钟理解Android数据库的创建与使用(附具体解释和演示样例代码)

    1.Android数据库简单介绍. Android系统的framework层集成了Sqlite3数据库.我们知道Sqlite3是一种轻量级的高效存储的数据库. Sqlite数据库具有以下长处: (1) ...

  4. java 又一次抛出异常 相关处理结果演示样例代码

    java 又一次抛出异常 相关处理结果演示样例代码 package org.rui.ExceptionTest; /** * 又一次抛出异常 * 在某些情况下,我们想又一次掷出刚才产生过的违例,特别是 ...

  5. C编程规范, 演示样例代码。

    /*************************************************************** *Copyright (c) 2014,TianYuan *All r ...

  6. java I/O进程控制,重定向 演示样例代码

    java I/O进程控制,重定向 演示样例代码 package org.rui.io.util; import java.io.*; /** * 标准I/O重定向 */ public class Re ...

  7. AppCan移动应用开发平台新增9个超有用插件(内含演示样例代码)

    使用AppCan平台进行移动开发.你所须要具备的是Html5+CSS +JS前端语言基础.此外.Hybrid混合模式应用还需结合原生语言对功能模块进行封装,对于没有原生基础的开发人员,怎样实现App里 ...

  8. Linux下用OTL操作MySql(包含自己封装的类库及演示样例代码下载)

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/ClamReason/article/details/23971805 首先重点推荐介绍otl介绍及使 ...

  9. java 状态模式 解说演示样例代码

    package org.rui.pattern; import junit.framework.*; /** * 为了使同一个方法调用能够产生不同的行为,State 模式在代理(surrogate)的 ...

随机推荐

  1. Spring框架配置beans.xml

    Spring学习笔记(一) 一.Spring 框架 Spring 是一个开源框架,是为了解决企业应用程序开发复杂性而创建的.框架的主要优势之一就是其分层架构,分层架构允许您选择使用哪一个组件,同时为 ...

  2. nyoj 题目6 喷水装置

    喷水装置(一) 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 现有一块草坪,长为20米,宽为2米,要在横中心线上放置半径为Ri的喷水装置,每个喷水装置的效果都会让以 ...

  3. java替换富文本标签等

    (转自:http://www.cnblogs.com/1246447850qqcom/p/5439366.html) package q;import java.util.regex.Matcher; ...

  4. 【bzoj2161】布娃娃 权值线段树

    题目描述 小时候的雨荨非常听话,是父母眼中的好孩子.在学校是老师的左右手,同学的好榜样.后来她成为艾利斯顿第二代考神,这和小时候培养的良好素质是分不开的.雨荨的妈妈也为有这么一个懂事的女儿感到高兴.一 ...

  5. [HNOI2004][bzoj1212] L语言 [Trie+dp]

    题面 传送门 思路 无后效性 显然,不管某个前缀的理解方式是怎么样的,如果它能被理解,那么前面的决策对于后面的决策而言都是等价的 因此这题可以DP DP方程 令$dp[i]$表示前缀i是否能被理解 那 ...

  6. 觉醒力量 (hidpower)

    觉醒力量 (hidpower) 题目描述 [题目背景] 从前有一款非常火的游戏被人们称为pokemon,从最初的红绿蓝黄版直到现在的XY版,都受到世界各地小朋友和大朋友们的喜爱. [题意描述] 作为一 ...

  7. vi 使用介绍

    参考 <<vi编辑器使用介绍>>文本编辑器有很多,比如图形模式的gedit.kwrite.OpenOffice ,文本模式下的编辑器有vi.vim(vi的增强版本)和nano, ...

  8. chrome浏览器警告:Failed to decode downloaded font:

    使用iconfont字体时chrome报错 Failed to decode downloaded font: 在服务器设置一下自己定义MIME类型. 扩展名: .woff Mime类型:applic ...

  9. EasyUI中combogrid设置onSelect后 获取不到getSelecte问题解决

    $('#person').combogrid({ onSelect: function(index, item){ $('#dataForm').form('load', item); $(" ...

  10. Docker 常用命令总结

    Docker 常用命令总结   回到顶部 镜像相关 搜索 docker search *image_name* 下载 docker pull *image_name* 查看 docker images ...