如何进行Jython数据库插入(JDBC)
创始人
2024-04-16 07:21:05
0

假定 Joe 是一名 QA,他需要为功能测试在 SAMPLE 数据库中创建新的雇员。在 Jython 中,Joe 进行少量工作就可以编写他自己的脚本,进行Jython数据库插入。

例如,Joe 可以在 SAMPLE 数据库中通过运行“jython batchinsert.jy joescript.txt”,创建三名新雇员。

清单 6. joescript.txt

  1. createEmployee(firstName='JOHN',midinit='M',lastName='DOE',salary=32888.55,sex='M',workdept='A01',  
  2. job='DESIGNER')  
  3. createEmployee(firstName='MANAGER',midinit='M',lastName='DOE',salary=50000,sex='M',workdept='A01',  
  4. job='MANAGER')  
  5. createEmployee(firstName='SARA',midinit='M',lastName='DOE',salary=40000,sex='F',workdept='C01',  
  6. job='DESIGNER') 

如果 Joe 想要添加另一名 Employee,就只需用他喜欢的文本编辑器编辑“joescript.txt”。

Jython数据库插入的脚本背后的功能十分简单。Jython 有一个名为 execfile(filename) 的内置函数。如果我们将 createEmployee() 实现为 Jython 函数,用于向 EMPLOYEE 表插入一行记录,那么 execfile('joescript.txt') 将按照 Joe 需要的数目插入雇员。

换言之,我们利用 Jython 的解释器,并可以为 Joe 派生一个像这样的小的测试语言。该解决方案也是可扩展的。如果 Joe 需要在脚本中删除或更新雇员,就只需要添加另一函数。对于 Joe 来说,最酷的事情就是学习曲线很短。他可以立刻编写这样的脚本,而没有意识到正在进行 Jython 函数调用。

清单 7. (batchinsert.jy)createEmployee 函数

  1. from java.lang import *  
  2. from java.sql import *  
  3. import sys  
  4. def createEmployee(**args):  
  5.     global stmt  
  6.     sqlTemplate=  
  7.     "INSERT into EMPLOYEE (EMPNO,FIRSTNAME,MIDINIT,LASTNAME,SALARY,SEX,EDLEVEL, HIREDATE, WORKDEPT,JOB)   
  8.     values ((select RTRIM(CHAR(MAX(INT(EMPNO))+1)) from EMPLOYEE),   
  9.     '%(firstName)s''%(midinit)s','%(lastName)s',   
  10.     %(salary).2f,'%(sex)s' ,18, CURRENT DATE,'%(workdept)s','%(job)s')"   
  11.     # dictionary based SQL string formatting  
  12.     sql=sqlTemplate % args  
  13.       
  14.     stmt.addBatch(sql)  
  15.       
  16. # load DB2 JDBC type 2 driver  
  17. Class.forName("COM.ibm.db2.jdbc.app.DB2Driver").newInstance()  
  18. con = DriverManager.getConnection( 'jdbc:db2:sample''vyang','jythonrocks');  
  19. con.setAutoCommit(0)  
  20. stmt = con.createStatement()  
  21. execfile(sys.argv[1])  
  22. stmt.executeBatch()  
  23. stmt.close()  
  24. # commit  
  25. con.commit()  
  26. con.close() 

Jython数据库插入的这部分有许多新内容。

con.setAutoCommit(0) 用于关闭自动提交(auto commit),就像 JDBC 调用中的 con.setAutoCommit(false) 一样。

用于成批插入的 stmt.addBatch(sql) 、 stmt.executeBatch() 能有效地加快批量插入的速度。该技术还在 Neo 的加载仿真器中用于进行大容量的插入。

global stmt 将使 stmt 成为一个共享的全局变量,很适用于该环境中。

def createEmployee(**args) 接收参数为字典 args ,并显示 Jython 函数声明是多么灵活。

sql=sqlTemplate % args 使用基于字典的 SQL 字符串格式化,我们在 select2.jy 中已经了解。

【编辑推荐】

  1. Jython开发的JUnit测试包
  2. 创建Jython类的过程探讨
  3. 轻松创建Jython全局函数
  4. 直接在源文件中编写Jython代码
  5. Jython入门指导:语言特性简介

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...