|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
数据库显示程序,能调任意库,任意字段,多要害字搜索,自动分页. 1. 能显示指定的字段,当然,字段名和显示的文字可以不相同. 2. 能同时按多个字段进行查询,支持模糊和精确两种查询方法. 3. 有横向排列和纵向排列字段两种显示方法. 4. 能自动分页. 5. 能设定每页显示多少条记录.好啦,要求大至就是这样了.根据这个要求,阿余写了下面的函数. 实际上,这里阿余写了两个函数.一个是TABDISP(),用于显示一个指定表中的内容.还有一个是ER()一个小小的错误处理函数. 这个函数有5个参数(真够多的).并且各个参数都要输入数据,不能是空白,不然会出错的. 1(TAB), 要调用的表名. 2(DISPFILD), 要显示表中的哪一些字段,如字段名和要显示的字符不相同用<分隔.比如某一个字段名为:IMG,但要在页面上显示为:图片, 那么,就写为IMG<图片,假如有多个字段,各字段间用“,”分隔,唉,老声长谈. 3(FINDFILD), 要按哪些字段进行查询,字段名和要显示的字符间用<分隔. 4(PAGEN), 每页显示多少条记录. 5(FH), 显示的方向.当为S时纵向显示.为H时横向显示. 函数的返回值,当没有出错的时候,返回值为真,否则为假. 这个函数中没有包括连接到数据库的部分.所以要自己连接到库.另外,为了重复应用.可以把这个函数专门用一个文件来保存,然后在需要的时候包含这个文件. 看下面的函数: (不要不看完,最后我举有应用的例子) <% \\\'以下定义一个显示表格的函数TABDISP(),参数TAB,被显示的表名,DISPFILD,要显示的字段,FINDFILD,查询字段,PAGEN,每页显示数量,fh,显示的方向 \\\'如显示成功,返回值为真,不成功,返回值为假. \\\'多个字段间用,分隔 \\\'查询字段一定要包含在显示字段中. \\\'如字段名与要显示的名称不相同,用<分隔,前面是字段名,后面是显示的名字,而要进行搜索的字段则一定要用<分隔要字段名和显示字符 \\\'FH显示方向为"H"时作横向显示,为"S"时作纵向显示 区分大小写 FUNCTION TABDISP(TAB,DISPFILD,FINDFILD,PAGEN,FH) On Error Resume Next IF DISPFILD="" THEN DISPFILD="*" IF PAGEN="" THEN PAGEN=15 DISPFILD1=DISPFILD&"," findfild1=findfild&"," dim findl(10),findr(10) i1=1 do while instr(findfild1,",")<>0 star=instr(findfild1,",") findl(i1)=left(findfild1,star-1) findr(i1)=findl(i1) fildbak=findl(i1) findl(i1)=left(fildbak,instr(fildbak,"<")-1) findr(i1)=right(fildbak,len(fildbak)-instr(fildbak,"<")) findfild1=right(findfild1,len(findfild1)-star) i1=i1+1 loop Response.Write "<table border=\\\'0\\\' width=\\\'100%\\\' cellspacing=\\\'0\\\'><tr><form method=\\\'GET\\\'>" Response.Write "<TD > " \\\'width=\\\'50%\\\' IF SESSION("FLMENULBUP")<>"" THEN Response.Write "当前栏目:<A HREF=\\\'FLMEN.ASP?MENULB="&SESSION("FLMENULBUP")&"\\\'>"&MID(SESSION("FLMENULBUP"),4,200)&"" END IF IF SESSION("flmenulb")<> SESSION("FLMENULBUP") THEN Response.Write " >> <A HREF=\\\'FLMEN.ASP?menulb="&SESSION("FLMENULBUP")&"&LB="&SESSION("flmenulb")&"\\\'>"&MID(SESSION("flmenulb"),4,200)&"" END IF Response.Write "</TD><td align=\\\'right\\\' ></td><td align=\\\'right\\\'><table border=\\\'0\\\' cellspacing=\\\'0\\\' cellpadding=\\\'0\\\'> " Response.Write "<tr><td rowspan=\\\'2\\\'><img src=\\\'img/SEARCH.GIF\\\' width=\\\'50\\\'> </td>" for i3=1 to i1-1 Response.Write "<td>"&findr(i3)&":</td>" next Response.Write "</tr><tr>" \\\'<td></td> for i2=1 to i1-1 Response.Write "<td><input type=\\\'text\\\' name=\\\'key_word"&i2&"\\\' size=\\\'8\\\' value=\\\'\\\'></td>" next Response.Write "<tr></table></td><td width=\\\'20%\\\'> <input type=\\\'checkbox\\\' name=\\\'find_fr\\\' value=\\\'yes\\\'>精确 <input type=\\\'submit\\\' value=\\\'开始\\\' name=\\\'B_FIND\\\'></td>" Response.Write "</form> </tr></table>" find_fr=request("find_fr") TJ="" urllr="&find_fr="&find_fr findlrdisp="" FOR I3=1 TO I1-1 TJ1=request("KEY_WORD"&I3) urllr=urllr&"&key_word"&i3&"="&tj1 IF TJ1=FINDR(I3) OR TJ1="" THEN TJ1="" ELSE if find_fr<>"yes" then findlrdisp=findlrdisp&findr(i3)&"包含“"&TJ1&"” " tj1=" AND "&findL(I3)&" like \\\'%"&TRIM(TJ1)&"%\\\' " else findlrdisp=findlrdisp&findr(i3)&"是“"&TJ1&"” " tj1=" AND "&FINDL(I3)&" = \\\'"&TRIM(TJ1)&"\\\' " end if END IF TJ=TJ&TJ1 IF TJ="" THEN TOPSN=" TOP 300 " ELSE TOPSN="" END IF NEXT dim fild(35),dispfil(35),dispfildlr dispfildlr="" i=1 dispfild1=dispfild1 do while instr(dispfild1,",")<>0 star=instr(dispfild1,",") fild(i)=left(dispfild1,star-1) dispfil(i)=fild(i) if instr(fild(i),"<")<>0 then fildbak=fild(i) fild(i)=left(fildbak,instr(fildbak,"<")-1) dispfil(i)=right(fildbak,len(fildbak)-instr(fildbak,"<")) end if dispfildlr=dispfildlr&fild(i)&"," dispfild1=right(dispfild1,len(dispfild1)-star) i=i+1 loop dispfildlr=left(dispfildlr,len(dispfildlr)-1) SQL="SELECT "&topsn&" id,"&DISPFILDlr&" FROM "&TAB&" WHERE ID<>-1 "&tj&" order by -ID" \\\'Response.Write sql session("tabsql")=sql Set rs=Server.CreateObject("ADODB.RecordSet") rs.Open sql,conn,1,3 if not rs.eof then pagesn=request("pagesn") if pagesn<=0 or pagesn="" then pagesn=1 rs.pagesize=pagen pagezs=rs.pagecount IF cint(PAGESN)>pagezs THEN pagesn=PAGEZS zs=rs.recordcount page=(pagesn-1)*pagen rs.move page,1 if findlrdisp<>"" then Response.Write "经搜索,"&findlrdisp&"的记录如下:" Response.Write "<table border=\\\'0\\\' width=\\\'90%\\\'>" if zs>=300 and topsn<>"" then Response.Write "<tr> <form method=\\\'POST\\\' action=\\\'?"&urllr&"\\\'><td width=\\\'54%\\\'>总数很多,当前显示前"&ZS&"条,分"&PAGEZS&"页,现在是第"&PAGESN&"页</td>" else Response.Write "<tr> <form method=\\\'POST\\\' action=\\\'?"&urllr&"\\\'><td width=\\\'54%\\\'>一共"&ZS&"条,分"&PAGEZS&"页,现在是第"&PAGESN&"页</td>" end if Response.Write "<td width=\\\'11%\\\' align=\\\'center\\\'><a href=\\\'?PAGESN="&PAGESN-1&urllr&"\\\'>上一页</td>" Response.Write "<td width=\\\'11%\\\' align=\\\'center\\\'><a href=\\\'?PAGESN="&PAGESN+1&urllr&"\\\'>下一页</td>" Response.Write "<td width=\\\'24%\\\' ALIGN=\\\'RIGHT\\\'>跳转到第 " Response.Write "<input type=\\\'text\\\' name=\\\'PAGESN\\\' size=\\\'2\\\'>页<input type=\\\'submit\\\' value=\\\'GO\\\' name=\\\'B1\\\'></td></form> " Response.Write "</tr></table> " if fh="H" THEN Response.Write " <table border=\\\'0\\\' width=\\\'100%\\\' cellspacing=\\\'1\\\' cellpadding=\\\'0\\\'>" Response.Write " <tr bgcolor=\\\'#EDBAA5\\\' align=\\\'center\\\'> " for ii=1 to i-1 Response.Write "<td>"&dispFIL(ii)&"</td>" next Response.Write "</tr>" for iii=1 to pagen Response.Write "<tr bgcolor=\\\'#FFFAEE\\\'>" FOR II=1 TO I-1 Response.Write "<td>"&RS(fild(II))&"</td>" NEXT Response.Write "</tr>" RS.MOVENEXT if rs.eof then exit for next Response.Write "</table>" ELSE Response.Write " <table border=\\\'0\\\' width=\\\'100%\\\' cellspacing=\\\'1\\\' cellpadding=\\\'0\\\'>" for iii=1 to pagen FOR II=1 TO I-1 Response.Write "<tr><td bgcolor=\\\'#EDBAA5\\\' ALIGN=\\\'RIGHT\\\' WIDTH=\\\'20%\\\'>"&dispFIL(ii)&":</td><td bgcolor=\\\'#FFFAEE\\\'>"&RS(fild(II))&"</td></tr>" NEXT Response.Write "<tr height=\\\'1\\\'><td bgcolor=\\\'#CFBA9E\\\' colspan=\\\'2\\\' ALIGN=\\\'RIGHT\\\' WIDTH=\\\'20%\\\'> </td></tr>" RS.MOVENEXT if rs.eof then exit for next Response.Write "</table>" END IF rs.close Response.Write "<table border=\\\'0\\\' width=\\\'90%\\\'>" if zs>=300 and topsn<>"" then Response.Write "<tr> <form method=\\\'POST\\\' action=\\\'?"&urllr&"\\\'><td width=\\\'54%\\\'>总数很多,当前显示前"&ZS&"条,分"&PAGEZS&"页,现在是第"&PAGESN&"页</td>" else Response.Write "<tr> <form method=\\\'POST\\\' action=\\\'?"&urllr&"\\\'><td width=\\\'54%\\\'>一共"&ZS&"条,分"&PAGEZS&"页,现在是第"&PAGESN&"页</td>" end if Response.Write "<td width=\\\'11%\\\' align=\\\'center\\\'><a href=\\\'?PAGESN="&PAGESN-1&urllr&"\\\'>上一页</td>" Response.Write "<td width=\\\'11%\\\' align=\\\'center\\\'><a href=\\\'?PAGESN="&PAGESN+1&urllr&"\\\'>下一页</td>" Response.Write "<td width=\\\'24%\\\' ALIGN=\\\'RIGHT\\\'>跳转到第 " Response.Write "<input type=\\\'text\\\' name=\\\'PAGESN\\\' size=\\\'2\\\'>页<input type=\\\'submit\\\' value=\\\'GO\\\' name=\\\'B1\\\'></td></form> " Response.Write "</tr></table> " else Response.Write "没有找到合适的记录" end if if er() then tabdisp=False else tabdisp=True end if END FUNCTION Function Er() \\\'错误处理函数 If Err.Number = 0 Then Er = False Else Err.Clear Er = True End If End Function %> 终于看完函数了.... 各位有点累,其实仔不仔细看都没有关系.反正只管调它就是了.下面举一个应用的例子. 首先, 我们把前面的函数就是<%和%>之间的部分保存到一个叫 TABDISP.ASP的文件中. 代码如下: 显示一个职式名册表,表名: ZG 有ID 姓名 职务 职称 TEL BP DZ(地址)几个字段. <% 。。。。。。 连接数据库,此处略过,不写了。 %> <!--#include file="TABDISP.asp"--> <% DISP="姓名,职务,职称,TEL<电话,BP<传呼,DZ<地址" FIND="姓名<姓名,职务<职务,DZ<地址" PAGEN="15" FH="H" TAB="ZG" IF NOT TABDISP(TAB,DISP,FIND,PAGEN,FH) THEN response.write "出现错误," END IF SET CONN=NOTHING %> 返回类别: 教程 上一教程: 一个分页存储过程 下一教程: 全文本检索的应用(3) 您可以阅读与"通用数据库显示程序"相关的教程: · 一个通用数据库显示程序,能调任意库,任意字段,多要害字搜索,自动分页 · 一个通用数据库显示程序 · 用ASP程序显示SQL数据库所有表的名称(带删除功能) · 如何准确显示数据库中的图片 · ASP中利用数组实现数据库记录的批量录入方式 |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |