亚洲第一国产综合野狼_中文字幕有码~第一页_一级少妇精品久久久久久久_亚洲中文字幕永久在线不卡

<pre id="bxsy8"><tt id="bxsy8"><rt id="bxsy8"></rt></tt></pre>
  • <span id="bxsy8"><var id="bxsy8"></var></span>
  • <menu id="bxsy8"></menu>
    1. 站內(nèi)搜索  

      哈爾濱百姓網(wǎng)首頁 | 操作系統(tǒng) | 軟件應(yīng)用 | 平面設(shè)計 | 程序開發(fā) | 硬件維護(hù) | 網(wǎng)絡(luò)安全
       您的位置: 哈爾濱百姓網(wǎng) > 電腦網(wǎng)絡(luò) > 程序開發(fā) > 閱讀文章:一個通用數(shù)據(jù)庫顯示程序,能調(diào)任意庫,任意字段,多關(guān)鍵字搜索,自動分頁
      一個通用數(shù)據(jù)庫顯示程序,能調(diào)任意庫,任意字段,多關(guān)鍵字搜索,自動分頁
      2009-4-17 9:50:33 哈爾濱百姓網(wǎng) 來源:百度空間 瀏覽 次 【 】【打印】【關(guān)閉

      阿余經(jīng)常寫一些數(shù)據(jù)庫相關(guān)的程序,當(dāng)然離不開顯示庫中的數(shù)據(jù)了,說實(shí)話,做這樣的程序真是無聊啊,所以,阿余就想寫個函數(shù),一個通用的數(shù)據(jù)庫顯示函數(shù).要求如下:

      1. 能顯示指定的字段,當(dāng)然,字段名和顯示的文字可以不一樣.
      2. 能同時按多個字段進(jìn)行查詢,支持模糊和精確兩種查詢方式.
      3. 有橫向排列和縱向排列字段兩種顯示方式.
      4. 能自動分頁.
      5. 能設(shè)定每頁顯示多少條記錄.好啦,要求大至就是這樣了.根據(jù)這個要求,阿余寫了下面的函數(shù).
      實(shí)際上,這里阿余寫了兩個函數(shù).一個是TABDISP(),用于顯示一個指定表中的內(nèi)容.還有一個是ER()一個小小的錯誤處理函數(shù).
      這個函數(shù)有5個參數(shù)(真夠多的).并且各個參數(shù)都要輸入數(shù)據(jù),不能是空白,不然會出錯的.
      1(TAB), 要調(diào)用的表名.
      2(DISPFILD), 要顯示表中的哪一些字段,如字段名和要顯示的字符不一樣用<分隔.比如某一個字段名為:IMG,但要在頁面上顯示為:圖片, 那么,就寫為IMG<圖片,如果有多個字段,各字段間用“,”分隔,唉,老聲長談.
      3(FINDFILD), 要按哪些字段進(jìn)行查詢,字段名和要顯示的字符間用<分隔.
      4(PAGEN), 每頁顯示多少條記錄.
      5(FH), 顯示的方向.當(dāng)為S時縱向顯示.為H時橫向顯示.
      函數(shù)的返回值,當(dāng)沒有出錯的時候,返回值為真,否則為假.
      這個函數(shù)中沒有包括連接到數(shù)據(jù)庫的部分.所以要自己連接到庫.另外,為了重復(fù)應(yīng)用.可以把這個函數(shù)專門用一個文件來保存,然后在需要的時候包含這個文件.
      看下面的函數(shù): (不要不看完,最后我舉有應(yīng)用的例子)

      <%
      '以下定義一個顯示表格的函數(shù)TABDISP(),參數(shù)TAB,被顯示的表名,DISPFILD,要顯示的字段,FINDFILD,查詢字段,PAGEN,每頁顯示數(shù)量,fh,顯示的方向
      '如顯示成功,返回值為真,不成功,返回值為假.
      '多個字段間用,分隔
      '查詢字段一定要包含在顯示字段中.
      '如字段名與要顯示的名稱不一樣,用<分隔,前面是字段名,后面是顯示的名字,而要進(jìn)行搜索的字段則一定要用<分隔要字段名和顯示字符
      'FH顯示方向?yàn)?H"時作橫向顯示,為"S"時作縱向顯示 區(qū)分大小寫
      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 "當(dāng)前欄目:<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&"     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 "經(jīng)搜索,"&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%'>總數(shù)很多,當(dāng)前顯示前"&ZS&"條,分"&PAGEZS&"頁,現(xiàn)在是第"&PAGESN&"頁</td>"
              else
                 Response.Write   "<tr>   <form method='POST'    action='?"&urllr&"'><td width='54%'>一共"&ZS&"條,分"&PAGEZS&"頁,現(xiàn)在是第"&PAGESN&"頁</td>"
              end if
              Response.Write   "<td width='11%' align='center'><a href='?PAGESN="&PAGESN-1&urllr&"'>上一頁</A></td>"
              Response.Write   "<td width='11%' align='center'><a href='?PAGESN="&PAGESN+1&urllr&"'>下一頁</A></td>"
              Response.Write   "<td width='24%' ALIGN='RIGHT'>跳轉(zhuǎn)到第 "
              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%'>總數(shù)很多,當(dāng)前顯示前"&ZS&"條,分"&PAGEZS&"頁,現(xiàn)在是第"&PAGESN&"頁</td>"
      else
         Response.Write   "<tr>   <form method='POST'    action='?"&urllr&"'><td width='54%'>一共"&ZS&"條,分"&PAGEZS&"頁,現(xiàn)在是第"&PAGESN&"頁</td>"
      end if
         Response.Write   "<td width='11%' align='center'><a href='?PAGESN="&PAGESN-1&urllr&"'>上一頁</A></td>"
         Response.Write   "<td width='11%' align='center'><a href='?PAGESN="&PAGESN+1&urllr&"'>下一頁</A></td>"
         Response.Write   "<td width='24%' ALIGN='RIGHT'>跳轉(zhuǎn)到第 "
         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()   '錯誤處理函數(shù)
               If Err.Number = 0 Then
               Er = False
               Else
               Err.Clear
               Er = True
               End If
      End Function
      %>


           終于看完函數(shù)了....
      各位有點(diǎn)累,其實(shí)仔不仔細(xì)看都沒有關(guān)系.反正只管調(diào)它就是了.下面舉一個應(yīng)用的例子.
      首先, 我們把前面的函數(shù)就是<%和%>之間的部分保存到一個叫 TABDISP.ASP的文件中.
      代碼如下:
      顯示一個職式名冊表,表名: ZG  
      有ID 姓名 職務(wù) 職稱 TEL BP DZ(地址)幾個字段.

      <%
      。。。。。。
      連接數(shù)據(jù)庫,此處略過,不寫了。
      %>
      <!--#include file="TABDISP.asp"-->
      <%
      DISP="姓名,職務(wù),職稱,TEL<電話,BP<傳呼,DZ<地址"
      FIND="姓名<姓名,職務(wù)<職務(wù),DZ<地址"
      PAGEN="15"
      FH="H"
      TAB="ZG"

      IF NOT TABDISP(TAB,DISP,FIND,PAGEN,FH) THEN
           response.write "出現(xiàn)錯誤,"
      END IF
      SET CONN=NOTHING
      %>


      把上面的內(nèi)容隨便起個文件名,就一切OK.  

      另外, 阿余的站http://www.zydn.net有不少好文章給大家.阿余也在站上隨時準(zhǔn)備和和朋友交流.阿余的EMAIL:COOLKK@21CN.COM
      還有啊,軟件世界竟然發(fā)了篇牛記的文章,說程序員工資太高,阿余在站上也放了個論壇,大家可以一起到阿余的站上去罵死那個家伙.
      [責(zé)任編輯:佚名]
       相關(guān)文章
      ·CSS布局方法的十八般技巧和兼容方案 (2009-11-13 17:14:48)
      ·利用Google給自己的網(wǎng)站加上投票功能 (2009-10-13 12:32:39)
      ·您試圖在此 Web 服務(wù)器上訪問 (2009-8-13 14:20:12)
      ·Asp偽靜態(tài)的實(shí)現(xiàn)及URL重寫-用ISAPI_Rewri (2009-8-6 15:07:08)
      ·巧用ASP腳本命令重啟服務(wù)器 (2009-8-6 15:05:39)
      ·Dreamweaver CS3網(wǎng)頁制作之CSS布局 (2009-7-1 16:07:45)
      ·網(wǎng)頁設(shè)計經(jīng)驗(yàn)和技巧總結(jié) (2009-7-1 16:03:12)
      ·網(wǎng)頁優(yōu)化必須做的26件事情 (2009-7-1 16:00:36)
      ·把數(shù)據(jù)庫結(jié)構(gòu)顯示出來的源代碼 (2009-4-17 9:55:16)
      ·插入記錄后馬上得到自動編號值(Access庫) (2009-4-17 9:54:33)
      ·全面解決--如何獲得剛插入數(shù)據(jù)庫的記錄的 (2009-4-17 9:53:29)
      ·ASP計算兩個時間之差的函數(shù) (2009-4-17 9:52:11)
      ·技巧:ASP開發(fā)中存儲過程應(yīng)用全接觸 (2009-4-17 9:48:31)
      ·網(wǎng)站簡體繁體轉(zhuǎn)換代碼 (2009-4-17 9:44:15)
      ·ASP導(dǎo)出Excel數(shù)據(jù)的四種方法 (2009-4-17 9:42:14)
      ·利用網(wǎng)頁監(jiān)聽,實(shí)現(xiàn)內(nèi)容中的圖片由滾輪控 (2009-4-17 9:37:21)
      ·html操作本地數(shù)據(jù)庫 (2009-4-17 9:33:18)
      ·Access中使用Create Procedure創(chuàng)建 (2009-4-17 9:31:08)
      ·asp實(shí)現(xiàn)同網(wǎng)站不同目錄綁定不同域名 (2009-4-17 9:27:57)
       熱門文章 哈爾濱電腦
      ·安全防護(hù)策略-打造堡壘主機(jī)
      ·SQL Server到底需要使用哪些端口?
      ·把重要的Word 2003文檔放到菜單中
      ·您試圖在此 Web 服務(wù)器上訪問的 
      ·Photoshop制作火焰的神龍
      ·Win2003架設(shè)多用戶隔離Ftp服務(wù)器
      ·XP系統(tǒng)服務(wù)恢復(fù)批處理
      ·還有2天發(fā)布 Windows7必備77條小知識
      ·情侶玩兒法:用虛擬硬盤打造堅不可摧的影子系統(tǒng)
      ·用U盤當(dāng)鑰匙 輕松繞過WinXP的登陸密碼
      ·Photoshop打造漂亮的心形掛鏈壁紙
       推薦文章 哈爾濱電腦
      ·精簡節(jié)約!小公司辦公打印省錢全攻略
      ·CSS布局方法的十八般技巧和兼容方案
      ·三種方法 教你解決輸入法不顯示的問題
      ·當(dāng)紅情侶QQ表情:茉莉和龍井
      ·Win 7出現(xiàn)休眠Bug 微軟提供解決方案
      ·將Powerpoint文檔轉(zhuǎn)換為Word文檔
      ·非常實(shí)用來學(xué)習(xí)連續(xù)供墨系統(tǒng)入門知識
      ·怕吃虧?怕假的?鑒別真假耗材的小竅門
      ·情侶玩兒法:用虛擬硬盤打造堅不可摧的影子系統(tǒng)
      ·開始—運(yùn)行(cmd)命令大全
      ·您試圖在此 Web 服務(wù)器上訪問的 
       最新文章 哈爾濱電腦
      ·Web服務(wù)器如何避免CC攻擊
      ·SQL Server到底需要使用哪些端口?
      ·XP系統(tǒng)服務(wù)恢復(fù)批處理
      ·局域網(wǎng)遭ARP攻擊網(wǎng)絡(luò)掉線批處理
      ·CISCO 2811 路由器配置命令全集
      ·避免“悲劇” 打印機(jī)使用技巧全面攻略
      ·保障遠(yuǎn)程桌面Web連接安全四項注意
      ·教你六招處理服務(wù)器數(shù)據(jù)意外丟失
      ·挑選相紙有學(xué)問 教你如何辨別相紙優(yōu)劣
      ·精簡節(jié)約!小公司辦公打印省錢全攻略
      ·CSS布局方法的十八般技巧和兼容方案