标题: 数据库查询的问题 [打印本页] 作者: unimapmajj 时间: 2006-4-5 11:28 标题: 数据库查询的问题 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 编辑 ]作者: 海龙 时间: 2006-4-5 11:59
("SELECT * FROM scm_groups WHERE id = i")
这样写 i 作为字符使用的而不是变量
("SELECT * FROM scm_groups WHERE id = " & i )作者: Horus_Ra 时间: 2006-4-5 13:29
这个……最最最最基础的编程问题,字符串要用引号,而变量不能用引号……
另外,在SQL语句中,字符串用单引号,你最好写成SELECT * FROM scm_groups WHERE id = '51',可能数字没问题,换成字母就会有问题了……作者: unimapmajj 时间: 2006-4-5 14:08
谢谢 问题解决了作者: mstiunicon 时间: 2006-4-5 16:31
建议sql语句作为参数传入chaxun的方法。
而且你可以这样写SQL:
select * from scm_groups WHERE id >=50 and id <=100;
这样直接传SQL语句进来执行,结构比较好一点作者: xiaomaoxiaogou 时间: 2006-4-5 17:25
哪位给详细 介绍一下create object 的用法
多谢 !!