仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 426|回复: 8
打印 上一主题 下一主题

[学习教程] ASP网页设计手把手教你在ASP中利用SQL语句

[复制链接]
若相依 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:11:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
国内有些大的CRM厂商的ASP就写得不错.无论是概念还是它里面用JAVASCRIPT的能力.并不是说现在的程序员用了ASP.NET来写程序就可以说自己高档了sql|语句八门五花的SQL产物多得要命,也许你早顾不得别的甩开袖子就下手干了。但你要同时接纳ASP和SQL的话便可能会头晕。MySQL、SQLServer和mSQL都是尽佳的SQL工具,惋惜,在ASP的情况下你却用不着它们来创立有用的SQL语句。不外,你能够使用本人把握的Access常识和响应的Access妙技,再加上我们的提醒和技能,信任必定能乐成地在你的ASP网页中到场SQL。


1.SELECT语句

在SQL的天下里,最最基本的操纵就是SELECT语句了。在数据库工具下间接接纳SQL的时分良多人城市熟习上面的操纵:
SELECTwhat
FROMwhichTable
WHEREcriteria

实行以上语句就会创立一个寄存其了局的查询。

而在ASP页面文件上,你也能够接纳以上的一样平常语法,不外情形略微分歧,ASP编程的时分,SELECT语句的内容要作为字符串赋给一个变量:
SQL="SELECTwhatFROMwhichTableWHEREcriteria"

好了,分明了ASP下SQL“措辞”的体例,接上去依样画葫芦便可,只需满意你的必要,传统的SQL查询形式和前提查询都能派用处。

举例申明,无妨假定你的数据库内有个数据表,名字是Products,如今你想掏出这个内外的全体纪录。然后你就编写了上面的代码:
SQL="SELECT*FROMProducts"

以上代码――SQL语句的感化就是掏出表内的全体数据――实行后将会选出数据表内的全体纪录。不外,如果只想从表内掏出某个特定列,好比p_name。那就不克不及用*通配符了,这里得键进详细某列的名字,代码以下:
SQL="SELECTp_nameFROMProducts"

实行以上查询以后Products表内、p_name列的内容就会全被拔取出来。


2.用WHERE子句设置查询前提

有的时分掏出全体数据库纪录大概恰好满意你的请求,不外,在年夜多半情形下我们一般只需失掉部分纪录。如许一来该怎样计划查询呢?固然会更费点头脑了,况且本文也居心不想让你往用谁人甚么劳什子的recordset。

举个例子,假设你只盘算掏出p_name纪录,并且这些纪录的名字必需以字母w打头,那末你就要用到上面的WHERE子句了:
SQL="SELECTp_nameFROMProductsWHEREp_nameLIKEW%"

WHERE关头词的前面随着用来过滤数据的前提,有了这些前提的匡助,只要满意必定尺度的数据才会被查询出来。在以上的例子里,查询的了局只会失掉名字以w打头的p_name纪录。

以上例子中,百分比标记(%)的寄义是唆使查询前往一切w字母打头并且前面是任何数据乃至没无数据的纪录条目。以是,在实行以上查询的时分,west和willow就会从Products表内被拔取出来并寄存在查询里。

就像你看到的那样,只需细心地计划SELECT语句,你就能够限定recordset中前往的信息量,多揣摩揣摩总能满意你的请求。

这些啊还不外是把握SQL用处刚起步。为了匡助你慢慢把握庞大的SELECT语句用法,上面就让我们再来看一下关头的尺度术语:对照运算符,这些玩意都是你在修建本人的SELECT字符串来取得特定命据时要常常用到的。

WHERE子句基本
在入手下手创立WHERE子句的时分,最复杂的体例是接纳尺度的对照标记,它们是<、<=、>、>=、和=。明显,你很快就可以分明以下代码的寄义和详细运转了局:
SELECT*FROMProductsWHEREp_price>=199.95
SELECT*FROMProductsWHEREp_price19.95
SELECT*FROMProductsWHEREp_version=4

注重:这里你会注重到,最初一个例句中的数字4四周加了单引号。缘故原由是如许的,在这个例子中的4是文本范例而非数字范例。由于你会把SELECT语句放到引号中来把它作为一个值赋给变量,以是你也能够在语句中接纳引号。

对照运算符

对照运算符指定从表内掏出数据的内容局限。你能够用它们来创立过滤器以便减少recordset的局限,促使其只保留给定义务下你体贴的信息。

3.LIKE、NOTLIKE和BETWEEN


你已在下面掏出w打头纪录的例子中看到了LIKE的用法。LIKE判断词是一个十分有效的标记。不外,在良多情形下用了它大概会带给你太多的数据,以是在用到它之前最好先开动头脑多想一想本人究竟想取得甚么数据。假定你想掏出5位数字的SKU号码,并且其开首是1开头是5,那末你能够用下划符(_)取代%标记:
SQL="SELECT*FROMProductsWHEREp_skuLIKE1___5"

下划符暗示恣意一个字符。以是在输出“1___5”的情形下,你的搜刮就会限定在满意特定形式的5位数局限内了。

假设你想反其道而行之,要找出一切不婚配“1___5”形式的SKU条目。那末你只必要在方才语句例子中的LIKE后面加上NOT就能够了。

BETWEEN
假定你想掏出必定局限内的数据,并且你事前晓得局限的出发点和尽头,那末你无妨接纳BETWEEN判别词。如今就让我们假定你想拔取给定表内局限在1和10之间的纪录。你能够以下利用BETWEEN:
…WHEREIDBETWEEN1AND10

大概你也能够接纳已熟习的数学判别字句:
…WHEREID>=1ANDID>=10


4.团结语句

我们到今朝为止所谈到的SQL语句绝对较为复杂,假如再能经由过程尺度的recordset轮回查询,那末这些语句也能满意一些更庞大的请求。不外,何须非要拘泥在浅尝则止的基本水准之上呢?你完整能够再增添其他一些标记,好比AND、OR和NOT来完成更壮大的功效。

以上面的SQL语句为例:
SQL="SELECTc_firstname,c_lastname,c_emailFROMcustomersWHEREc_emailIS
NOTNULLANDc_purchase=1ORc_purchase=2ANDc_lastnameLIKE
A%"

就你今朝所把握的SQL常识,以上的例子也不难明释,不外下面的语句并没有很分明地让你看清前提字句是怎样胶合在单一SQL语句中的。

多行语句
在SQL语句欠好懂的情形下,你无妨把全部语句分化为多行代码,然后在现有变量基本上慢慢增添查询语句的各个构成部分并把它存在统一变量内:
SQL="SELECTc_firstname,c_lastname,c_emailaddress,c_phone"
SQL=SQL&"FROMcustomers"
SQL=SQL&"WHEREc_firstnameLIKEA%andc_emailaddressNOTNULL"
SQL=SQL&"ORDERBYc_lastname,c_firstname"
到了最初一句,SQL变量就包括了以下的完全SELECT语句:
"SELECTc_firstname,c_lastname,c_emailaddress,c_phoneFROMcustomers
WHEREc_firstnameLIKEA%andc_emailaddressNONULLORDERBYc_lastname,
c_firstname"

整句照下面分化以后明显好读多了!在举行调试的时分,你也许更乐于多敲几个字符把程序改得更好读些。不外你可要记着了,在关闭引号之前大概在翻开引号以后你必要增添空格,如许才干包管字符串联接起来的时分你没有把几个词凑到了一块。
5.入手下手实行

在学会了SELECT语句的机关和用处以后你就该进修怎样利用它了。在你所把握的数据库工具下,这大概意味着你得按下某个写着“实行”字样的按钮。在ASP网页上,能够当即实行SQL语句也能够看成存储历程挪用。

一旦创立了SQL语句,你还得想法会见其查询了局。明显,这里的关头就是ASPrecordset。在利用非SQL的recordset时,创立recordset的代码一般以下所示:
DimobjRec
SetobjRec=Server.CreateObject("ADODB.Recordset")
objRec.Open"customers",objConn,0,1,2

假如你对ASP对照熟习以上的代码对你可就不生疏了,你应当晓得“customers”暗示你翻开数据库内一个数据表的名字。

翻开recordset
为了充实使用你更加熟习的SQL妙技,你必要调剂惯例ASP网页上最常接纳的recordset:
DimobjRec
SetobjRec=Server.CreateObject("ADODB.Recordset")
objRec.OpenSQL,objConn,0,1,2

这里独一的修正就是在objRec.Open,以后用包括SQL语句的变量取代了要查询的数据表的称号。

这类办法的长处之一是你能够指定游标范例(如以上0,1,2所示)。

实行SQL
你能够用松散的一行代码实行SQL语句来创立recordset。以下是语法:
DimobjRec
setobjRec=objConn.Execute(SQL)

在上例中,你所看到的SQL是你寄存本人SQLSELECT语句的变量。该代码行“运转”SQL语句(大概说对数据库举行查询),拔取数据并把数据寄存在recordset内,在上例中就是变量objRec。这类办法的次要弱点是你不克不及选择本人想接纳的游标范例。相反,recordset老是用前向游标翻开。

由于游标的原因,你也许盘算熟习两种创立recordset的办法。间接实行查询节俭了键进字符所损耗的工夫,但那样的话你就得接纳默许的游标了,如许有大概遭受常常不克不及一般运转的偏差。不论你详细接纳哪一种举措,二者之间的最年夜的不同也不过乎代码简练与否。在不思索你获得甚么字段、你的尺度是甚么的条件下,也不论你怎样存储数据,接纳SQL式的recordset在体积上会比ASP上翻开的尺度recordset要小很多,更别提操纵起来的浅易性了。究竟,经由过程过滤数据,你打消了泯灭工夫的if-then测试和大概用到的轮回。

编写测试用SQL
这里有个技能,很多专业ASP程序员习气在测试网页的时分“编写”本人的SQL语句。如许做能够匡助你调试代码,由于你能够从中看到传送给服务器实行的字符串。而你要做的不过是增添Response.WriteyourVariable在屏幕上显现有关信息。在你把和SQL有关的成绩提交给ASP会商组的时分你就应当附上这些信息。

6.存储查询


当你的查询绝对复杂的时分,每次重新入手下手创立SQL语句也不费甚么光阴,不外,庞大的查询就分歧了,每次都重新来会发生良多开辟毛病。因而,一旦让SQL顺遂地运转起来,你最好把它们存起来,在必要时再挪用它们。如许,哪怕是一个复杂查询你都能随时用上存储的查询语句了。

假定你每周都要给团队做一次呈报,指出今朝存在的营业撑持成绩,这些数据必要从你的数据库当选取,并且要依照日期选择纪录,同时依据你地点团队所接纳的撑持成绩的种别排序。一旦你计划了这一查询,你何须今后每周都从头编写一次呢?不要在你的HTML页面上创立查询,你应当用你的数据库工具创立查询而且保留它。

然后你能够接纳ActiveCommand属性把查询拔出到你的ASP网页。头一两回你大概会以为没啥意义,实在也就几行代码罢了:
SetobjSQ=Server.CreateObject("ADODB.Command")
objSQ.ActiveConnection="databaseName"

objSQ.CommandText="storedQueryName"
objSQ.CommandType=adCmdStoredProc

setobjRec=objSQ.Execute

注重,接纳adCmdStoredProc暗示你已在页面上包括了adovbs.inc文件。该文件界说了你能够依照名字而非数字举行会见的Access常数。只必要在页面上包括该文件便可(<!--#INCLUDE-->),然后你就能够用adCmdStoredProc这类名字了。如许,未来你再看到的时分更简单了解以上被存储的查询究竟是个甚么意义。

7.ORDERBY

从Access数据库当选取纪录有件最使人沮丧的事变,它们是以如何的按次输出到数据库内就依照如何的按次出来。就算你在Access情况内接纳SortBy来改动纪录视图,数据表内的纪录按次也并没有产生改动。


假如你正在利用ASPrecordset在网页上写出纪录,那末你也许晓得乱纷繁的按次是多使人疾苦的事。可是你大概不能不常常得面临这一成绩,由于其实不存在甚么复杂便利的办理计划。幸亏ORDERBY能够简化这一困难。

为了对你的了局排序,只需在SELECT语句开端加上ORDERBY,然后指定你必要排序的参照列便可。因而,假如你想要依据主顾的姓氏对Customers表排序,那末你能够编写以下的查询语句:
SQL="SELECTc_lastname,c_firstname,c_emailFROMCustomersORDERBYc_lastname"

如许,只需你创建了recordset并且入手下手把了局写到屏幕上,你就会瞥见数据依照字母按次分列起来了。

多级排序
实在不单单能够在SQL语句中举行一级排序。实践上,在良多情形下,你大概会但愿指定两到三级深度的数据排序。假定你有以下数据表,其内容以下所示:

先前接纳的单级ORDERBY排序是按上面的按次掏出数据的:
AbsurdlyAssured
absurd@assured.com

AbsolutelyAssured
absolutely@assured.com

CrazedCoder
crazy@coder.net

LooselyFringe
loose@fringe.to

LunaticFringe
lune@fringe.to

HandsOn
hands@yes.org

明显ORDERBY起了应有的感化。在实践的表布局下,AbsurdlyAssured是最初的条目,但它排在检索了局的最顶端。HandsOn纪录排最初由于O在以上列表中排在字母表最初。明显,Absolutely依照字母表最好排在Absurdly之前。为此,你必要接纳第2级ORDERBY排序尺度,参照第2列举行排序:
SQL="SELECTc_lastname,c_firstname,c_emailFROMCustomersORDERBY
c_lastname,c_firstname"

其了局将起首依照c_lastname列排序然后依照c_firstname列排序。假设你的数据表包括的纪录对照多,细心计划排序会令输入了局编排更加公道。

投进利用
假如你同年夜多半程序员一样喜好本人下手编代码,沉沦于把握新手艺的狂热当中。何不从ASP的冗杂编码直达过火来实验一下SQL编码呢?上面我们迁就ASP编程经常见的成绩和怎样在ASP中高效天时用SQL语句做一番切磋。

11.纪录统计


断定数据库内有几纪录,大概断定有几纪录到达了某些尺度,这些用ASP完成并不是难事。假如你接纳了准确的游标范例,你能够用RecordCount属性取得纪录数固然也能够用recordset。可是,有个更复杂的举措,这就是在本人的SELECT语句中接纳count(*),代码以下所示:
SQL="SELECTcount(*)FROMCustomers"

大概
SQL="SELECTcount(*)FROMCustomersWHEREc_lastnameLIKEA%"

举例申明,以下代码将选出一些纪录和这些纪录的总数:
SQL="SELECTc_firstname,c_lastname,count(*)FROMCustomersWHEREc_lastnameLIKEA%"

可是你不克不及完成本人的目标。这里接纳的“count”函数实际上是一种汇合函数,意义是只前往单行信息:回覆你提出的成绩。对第1个SELECT语句来讲,成绩是“在客户表内有几笔记录?”查询前往单一的值作为呼应,因而它不克不及同你惯例的查询相组合。假设你但愿失掉其他数据,你必要接纳RecordCount。

汇合函数除“count”以外还包含AVG、MIN、MAX和SUM等。


12.毗连

任何熟习SQL和干系数据库的人都碰见过大批的毗连范例。最复杂的说,毗连(join)会把两个表的内容组合到一个假造表大概recordset内。假设数据表无效地规一化,也许你会常常从某一个表当选出特定的信息再从另外一个表当选出联系关系信息。如许做就必要复杂的“一律毗连(equijoin)”。

为了懂得实践的毗连操纵,如今让我们假定在一个数据库内寄存了某类软件的相干纪录。某个表(Software)包括了软件产物的称号、软件的版本和其他有关细节:

另外一个表(Releases)则存储了软件公布汗青的信息,个中包含公布日期和公布形态等(好比测试版、以后版、过期等):

上表中还包括了一个列,内容指向软件表中接纳的ID号。以是,经由过程这类索引软件表的体例,你就晓得公布表中software_ID即是2的软件是Rome。

你接纳毗连组合信息,如许就不必要在两个表之间往返折腾了。不外,除组合信息以外还能够经由过程毗连把有关信息兼并。如许,只需公布表内的software_ID婚配软件表内的ID,你就把婚配信息一同放到一个纪录内。

代码以下:
SQL="SELECT*FROMSoftware,ReleasesWHEREsoftware.ID=releases.softwareID"

细心剖析以上的语句,起首注重到两个表名列在了FROM的前面。再依据所接纳的毗连,从此你大概还会发明语法会有所变更(大概毗连范例有变),可是以上的语法是最基础的,显现了数据的团结选择体例。这里的WHERE子句用来对照特定的ID值。在Software表内,存在ID列。一样的,Releases表内则有个software_ID列。为了明白你在WHERE子句里要对照的值,你用表名作为前缀,前面还加上了一个点号(.)。

以下是毗连拔取数据以后的了局:

注重:在创立毗连的时分要细心思索选出数据的列。以上代码接纳*通配符是为了让读者存眷于SELECT代码行的其他部分。可是,正如你从上图看到的那样,你没法选出softwareID列,由于这一列没有作为recordset部分的增添值。它的感化就是为WHERE子句所用。缺点:正版成本价格贵(盗版就不说了)、不够安全,大多数服务器用windows系统,没有linux安全
小女巫 该用户已被删除
沙发
发表于 2015-1-18 22:37:13 | 只看该作者
如何学好ASP,以前也有人问过,把回答给你转过来看看能否对你有帮助:
因胸联盟 该用户已被删除
板凳
发表于 2015-1-24 22:00:43 | 只看该作者
交流是必要的,不管是生活还是学习我们都要试着去交流,通过交流我们可以学到很多我们自己本身所没有的知识,可以分享别人的经验甚至经历。
第二个灵魂 该用户已被删除
地板
发表于 2015-2-2 14:56:49 | 只看该作者
我就感觉到ASP和一些常用的数据库编程以及软件工程方面的思想是非常重要的。我现在也在尝试自己做网页,这其中就用到了ASP,我想它的作用是可想而知的。
若相依 该用户已被删除
5#
 楼主| 发表于 2015-2-7 23:46:27 | 只看该作者
Application:这个存储服务端的数据,如果不清除,会直到web应用程序结束才清除(例如重启站点)
admin 该用户已被删除
6#
发表于 2015-2-23 19:48:50 | 只看该作者
如何学好ASP,以前也有人问过,把回答给你转过来看看能否对你有帮助:
冷月葬花魂 该用户已被删除
7#
发表于 2015-3-7 10:10:19 | 只看该作者
封装性使得代码逻辑清晰,易于管理,并且应用到ASP.Net上就可以使业务逻辑和Html页面分离,这样无论页面原型如何改变,业务逻辑代码都不必做任何改动;继承性和多态性使得代码的可重用性大大提高。
再见西城 该用户已被删除
8#
发表于 2015-3-14 23:24:23 | 只看该作者
最近在学asp,不要问我为什么不直接学.net,因为公司网站是asp做的所以有这个需要,卖了本书asp入门到精通,对里面的六大内置对象老是记不住,还有很多属性和方法看的头晕。
乐观 该用户已被删除
9#
发表于 2015-3-21 16:28:34 | 只看该作者
弱类型造成潜在的出错可能:尽管弱数据类型的编程语言使用起来回方便一些,但相对于它所造成的出错几率是远远得不偿失的。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-26 06:47

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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