if not (rs.eof or rs.bof) then response.write "错误,你输入的ID号已经被占用,请换一个再试试!" else sql = "Insert Into 作者表 (id, 昵称,Email, 密码,姓名,学校,系别,性别,电话) Values(" sql = sql & SqlStr(id) & "," sql = sql & SqlStr(nickname) & "," sql = sql & SqlStr(email) & "," sql = sql & SqlStr(password) & "," sql = sql & SqlStr(name) & ",&", " sql = sql & SqlStr(sex) & "," sql = sql & SqlStr(phone) & ")" conn.Execute sql 使用一个SQL的Insert语句把资料插入到数据库中。其实这一查询也可以做成预存程序放在数据库中,我偷了点懒:-)不过对比之下也可以看到预存程序的好处,执行时查询写起来实在是太麻烦了。 2、构建文章显示模块 前面说过,一片具体的文章是分属在看板和主体之下的。因此显示文章也要经过看板列表和主体列表这两页面后,才能得到特定主题下文章的列表。 (1)板列表的显示页面:
< html> < head> < title>看板列表< /title> < meta http-equiv="Content-Type"content="text/html; charset=GB2312"> < /head> (2)打开连接,显示看板列表
< %Set conn = Server.CreateObject("ADODB.Connection") conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb") sql = "select * from 看板列表" set rs=conn.execute(sql) %> 注:简单的SQL查询,把所有的看板有关讯息传回到纪录集RS中。下面的任务就是显示纪录记得内容,并在相应的看板名称上建立显示看板主题的连接。
< body bgcolor="#FFFFFF"> < h2 align="center">看板列表</h2> < table width="60%" border="0"cellspacing="0" cellpadding="0"align="center"> < tr bgcolor="#FFFFCC"> < td height="35" width="25%">看板名称</td> < td height="35" width="21%">板主</td> < td height="35" width="23%">主题数</td> < td height="35" width="31%">板主登陆</td> < /tr> 注:这儿一部分是显示出表格中每一列的标题,这儿我没有用一个统一的函数来显示RS纪录记的内容,因为这样可以对表格的外观和风格做更多的控制,使用起来虽然有点麻烦,但是却更为灵活。
< % do boardid=rs("id") boardname=rs("名称") boardmanager=rs("板主") response.write "< tr>< td><a href=qBoard.asp?boardid="& boardid& "&boardname=" & boardname& ">" & boardname &"< /a>< /td>" 注:这一行是重点,当点击了各个板的名称后,可以连接到显示看板主题的页面。程序代码看起来有点麻烦,我分解了给你讲,你就会明白了。在点击之后,浏览器请求使用的是qBoard.asp页面,并带有一个参数boardid,代表要显示看板的ID号,在请求页面和参数之间用问号(?)分隔。Boardid是前面设定了的变量,其中包含的就是对应看板的ID号。这个连接中还带有另外一个参数boardname,用来把看板名称传递给qBoard.asp页面。在多个参数间使用"&"来分隔。这个参数不是必须的,传递过去是为了免得在qBorad.asp中再次用boardid来查询看板名称。一般来说,能够少用数据库操作就应当尽量的少用,这样可以提高ASP页面的性能。因为Response.Write语句使用字符串作为参数的,所以上面的字符串和变量之间使用的是"&"联结符。最后ASP页面解释的结果应该是像这样的
<td>< a href=qBoard.asp?boardid=1&boardname=系统板>系统板 < /a>< td>。 response.write "< td>< a href=qAuthor.asp?author="&boardmanager & ">" &boardmanager & "< /a></td>"
上一篇: 如何处理ASP中的图象
下一篇: ASP应用程序设计的Web状态管理分析
|