编程开发 > ASP > 文章内容

ASP教程:数据库查询语言(1)

2017-6-7编辑:daibenhua

  1、Select 子句列出所有要求 SELECT 语句检索的数据项。它放在 SELECT 语句开始处,指定此查询要检索的数据项。这些数据项通常用选择表表示,即一组用“,”隔开的选择项。按照从左到右的顺序,每个选择项产生的一个列的查询结果,一个选择项可能是以下项目:

  (1)、列名:标识 FROM 子句指定表中的列。如果列名作为选择项,则 SQL 直接从数据库表中每行取出该列的值,再将其放在查询结果的相应行中。

  (2)、常数:指定在查询结果的每行中都放上该值。

  (3)、SQL 表达式:说明必须将要放入查询结果中的值按表达式的规定进行计算。

  2、From 子句列出包含所要查询数据的表,它由关键字 FROM 后跟一组用逗号分开的表名组成。每个表明都代表一个包括该查询要检索数据的表。这些表称为此 SQL 语句的表源,因为查询结果都源于它们。

  3、Where 子句告诉 SQL 只查询某些行中的数据,这些行用搜索条件描述。

  4、Group By 子句指定汇总查询,即不是对每行产生一个查询结果,而是将相似的行进行分组,再对每组产生一个汇总结果。

  5、Having 子句告诉 SQL 只产生有 Group By 得到的某些组的结果,和 Where 子句一样,所需要的组也用一个搜索条件指定。

  6、Order By 子句将查询结果按一列或多列中的数据排序。如果省略此子句,则查询结果将是无序的。

  下面作者将提供一个简单但实用的运用 SQL 语句查询的 ASP 程序供大家参考。

  为了使大家更清楚更直接地了解 SQL 语法在 ASP 中的应用,我们先将查询的所有核心过程写成一个名为 query2table 的 SUB,然后利用 ASP 的服务器端包容功能调用该 SUB。请将以下语句剪贴到记事簿,保存为 subdbtable.inc 文件,并置于虚拟目录 asptest 下 :

  < %

  sub query2table(inputquery)

  set conntemp=server.createobject("adodb.connection")

  conntemp.open "DSN=Student;uid=student;pwd=aspmagic"

  set rstemp=conntemp.execute(inputquery)

  howmanyfields=rstemp.fields.count -1

  ' 统计数据库中的列数

  %>

  < table border=1>< tr>

  < %

  for i=0 to howmanyfields

  %>

  < td>< b>< %=rstemp(i).name%>< /B>< /TD>

  < % next %>

  < /tr>

  < %

  do while not rstemp.eof

  %>

  < tr>

  < % for i = 0 to howmanyfields

  thisvalue=rstemp(i)

  If isnull(thisvalue) then

  thisvalue="?

  ' 如果字段为空,则将变量 thisvalue 的值定义为一个空格

  end if%>

  < td valign=top>< %=thisvalue%>< /td>

  < % next %>

  < /tr>

  < %rstemp.movenext

  loop%>

  < /table>

  < %

  rstemp.close

  set rstemp=nothing

  conntemp.close

  set c

  onntemp=nothingend sub%>

  完成了 SUB 的定义过程,在下面几个 ASP 程序中我们只要加入想要使用的 SQL 查询语句,并调用该过程就可以非常方便的得到查询结果。将以下四段代码分别保存为 asp11a.asp、asp11b.asp、asp11c.asp、asp11d.asp 四个 .asp 文件。

  < HEAD>< TITLE>asp11a.asp< /TITLE>< /HEAD>

  < HTML>< body bgcolor="#FFFFFF">

  < %

  call query2table("select * from publishers where name like 'A%%'")

  ' 将表 publishers 中所有姓名中有字母 A 的记录查询出来

  %>

  < !--#include virtual="/asptest/subdbtable.inc"-->< /BODY>< /HTML>

  < HEAD>< TITLE>asp11b.asp< /TITLE>< /HEAD>< HTML>< body bgcolor="#FFFFFF">

  < %

  call query2table("select * from titles where Year_Published > = 1998")

  ' 将表 titles 中所有发表年份大于或等于 1998 年的记录查询出来

  %>

  < !--#include virtual="/asptest/subdbtable.inc"-->< /BODY>< /HTML>

  < HEAD>< TITLE>asp11c.asp< /TITLE>< /HEAD>< HTML>< body bgcolor="#FFFFFF">

  < %

  call query2table("select * from publishers where amount>10000 and sex='male'")

  ' 将表 publishers 中所有数量大于 10000 且性别为男的记录查询出来

  %>

  < !--#include virtual="/asptest/subdbtable.inc"-->< /BODY>< /HTML>

  < HEAD>< TITLE>asp11d.asp< /TITLE>< /HEAD>< HTML>< body bgcolor="#FFFFFF">

  < %

  call query2table("select * from publishers where state< > 'NY'")

  '将表 publishers 中所有所在城市不为纽约的记录查询出来。

  %>

  < !--#include virtual="/asptest/subdbtable.inc"-->< /BODY>< /HTML>

  利用 subdbtable.inc 文件中的所定义的过程 query2table,你就可以非常迅速地对数据库进行查询,你所要做的只是将“conntemp.open "DSN=Student;uid=student;pwd=aspmagic"”中的数据库名称、用户身份和密码稍加改动,并在调用 query2table 时输入想要使用的 SQL 查询语句即可。是不是很简单 ? 这就是 ASP 和 SQL 的魅力所在 !!!

ASP教程:ASP内建对象Response

热点推荐

登录注册
触屏版电脑版网站地图