ASP进阶教程:留言查询功能(一)

2016-01-29 19:57 5 1 收藏

ASP进阶教程:留言查询功能(一),ASP进阶教程:留言查询功能(一)

【 tulaoshi.com - ASP 】

     当有一天,你的心情突然变得很坏,但是巧合的是,在你的留言簿中你的网友留了一句很让你振奋的话,于是你很快就重拾了快乐的心情。但是在不久后你又一次心情变坏,但是这次却没有上次那么幸运,因为没有人给予你鼓励,于是你自然就想再看一看上次那句令你很受振奋的话。这时你就会想:假如我的留言簿有留言查询功能就好了!


  为了能达成你的心愿,于是我决定在本章教程为你解说具有留言查询功能的留言簿程序。在讲解之前,让我们还是先来学习将在源程序中用到的COMMAND对象。
  

  首先让我们先来了解一下Command对象所提供的属性和方法以及它们的相应功能


ActiveConnection属性--建立与Connection通道的链接关系
CommandText属性--指定数据查询信息
CommandTimeout属性--开始执行数据查询后允许继续执行的最长时间
CommandType属性--指定数据查询信息的类型
Prepared属性--指定数据查询信息是否要先行编译
CreateParameter方法--建立一个新的参数对象
Execute 方法--对数据库提出数据查询


  Command对象也是ADO对象集合的一员,它主要用来控制对数据库发出的请求信息,告诉数据库:“要哪个数据表里的数据?要什么字段内的数据?数据必须符合什么限制?请把这些符合我要求的数据全部存放在Recordset对象内返回回来!”那么说到底,Command对象的功能就是执行SQL(Structured Query Language结构式查询语言,是用于对存放在计算机数据库中的数据进行组织、管理和检索的一种工具;是一种特定类型的数据库--关系数据库)命令。假如你是一位比较细心的人,你一定还记得我在第三章中其实就已经用上了SQL命令,于是你就会对我发问:“你当时并没有用到Command对象呀?”


  确实,没有Command对象我们也一样可以执行SQL命令。我们利用Connection对象或是利用Recordset对象同样可以执行SQL命令。方法如下所示:



Set rs = conn.Execute(SQL命令)
' 利用Connection对象执行Select SQL命令,然后将结果指定给Recordset对象。
conn.Execute SQL命令
' 利用Connection对象执行数据操作的SQL命令。
Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open SQL命令,conn


' 先建立Recordset对象,再执行SQL命令选取数据。
利用Command对象又是如何来执行SQL命令的呢?大家请看:
Set cmd = Server.CreateObject("ADODB.Command")
Set cmd.ActiveConnection = conn
cmd.CommandText = sql
Set rs = cmd.Execute


' 可见利用Command对象来执行SQL命令,得先将Connection对象及SQL命令设置给对象Command的ActiveConnection及CommandText属性,然后才执行cmd.Execute函数。


  由上述我们可以知道,原来使用Recordset对象和使用Command对象来执行SQL命令,本质都是一样的。既然如此,那么我们为什么还要利用Command对象呢?为了说明这个问题,我分别用两种不同的方法来为留言簿添加留言查询功能,其中查询“留言簿过去五天留言记录”和“留言记录日期查询”是利用Command对象来执行SQL命令的,而“留言者姓名查询”和“最新十条留言记录”的查询则是利用Recordset对象来执行SQL命令。

  讲了这许多也该入正题了,我们首先来学习的是利用Recordset对象来实现“留言者姓名查询”和“最新十条留言记录”的查询。以下我们还是通过分步骤的方法来进行说明。

步骤一: 首先我们得设计一个留言查询的界面(Datesearch.asp),如下图所示:





步骤二:利用Recordset对象来执行SQL命令,实现“最新十条留言记录”的查询。
Set conn = Server.CreateObject("ADODB.Connection")
DBPath = Server.MapPath("book2.mdb")
conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath
sql ="select top 10 * from guestbook order by ID Desc"


  这里用“ order by ID Desc”表示按照“ID”字段从大到小排序。因为在数据库中我将ID字段的数据类型设为“自动编号”,留言记录的ID将按先后从小到大进行排序,所以要查询最新的十条留言即是查询最后的十条ID的记录。
Set rs = conn.Execute( sql )

  利用Recordset对象来执行SQL命令,实现“留言者姓名”的查询的原理与上述一致,程序如下所示:


namesearch = request.form("name")
namesearch = Replace(namesearch,"'","''")
'还记得我在第三章中介绍SqlStr函数时的说明吗?忘了就到回去看看吧。
Set conn = Server.CreateObject("ADODB.Connection") DBPath =Server.MapPath("book2.mdb")
conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & DBPath
sql ="select * from guestbook where 姓名 = '"&namesearch&"' order by ID Desc"
Set rs = conn.Execute( sql )


步骤三:设计查询结果的Web页面(Search.asp)。

<

来源:http://www.tulaoshi.com/n/20160129/1510431.html

延伸阅读
标签: ASP
        为了能使我们做出来的留言簿更美观,让我们来给上一章的简单留言簿润下色,再令其留言在另外的一个单独的页面显示。 那么怎样给该留言簿润色呢?留言表单界面的背景总不能没吧?而且为了让留言表单的内容显示得更加规整,我们是否有必要用框架将留言表单的内容框起来呢?想好了,现在就让我们立即动...
标签: ASP
      如何编写一个自己喜欢的留言薄呢?本文将以 Active Server Pages 为中心,向你全面展示制作的过程,并使用大量的例子循序渐进地为大家进行讲解和演示,让你在不断的理论和实践之中更轻松地跨入ASP的大门。当然在学习应用ASP之前,让我们先来看一下ASP到底有什么优点。 ASP(Active Server Pages)动态网页,...
标签: ASP
在前面我们介绍了文件版本的留言簿,现在我们不妨来设想一下:如果留言文件里面的留言很多,而你又急于想寻找其中的某条留言时,这时打开txt留言文件,对着一段段的留言记录,你敢担保你不会当场晕倒吗?而且文件留言簿最令人讨厌还远不只是这个原因,更气人的是:譬如你已经找到了你要找的留言,而且是非要将其删除不可(当然是因为那段留...
标签: ASP
ASP本身没有发送邮件的能力,但是如果你希望用ASP来发送E-MAIL(例如:你有一个消息,只想让那些在你的留言薄上留了言的上网者们知道,你希望上网者在你的留言薄上填写完成后,你的留言簿便自动将该消息E-MAIL给留言的上网者),那么你需要安装一个ASP组件。并借助这些组件来帮你实现邮件的自动发送、回复等工作。 如果你的ASP及WEB...
标签: ASP
        ASP本身没有发送邮件的能力,但是如果你希望用ASP来发送E-MAIL(例如:你有一个消息,只想让那些在你的留言薄上留了言的上网者们知道,你希望上网者在你的留言薄上填写完成后,你的留言簿便自动将该消息E-MAIL给留言的上网者),那么你需要安装一个ASP组件。并借助这些组件来帮你实现邮件的自动发送、回...

经验教程

900

收藏

51
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部