[Python] SQLBuilder 演示样例代码
用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 演示样例代码的更多相关文章
- java 线程、线程池基本应用演示样例代码回想
java 线程.线程池基本应用演示样例代码回想 package org.rui.thread; /** * 定义任务 * * @author lenovo * */ public class Lift ...
- java文件夹相关操作 演示样例代码
java文件夹相关操作 演示样例代码 package org.rui.io; import java.io.File; import java.io.FilenameFilter; import ja ...
- 10分钟理解Android数据库的创建与使用(附具体解释和演示样例代码)
1.Android数据库简单介绍. Android系统的framework层集成了Sqlite3数据库.我们知道Sqlite3是一种轻量级的高效存储的数据库. Sqlite数据库具有以下长处: (1) ...
- java 又一次抛出异常 相关处理结果演示样例代码
java 又一次抛出异常 相关处理结果演示样例代码 package org.rui.ExceptionTest; /** * 又一次抛出异常 * 在某些情况下,我们想又一次掷出刚才产生过的违例,特别是 ...
- C编程规范, 演示样例代码。
/*************************************************************** *Copyright (c) 2014,TianYuan *All r ...
- java I/O进程控制,重定向 演示样例代码
java I/O进程控制,重定向 演示样例代码 package org.rui.io.util; import java.io.*; /** * 标准I/O重定向 */ public class Re ...
- AppCan移动应用开发平台新增9个超有用插件(内含演示样例代码)
使用AppCan平台进行移动开发.你所须要具备的是Html5+CSS +JS前端语言基础.此外.Hybrid混合模式应用还需结合原生语言对功能模块进行封装,对于没有原生基础的开发人员,怎样实现App里 ...
- Linux下用OTL操作MySql(包含自己封装的类库及演示样例代码下载)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/ClamReason/article/details/23971805 首先重点推荐介绍otl介绍及使 ...
- java 状态模式 解说演示样例代码
package org.rui.pattern; import junit.framework.*; /** * 为了使同一个方法调用能够产生不同的行为,State 模式在代理(surrogate)的 ...
随机推荐
- BZOJ 2243:染色(树链剖分+区间合并线段树)
[SDOI2011]染色Description给定一棵有n个节点的无根树和m个操作,操作有2类:1.将节点a到节点b路径上所有点都染成颜色c:2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认 ...
- display:table布局总结
1. table布局方式 2. table布局实际应用 效果: 代码: <!DOCTYPE html> <html lang="en"> <head& ...
- 1 - Django安装
一.Python安装 在Mac系统下,系统自带python开发环境,打开终端,输入python,我们就可以看到当前python版本号,例如我的系统是OS X EI Caption 10.11.1,自带 ...
- Intelli IDEA快捷键(配合IdeaVim)
Intelli IDEA开发环境,个人总结的一些常用的快捷键. 想要使用vim方式编辑代码,可以使用Intelli IDEA的IdeaVim.IdeaVim插件功能很强大,在vim编辑模式下还可以使用 ...
- 倒计时浏览器跳转JavaScript
原文发布时间为:2008-10-11 -- 来源于本人的百度文章 [由搬家工具导入] <html> <head> <title>显示时间</title> ...
- 【HugeChm】HugeChm制作chm帮助文档
1.下载软件:HugeChm.exe 2.开始打包: 3.选择开始打包即可
- anaconda 安装
1. 安装: 参考博客:https://blog.csdn.net/qq_36851515/article/details/82956150 2. 更新包: 更新失败:conda httperror ...
- bonds
Linux--多网卡的7种Bond模式 http://www.cnblogs.com/lcword/p/5914089.html 七种网卡绑定模式详解: http://blog.csdn.net/w ...
- JS-JavaScript String 对象-string对象方法3:concat()
1.concat():用于连接两个或多个字符串. 1).语法:string.concat(string1, string2, ..., stringX) (string1, string2, . ...
- Codeforces Gym101063 F.Bandejao (2016 USP-ICMC)
F.Bandejao It is lunch time on Mars! Everyone has got that big smile on their faces, all eager to se ...