ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 2962|回复: 8

ASP与数据库应用(给初学者)转

[复制链接]

TA的精华主题

TA的得分主题

发表于 2004-9-15 18:26 | 显示全部楼层 |阅读模式

见最近许多网友询问一些关于数据库操作的基础问题,现把我以前写的一篇简单教程贴上来,好让一些初学者最快的入门:

ASP与数据库应用(给初学者)

  一般来说,一个真正的、完整的站点是离不开数据库的,因为实际应用中,需要保存的数据很多,而且这些数据之间往往还有关联,利用数据库来管理这些数据,可以很方便的查询和更新。数据库有很多种,如:Fox 数据库(.dbf)、Access 数据库(.mdb)、Informix、Oracle 和 SQL Server 等等,在这里,我将以 Microsoft Access 数据库为例来说明ASP是如何访问数据库的。

常用数据库语句

  1.SELECT 语句:命令数据库引擎从数据库里返回信息,作为一组记录。   2.INSERT INTO 语句:添加一个或多个记录至一个表。   3.UPDATE 语句:创建更新查询来改变基于特定准则的指定表中的字段值。   4.DELETE 语句:创建一个删除查询把记录从 FROM 子句列出并符合 WHERE 子句的一个或更多的表中清除。   5.EXECUTE 语句:用于激活 PROCEDURE(过程)

用 ASP 来做一个自己的通讯录练练手吧……

一、建立数据库:

  用 Microsoft Access 建立一个名为 data.mdb 的空数据库,使用设计器创建一个新表。输入以下几个字段:

  字段名称  数据类型  说明      其它   ID     自动编号  数据标识    字段大小:长整型 新值:递增 索引:有(无重复)   username  文本    姓名      缺省值   usermail  文本    E-mail     缺省值   view    数字    查看次数    字段大小:长整型 默认值:0 索引:无   indate   时间日期  加入时间    缺省值

  保存为 data.mdb 文件,为了便于说明,只是做了一个比较简单的库。

二、连接数据库

  方法1:   Set conn = Server.CreateObject("ADODB.Connection")   conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq="&Server.MapPath("data.mdb")

  方法2:   Set conn = Server.CreateObject("ADODB.Connection")   conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Server.MapPath("data.mdb")

  注意:一个页面中,只要连接一次就可以了,数据库使用完后要及时关闭连接。   conn.Close   Set conn = Nothing

三、添加新记录到数据库

  Set conn = Server.CreateObject("ADODB.Connection")   conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq="&Server.MapPath("data.mdb")

  username = "风云突变"   usermail = "fytb@163.com"   indate = Now()

  sql = "insert into data (username,usermail,indata) values('"&username&"','"&usermail&"','"&indate&"')"   conn.Execute(sql)

  conn.Close   Set conn = Nothing

  说明:建立数据库连接;通过表单获取姓名、E-mail 字符串,Now()获取当前时间日期;使用 insert into 语句添加新记录;conn.Execute 来执行;最后关闭。

四、选择数据库里的记录

  1.选择所有记录的字段(按记录倒序排序):sql = "select * from data order by ID desc"   2.选择所有记录的姓名和E-mail字段(不排序):sql = "select username,usermail from data"   3.选择姓名为“风云突变”的所有记录:sql = "select * from data where username='"风云突变"'"   4.选择使用 163 信箱的所有记录(按查看次数排序):sql = "select * from data where usermail like '%"@163.com"%' order by view desc"   5.选择最新的10个记录:sql = "select top 10 * from data order by ID desc"

  SQL 语句已经知道了,不过在Web应用时,还得创建一个 RecordSet 对象得到记录集,才能把从数据库里取出的值应用在网页上,如果现在将所有的记录显示在网页上就这样:

  Set conn = Server.CreateObject("ADODB.Connection")   conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq="&Server.MapPath("data.mdb")

  sql = "select * from data"   Set rs = Server.CreateObject("ADODB.RecordSet")   rs.Open sql,conn,1,1

  Do While Not rs.Eof     Response.Write "<p>姓名:"& rs("username") &" E-mail:"& rs("usermail") &" 查看:"& rs("view") &"次 "& rs("indate") &"加入</p>"     rs.MoveNext   Loop

  rs.Close   Set rs = Nothing   conn.Close   Set conn = Nothing

  说明:建立数据库连接;创建 rs 得到记录集;循环显示记录,rs.Eof 表示记录末,rs.MoveNext 表示移到下一个记录;最后关闭。

五、修改(更新)数据库记录

  修改记录的E-mail:

  Set conn = Server.CreateObject("ADODB.Connection")   conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq="&Server.MapPath("data.mdb")

  ID = 1   usermail = "fytb@163.com"

  sql = "update data set usermail='"&usermail&"' where ID="&CInt(ID)   conn.Execute(sql)

  conn.Close   Set conn = Nothing

  说明:建立数据库连接;获取记录ID、新 E-mail 字符串;使用 update 语句修改记录;conn.Execute 来执行;最后关闭。   如果使记录的查看值加1,则:sql = "update data set view=view+1 where ID="&CInt(ID)

六、删除数据库记录

  删除某一条记录:

  Set conn = Server.CreateObject("ADODB.Connection")   conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq="&Server.MapPath("data.mdb")

  ID = 1

  sql = "delete from data where ID="&CInt(ID)   conn.Execute(sql)

  conn.Close   Set conn = Nothing

  说明:建立数据库连接;获取记录ID;使用 delete 语句删除记录;conn.Execute 来执行;最后关闭。   删除多条记录为:sql = "delete from data where ID in (ID1,ID2,ID3)"   删除所有记录为:sql = "delete from data"

总结:

  以上教程是针对ASP的初学者而写的,只是介绍了一些基本的用法,在了解之后可以自己去试试,重要的在于能举一反三、综合运用。更多的语法和参数请参阅 Microsoft Access 帮助中的 Microsoft Jet SQL 参考,由于本人才疏学浅、能力有限,如有表达不明确有地方还望指出,如果在应用当中遇到什么问题,也希望能够提出。谢谢。

TA的精华主题

TA的得分主题

发表于 2004-9-24 20:18 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

这确实是基础,但是很重要。

谢谢楼主!

TA的精华主题

TA的得分主题

发表于 2004-11-16 16:06 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2004-11-20 08:05 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2004-11-28 17:27 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
暂时不需要,不过谢谢搂主先。

TA的精华主题

TA的得分主题

发表于 2004-11-28 21:10 | 显示全部楼层

书写格式上,有一些小错误,复制代码的朋友要小心了

Set conn = Server.CreateObject("ADODB.Connection") 等号前后多了空格,其它很多有等号的地方也存在这个问题

sql = "insert into data (username,usermail,indata) values('"&username&"','"&usermail&"','"&indate&"')"

最后一个字段对应的值是日期类型,数据表中也指定了格式为日期型,SQL语句中变量表达式不对,'"&indate&"'改为 #"&indate&"#,否则执行时会提示数据类型不对

其它一些SQL语句和部分地方书写格式有少少问题,不懂写源程序时出现的还是复制时出现的,主要是出应多余的空格导致语句不连贯,这个对初学者来说是致命的,使用的朋友调试时注意总结语句书写格式

TA的精华主题

TA的得分主题

 楼主| 发表于 2004-11-30 15:27 | 显示全部楼层
呵呵!谢谢指正,当初依葫芦画瓢时,都是自己输入的,没有复制代码。

TA的精华主题

TA的得分主题

发表于 2004-12-1 07:32 | 显示全部楼层

我想知道,那些东西在一个页面上,也就是把那写放在一起,总不能全部放在一起吧.

麻烦斑竹再把步骤说详细点好吗?

TA的精华主题

TA的得分主题

发表于 2004-9-24 10:55 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-24 01:35 , Processed in 0.032062 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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