51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 3788|回复: 11
打印 上一主题 下一主题

[讨论] 【已解决】不同参数取值方式导致调用函数失败?

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2009-8-15 14:28:11 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Function 功能说明:根据条件查询DB里面某个字段的值,参数:查询条件值
test 功能说明: 传递参数,调用function。
      参数有两种赋值方式:
          方式1: 直接赋值。a="123456"
          方式2:通过datatable 取值。a=DataTable.Value("a",Global)   //在global table 里面已经设好a的值等于123456
      相同函数调用语句:DBfileName=ConnectDB(a)
现在的问题是:
        用方式1,可以调用函数成功返回DB里面的filename。但是用方式2不行,得到的filename为空?


Function 代码如下:
Function ConnectDB(a)                ‘Debug的结果a 的值通过两种方式传入均是一样的,都是123456
   Dim strCon,SQLQuerySentence
   strCon = "Driver={Microsoft ODBC for Oracle}; " & _
         "CONNECTSTRING=(DESCRIPTION=" & _
         "(ADDRESS=(PROTOCOL=TCP)" & _
         "(HOST=***)(PORT=***))" & _
         "(CONNECT_DATA=(SERVICE_NAME=***))); uid=***;pwd=***;"
   Dim oCon
     Set oCon = CreateObject("ADODB.Connection")
   Dim oRs
     Set oRs = CreateObject("ADODB.Recordset")
     SQLQuerySentence = "SELECT * tablename WHERE filecode ="
     SQLQuerySentence = SQLQuerySentence + "'"+a +"'"
     oCon.Open strCon
     Set oRs = oCon.Execute(SQLQuerySentence)
   Dim MSGLink
   While Not oRs.EOF               'debug结果是用方式1的时候oRs.EOF是false,方式2的时候oRs.EOF是true。但是SQLQuerySentence 都是相同一句话。为什么会这样呢?
     MSGLink=oRs.Fields(6).Value
     oRs.MoveNext
    Wend
msgbox MSGLink
  Dim LinkArray,filename
   filename=Mid(MSGLink,42,75)     '
   msgbox XMLname
    oCon.Close
  Set oRs = Nothing
  Set oCon = Nothing
  ConnectDBXML=filename
End Function

[ 本帖最后由 topor 于 2009-8-17 10:08 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

  • TA的每日心情
    开心
    2016-8-25 11:11
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    2#
    发表于 2009-8-15 14:47:57 | 只看该作者
    DBfileName=ConnectDB(DataTable.Value("a",Global))
    这样写试试。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2016-8-25 11:11
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    3#
    发表于 2009-8-15 15:37:20 | 只看该作者
    是你写错了。
    a=DataTable.Value("a",dtGlobalSheet)
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    4#
     楼主| 发表于 2009-8-15 16:32:42 | 只看该作者
    原帖由 liujinkui 于 2009-8-15 15:37 发表
    是你写错了。
    a=DataTable.Value("a",dtGlobalSheet)


    我那样写是正确的,因为我后面有msgbox出来看,value是正确的。
    Debug到函数里面看传的参数也是正确的,就是函数里面那个判断DB查询结果的语句两种方式运行结果不一样。
    我试过了
    a=DataTable.Value("a",dtGlobalSheet)
    a=DataTable.Value("a",Global)
    两者运行结果是一样的,你可以自己再试试...
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    5#
     楼主| 发表于 2009-8-15 16:33:19 | 只看该作者
    原帖由 liujinkui 于 2009-8-15 14:47 发表
    DBfileName=ConnectDB(DataTable.Value("a",Global))
    这样写试试。


    肯定不能这样写了,因为a是一个变量,不能用""的。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2016-8-25 11:11
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    6#
    发表于 2009-8-15 22:58:36 | 只看该作者
    Global 里有个a列, 问题应该不在这
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2016-8-25 11:11
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    7#
    发表于 2009-8-15 23:00:06 | 只看该作者
    SQLQuerySentence = SQLQuerySentence + "'"+a +"'"
    这条语句不用+ 用&,试试
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    8#
    发表于 2009-8-16 16:52:27 | 只看该作者
    不错,学习了~~~
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    9#
     楼主| 发表于 2009-8-17 09:44:32 | 只看该作者
    原帖由 liujinkui 于 2009-8-15 23:00 发表
    SQLQuerySentence = SQLQuerySentence + "'"+a +"'"
    这条语句不用+ 用&,试试


    试过了,结果还是一样的。两种方式的运行结果不一样。
    为什么呢?
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    10#
     楼主| 发表于 2009-8-17 10:10:03 | 只看该作者
    找到问题的根源了,其实两种方式都是可以的。
    是因为我datatable里面的那个值多了一个空格,晕死了...
    多谢liujinkui 一直的关注,呵呵
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    11#
    发表于 2009-8-17 10:26:36 | 只看该作者
    汗!

    DataTable的这种错误常见!!!大家小心了!!
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    12#
    发表于 2009-8-17 15:25:59 | 只看该作者
    vbs中,常见的错误就是空格的问题了。

    还有就是路径的调用,也有同样的问题。
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-19 17:50 , Processed in 0.073968 second(s), 26 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表