请教ASP查询ADO数据库的问题,气死我了。

pursue 2000-07-24 04:58:00
请教ASP查询ADO数据库的问题,气死我了。

编了快两年的程序,一直一次为乐,前些天迷上了ASP,特别是操作ADO。以前我对数据库不感兴趣,接触尚少,因此问题多多。但在众多高手的指点下我解决了一个又一个问题。这次我又遇上了查询数据的问题,感到绝望。
问题如下:
从page1.asp提交表单(只包括一个文本框name),由page2.asp处理。data.mdb是Access数据库,只有一个表namelist,其中namelist包含name,age等多个字段,其中各记录name的值不会重复。我的要求是在namelist中找字段name中与提交的name一样的记录,如果找到就得到的ID值,否则得知找不到。
之所以让提交表单的页面page1为asp文件,是为了用<% Response.Expires=0 %>。
以下是page2.asp的代码:
<%
Response.Expires = 0 '我不知这句在此有用没用
name=Request("name")
name = Replace(name,"'","''")
If name="" Then
Response.Write "没有输入名字!"
Response.End
End If
Set conn = Server.CreateObject("ADODB.Connection")
DBPath = Server.MapPath("data.mdb") '我肯定路径没错
conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath
Set cmd = Server.CreateObject("ADODB.Command")
Set cmd.ActiveConnection = conn
cmd.CommandText = "SELECT * FROM namelist WHERE name = '" & name & "' ORDER BY ID DESC" '我不知这句是否正确,因为我只要找到一条记录,为什么还要ORDER BY ID DESC" ?我还试着用Access为data.mdb建了一个叫FindName的查询,把namelist的name字段加入其中,并把这句改成cmd.CommandText = "FindName" ,也会出现下边的问题

'这样返回了rs,可是我如何得到想要的呢?我试着用rs.Fields(0).Value不成
。。。。。。。。。。。。。
rs.Close
conn.Close
Set rs=Nothing
Set conn=Nothing
%>

后来我自己写代码查询,如下:
<%
Response.Expires = 0
name=Request("name")
name = Replace(name,"'","''")
If name="" Then
Response.Write "没有输入名字!"
Response.End
End If
Set conn = Server.CreateObject("ADODB.Connection")
DBPath = Server.MapPath("data.mdb")
conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath
set rs=Server.CreateObject("ADODB.Recordset")
rs.open "namelist",conn,3
Found=False
While (Not rs.EOF) And (Found=False)
If rs.Fields(0).Value = name Then Found=True
rs.MoveNext
Wend
If Found=True Then
rs.MovePrevious
Response.Write rs.Fields(0).Value
Else
Response.Write "Can't Found!!"
End If
rs.Close
conn.Close
Set rs=Nothing
Set conn=Nothing
%>
这样当输入内容后第一次可显示正确的信息,按浏览器的后退,到page1.asp再来一次时无论输入的name在不在namelist里,都会在conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath 这句包错,还有用第一个程序处理也会在此处包错,但我用此方法读写数据库(就是没有查询)的另一个程序却可以正常运行,这是为何?
由于我木摸不着头脑,就把情况全写出来了,还请高手们耐心指点,谢谢。
...全文
132 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
mjs2000 2000-07-24
  • 打赏
  • 举报
回复
Response.Expires = 0 有用,你可以限定客户端对此页保持的时间0则说明是立即过时,这样在用户浏览此页时,就会从新从服务器端读取,否则则从缓存中读取(在限定的时间内)。这样在你提交数据后他会即时更新,避免一些缓存的问题(保持的数据信息)。

cmd.CommandText = "SELECT * FROM namelist WHERE name = '" & name & "' ORDER BY ID DESC" '我不知这句是否正确,因为我只要找到一条记录,为什么还要ORDER BY ID DESC" ?
我认为此句是正确的,不要ORDER BY ID DESC也可以,此句的目的是按降序方法把Record集合读到Rs中。


你在Response.Expires = 0 前面加一句Response.Buffer=False你试一下
Tyro 2000-07-24
  • 打赏
  • 举报
回复
1、报错信息是什么?
2、你文中提到“'这样返回了rs”,得到rs这段是怎么写的?
huntout 2000-07-24
  • 打赏
  • 举报
回复
<%
Response.Expires = 0 '有用
name=Request("name")
name = Replace(name,"'","''")
If name="" Then
Response.Write "没有输入名字!"
Response.End
End If
Set conn = Server.CreateObject("ADODB.Connection")
DBPath = Server.MapPath("data.mdb") '我肯定路径没错
conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath
set rs = conn.execute("SELECT * FROM namelist WHERE name = '" & name & "'")
if rs.eof then
response.write "沒有這個名字!"
else
'rs("id")
'rs("age")
......
end if
rs.Close
conn.Close
Set rs=Nothing
Set conn=Nothing
%>
酷窗版演示:http://www.edd8.com/bbs/index.asp?style=0 简装版演示:http://www.edd8.com/bbs/index2.asp 一点点论坛(http://www.edd8.com/bbs)使用说明 欢迎大家下载使用一点点论坛,在使用论坛前,请认真阅读以下内容: ===================================== 论坛:一点点论坛(http://www.edd8.com/bbs) 主页:一点点星空驿站(http://www.edd8.com/) 站长:叮咚虫(e_Mail:b_li@163.com) 版本:EDD8 Ver.2003 for DV =====================================   一点点论坛是建立在动网论坛基础上的ASP互动论坛,从动网Var5.b109开始论坛结构便开始脱离动网,与动网升级一起,本论坛本身也同时实现了动网新的功能,到519的发布,本人常得论坛本身已功能基本完善,所以决定与动网完全脱离,到动网Final的出现,本论坛也决定不再跟随动网升级了,本人全面对原来的论坛进行了代码优化和版面重排,并升级了部分功能代码,完成了现在这样的论坛。使论坛已经完全脱离了动网,以后也不可以随动网一起升级了!   所以选择本论坛的朋友请先明白,如果采用了本论坛的数据结构,以后就不可以和动网一起升级了,而现有的动网Final版的数据库和本论坛的数据库也是不兼容的!对于动网V5.b519的用户,本人同时在压缩包里提供了升级文件,可以把你519的数据库升级成和本论坛一致的数据结构!   由于一些朋友催得较急,部分功能还是没有完善的(但不会出错),我以后也会给出升级包的。所以决定使用本论坛的朋友,请一定要到本站论坛的“站务办公室”进行指定的留言签名,以好我第一时间通知大家升级!   论坛中使用到的部分插件并没有一同奉上,原因是我还没完成代码优化,请过几天到我的论坛上下载。可以下载的插件主要有:社区银行、网络拳皇、可乐吧台球、五子棋等等…… ===================================== 主要特色功能说明: ◎ 双版面设计,用户可以根据不同爱好选择不同的版式(酷窗版和精简版),系统会记录用户的选择,不用重复选择,也不会出现版面混淆等现象; ◎ 发贴回贴互动功能,给用户随机的互动事件,增加用户的参与兴趣; ◎ 增强的UBB代码和JS代码,新增的买卖贴、定时贴等十几种特色功能UBB代码; ◎ 贴子功能加强,增加互动鲜花、鸡蛋、金钱、炸弹等功能,并保存数据作为用户在论坛的人缘依据; ◎ 不好说了,等你去发掘吧,不然又说我叫卖了…… ====================================== 安装说明: 解压就可以了,数据库名称和路径有变动时不要忘了在CONN。ASP中进行相应修改。 (注意:当论坛中一个贴子也没有时,论坛明星会出错,但当你加入贴子后就正常了,大家不要惊慌) 升级:(对519),解压后把你的原519数据库覆盖现数据库,再执行根目录下的UPDATE。ASP文件就行了,如果没有升级成功的提示,说明你的数据不能进行升级! (注意:数据库的升级应做了备份,并在本机上进行!) ====================================== 最后一点说明: 由于论坛本来是打算自己用的,所以在设计的过程中部分变量已经去掉,不能从后台设置了(如表格边框),请大家最好保持现有的风格。 如果还不问题,可以到我的论坛上来交流。??注意,由于本人时间不限,技术支持是有限的,请不要过于强求!

28,391

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧