ADO组件之插入数据记录
2018-09-06 11:44
简单的显示记录已经掌握,现在需要的就是通过ASP将信息内容插入到数据库中。
一、拥有数据库cnbruce.mdb
本数据库的作用就是用来被插入数据的,可以直接采用上节中已经建立的cnbruce.mdb文件,当然连接打开数据库的文件conn.asp也就顺利引用了。
二、建立输入插入信息的页面平台addit.html
本页的主要作用是:显示一些文本输入框以用来提供输入信息内容提交数据库。
1,addit.html
<form action=addit.asp method=post> Title:<input type=text name=title><br> Author:<input type=text name=author><br> Content:<br> <textarea name=content rows=8 cols=30></textarea><br> <input type=submit value=Add> <input type=reset value=Reset> </form> [Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
本页其实很简单,就是通过submit按钮将表单的信息内容提交到addit.asp页面去处理。
三、建立处理接受数据并插入数据库表的页面程序addit.asp
2,addit.asp
<!--#includefile=conn.asp-->
<%
whattitle=request.form(title)
whoauthor=request.form(author)
whatcontent=request.form(content)
%>
<%
Setrs=Server.CreateObject(ADODB.Recordset)
sql=Select*fromcnarticle
rs.Opensql,conn,3,2
%>
<%
rs.addnew
rs(cn_title)=whattitle
rs(cn_author)=whoauthor
rs(cn_content)=whatcontent
rs.update
%>
文章添加成功,<ahref=showit.asp>浏览</a>
<%
rs.close
Setrs=Nothing
conn.close
setconn=Nothing
%>
恩,接着就是来具体分析一下。
1,<!--#includefile=conn.asp-->不用说,凡是要和数据库有联系的都要运用到该连接文件。
2,whattitle=request.form(title)之类就是将上页表单中接受过来的值赋到一变量上,方便下面程序的调用。
3,rs.Opensql,conn,3,2注意参数和显示数据库时采用的参数的不同。
4,rs.addnew很简单也很显眼的一个声明:新建一个数据库记录集行。
5,rs(cn_title)=whattitle之类即将接受的表单值对应到相关字段中。
6,rs.update只是值和数据库字段的对应,完了后还要将对应的值上传提交到数据库表中去。
7,插入后可以跳转到showit.asp查看需要说明,以后的ASP例题可能都是建立在前几节内容的基础之上完成的。
8,释放资源是规矩,不要忘记。
那么,现在。插入并显示数据库记录,对你来说完全是小菜一碟了。大体框架搭建完毕,下面就是具体的细化了。
其中包括:客户端的表单检测,防止用户信息输入的遗漏;当然最好还是要加上服务器端的表单检测,由于客户端的某些原因(比如自行设计提交非检测的页面)基于安全考虑,一切还是依服务器端所接受信息为准。那下面就继续细化应用下了。
1,客户端检测其实就是通过简单的脚本检测,这在初学ASP提到脚本的时候说到,下面将再次重复。
加强的addit.html
<script laguage=javascript> <!-- function form1_onsubmit() { if (document.form1.title.value==) { alert(请输入文章标题tent.value==) { alert(请输入文章内容) document.form1.content.focus() return false } } --> </script> <form action=addit.asp method=post name=form1 onsubmit=return form1_onsubmit()> Title:<input type=text name=title><br> Author:<input type=text name=author><br> Content:<br> <textarea name=content rows=8 cols=30></textarea><br> <input type=submit value=Add> <input type=reset value=Reset> </form> [Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
2,服务器端检测有人也许会问,既然有了客户端的检测,那还有多个服务器端的检测呢?原因很简单,比如仿照HTML表单提交页,自行设计一张去除了表单检测的页面。当点击提交,并且没有任何信息时,到达服务器端如没有任何防御则肯定会造成数据插入的失败。
加强的addit.asp
<!--#includefile=conn.asp-->
<%
whattitle=trim(request.form(title))
whoauthor=trim(request.form(author))
whatcontent=trim(request.form(content))
%>
<%ifwhattitle=\then%>
<scriptlanguage=vbs>
alert(请输入文章标题)
history.go(-1)
</script>
<%endif%>
<%ifwhatcontent=then%>
<scriptlanguage=vbs>
alert(请输入文章标题)
history.go(-1)
</script>
<%endif%>
<%
Setrs=Server.CreateObject(ADODB.Recordset)
sql=Select*fromcnarticle
rs.Opensql,conn,3,2
%>
<%
rs.addnew
rs(cn_title)=whattitle
rs(cn_author)=whoauthor
rs(cn_content)=whatcontent
rs.update
%>
文章添加成功,<ahref=showit.asp>浏览</a>
<%
rs.close
Setrs=Nothing
conn.close
setconn=Nothing
%>
可以看出,就是添加了如下类似的判断。
<%ifwhattitle=\then%>
<scriptlanguage=vbs>
alert(请输入文章标题)
history.go(-1)
</script>
<%endif%>
很简单,如果接受过来的信息为空,则弹出警告框,并且确认后返回到上页即addit.html了。当然cn_author没有设置检测,因为当初设计该字段的接受值是允许为空的。
OK,总结一下,插入记录主要就是
rs.addnew
rs(cn_title)=whattitle
...
rs.update
很简单,先声明addnew,然后一一对应,再提交插入数据库。
这是一种插入数据库的方法,下面就来接触了解一下另外一种。
需要注意,结构化的查询语言也就是SQL语句能够完成一些比较苛刻的数据库操作。当然,对于诸如提取、插入信息之流就更不在话下了。所以下面采用的插入记录的方法就是直接采用SQL语法完成。
修改了的addit.asp
<!--#includefile=conn.asp-->
<%
whattitle=request.form(title)
whoauthor=request.form(author)
whatcontent=request.form(content)
%>
<%
sql=insertintocnarticle(cn_title,cn_author,cn_content)values(whattitle,whoauthor,whatcontent)
conn.Execute(sql)
%>
文章添加成功,<ahref=showit.asp>浏览</a>
<%
conn.close
setconn=Nothing
%>
本程序中,你会发现只要一行的SQL语句,不需要建立Rescord记录集行,不需要声明addnew,不要执