51Testing软件测试论坛

标题: 如何把DataTable里面的数据放在数据库查询语句中 [打印本页]

作者: puccaguo    时间: 2008-7-24 15:21
标题: 如何把DataTable里面的数据放在数据库查询语句中
我想做数据库检查点,写的sql语句是:select  T.row1 from t where t.row2 = ***
这个***我希望是QTP在DataTable里面的数据,例如是DataTable.RawValue("Name1",dtLocalSheet)。请问这个时候我应该怎么处理啊?
谢谢各位。
作者: flying-kite    时间: 2008-7-24 22:51
QTP无法做到动态数据库检查的,SQL语句得出的结果必须是明确的。
既然你已经有数据在DataTable里,直接写到SQL语句不行吗?还是你要循环取DataTable里的值作为SQL语句的查询条件?
作者: xiaonan    时间: 2008-7-25 09:57
这个不难吧,你把DataTable里面的数据取出来,放进一个变量.然后就是个拼接 select语句的过程了. 你的这个select语句哪里用的,先问一下?
作者: luckxiaot    时间: 2008-7-25 13:28
cls_id  =DataTable("f_cls_id","Global")
sql="select count(*) from aa where f_cls_id='"&cls_id&"' "
作者: puccaguo    时间: 2008-7-28 12:29
标题: 回复 3# 的帖子
我这个selcet语句是放在数据库检查点里面的
作者: puccaguo    时间: 2008-7-28 12:29
标题: 回复 2# 的帖子
是要循环取DataTable里的值作为SQL语句的查询条件
作者: puccaguo    时间: 2008-7-28 12:30
标题: 回复 4# 的帖子
谢谢,我试试先。谢谢你哦
作者: puccaguo    时间: 2008-7-28 14:03
标题: 回复 4# 的帖子
好像不行啊。这样写的sql语句通过不了啊。
作者: 今天有雾    时间: 2008-7-28 14:14
SQL的写法应是

select table.列名 from table,不能写成select * from table
作者: lijian422202    时间: 2008-7-28 14:21
4楼正解。。不过4楼说的是不放在QTP自带的数据库检查点中的,需要自己写adodb,就看你的数据是什么了,加载不同的驱动就行。
作者: puccaguo    时间: 2008-7-29 16:34
标题: 回复 10# 的帖子
我是插入数据库输出值,然后选择Specify SQL statement manually这样做的。有什么方法啊?还有你说的,怎样自己写adodb啊?
作者: puccaguo    时间: 2008-7-29 16:39
我加载的驱动程序是oracle92
作者: puccaguo    时间: 2008-8-1 17:19
有没有人能帮帮我?




欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2