频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

一个通用数据库显示程序,能调任意库,任意字段,多关键字搜索,自动分页

来源: 作者: 出处:巧巧读书 2006-09-07 进入讨论组

  .

阿余经常写一些数据库相关的程序,当然离不开显示库中的数据了,说实话,做这样的程序真是无聊啊,所以,阿余就想写个函数,一个通用的数据库显示函数.要求如下:

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)&"</A>"
  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)&"</A>"
  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&"  本U R L:http://www.qqread.com/asp/2006/10/c239455.html 更多文章 更多内容请看数据库专栏数据库处理专题城域网专题专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
最新论坛文章
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章