51Testing软件测试论坛

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

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2220|回复: 5
打印 上一主题 下一主题

[原创] 数据库查询的问题

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2006-4-5 11:28:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
function chaxun(names,desc)
'连接数据库
Set conn = CreateObject("ADODB.Connection")
conn.Open "driver={SQL Server};server=192.168.0.201;uid=sa;pwd=sa;database=configure&manage"
If conn.State = 0 Then
     msgbox "连接数据库失败"
else
     msgbox  "连接数据库成功"
End If

'查询数据库
Set rs = conn.Execute("SELECT * FROM scm_groups WHERE id = 51")
names = rs("GroupName").Value
desc = rs("GroupDesc").Value
end function

我想把 id = 51 中的51用一个变量替换,变量的值从50开始依次+1 ,请教我应该怎么做呢??
我试了
for i=50 to 100
Set rs = conn.Execute("SELECT * FROM scm_groups WHERE id = i")
next
可这样做会报 i 不是有效列



还有个问题就是   nvarchar 和  int  之间应该怎么转换啊~~~~~~~

[ 本帖最后由 unimapmajj 于 2006-4-5 11:30 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2006-4-5 11:59:00 | 只看该作者
("SELECT * FROM scm_groups WHERE id = i")

这样写 i 作为字符使用的而不是变量

("SELECT * FROM scm_groups WHERE id = " & i )
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2006-4-5 13:29:50 | 只看该作者
这个……最最最最基础的编程问题,字符串要用引号,而变量不能用引号……

另外,在SQL语句中,字符串用单引号,你最好写成SELECT * FROM scm_groups WHERE id = '51',可能数字没问题,换成字母就会有问题了……
回复 支持 反对

使用道具 举报

该用户从未签到

4#
 楼主| 发表于 2006-4-5 14:08:24 | 只看该作者
谢谢   问题解决了
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2006-4-5 16:31:36 | 只看该作者
建议sql语句作为参数传入chaxun的方法。
而且你可以这样写SQL:
select * from  scm_groups WHERE id >=50 and id <=100;
这样直接传SQL语句进来执行,结构比较好一点
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2006-4-5 17:25:35 | 只看该作者
哪位给详细 介绍一下create object 的用法
多谢 !!
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

GMT+8, 2024-11-28 10:30 , Processed in 0.086085 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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