亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

如何提高MSSQL和Access的兼容性

2024-09-07 19:02:54
字體:
來源:轉載
供稿:網友

    大家都知道asp當中,最常用到的是Access和MSSQL兩個數據庫。很多程序都想開發成兩個數據庫都可以使用的模式,但是礙于兩個數據庫得一些sql語句不一致,所以導致很多程序都分兩個沒有必要的版本,就是access和mssql版!而事實上,我們可以通過對代碼判斷和識別,控制整個程序的兼容性。也就是說,將兩個版本兼容成一個系統。例如我的asp飛云小說系統,就是兩種數據庫都可以運作的程序。


    那么,到底如何讓程序存在數據庫兼容性并且得到高效的運作呢。下邊我將以我的飛云小說系統做范例,說說我的一些控制方法和代碼。


    首先,我們要控制一個參數,讓程序知道我們現在運作的是什么數據庫。


    如:飛云小說程序中的config.asp文件參數

const systemdatabasetype = "access"      '系統數據庫類型,"sql"為mssql 2000/2005數據庫,"access"為ms access 2000數據庫

    這是兼容性開始的基礎,是整個程序數據庫的判別。所以是非常有必要設置這么一個參數的。


    第二,數據庫連接方式和常用函數的區分


    在我的程序當中,conn.asp里邊還存在下邊的一段代碼:

if systemdatabasetype = "sql" then
        connstr = "provider = sqloledb; user id = " & sqlusername & "; password = " & sqlpassword & "; initial catalog = " & sqldatabasename & "; data source = " & sqlhostip & ";"
        fy_true = "1"
        fy_false = "0"
        fy_now = "getdate()"
        fy_ordertype = " desc"
        fy_datepart_d = "d"
        fy_datepart_y = "yyyy"
        fy_datepart_m = "m"
        fy_datepart_w = "ww"
        fy_datepart_h = "hh"
else   
        connstr= "provider = microsoft.jet.oledb.4.0;data source = " & server.mappath(mdb)
        fy_true = "true"
        fy_false = "false"
        fy_now = "now()"
        fy_ordertype = " asc"
        fy_datepart_d = "'d'"
        fy_datepart_y = "'yyyy'"
        fy_datepart_m = "'m'"
        fy_datepart_w = "'ww'"
        fy_datepart_h = "'h'"
end if 

    這個代碼,除了區別數據庫連接方式之后,還將mssql和access常用的語句進行變量賦值。這樣做的好處就是后面使用相關內容的時候可以直接使用調用變量的方法,而不再需要進行數據庫類型的判斷。


    例如對比時間的datediff函數問題上:

代碼:
"select * from [表] where datediff('"&fy_datepart_d&",數據庫時間,'變量名)=0 order by id desc" 

    這樣就免去了數據庫的判別,減少了代碼量和實用性。


    第三,正確使用兼容性代碼,而不使用特色代碼。


    很多人在寫mssql數據庫的是很,都很喜歡使用conn.execute語句,而不使用open方式。雖然在速度上,很多時間conn.execute會比open方式要高速度一點。但是這不是一概而論的。


    比如說,在一個判斷是否已經存在的過程算法當中。如果你已經使用了open進行了bof或eof的判斷,那么你還要使用conn.execute進行判斷的話,那速度,肯定是不如在open直接修改的好。


    而且,在代碼當中open方式的兼容性,遠遠要高過conn.execute。例如時間函數now()的使用上.(這個函數在access和mssql的區別,大家自己去百度)


    第四,在追求兼容性的情況下,犧牲一點效率也是必要的。


    第三點當中,如果你的過程不需要判斷是否存在,就是在沒有打開open的情況下的話。你可以使用conn.execute。但是我的不是一概而論的。比如說,如果是一個比較少用到,不是頻繁讀取的過程。我會選擇使用open方式,而不使用conn.execute方式。


    雖然這過程的速度會降低。可是這不影響到我的使用,所以我還是選擇open方式。原因很簡單,就是兼容性的選擇。


    最后,在必要的時候放棄兼容性的追求,采用不同數據庫不同代碼。


    前面第一點,我們對代碼已經做了一個設置,就是數據庫類型的設置。那么當我們遇到一些不能通過兼容性解決,或者是像conn.execute和open方式上的追求的時候。我們可以利用前面systemdatabasetype的參數設置進行判斷,然后相應使用不同的代碼。

如:
if systemdatabasetype = "sql" then
'mssql數據庫時使用的代碼
  else   
'access數據庫時使用的代碼
end if

    這樣就可以保證程序的高效性以及穩定性。這也是整個程序的兼容性的一種。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩成人在线视频| 精品国产一区二区三区在线观看| 久久久精品电影| 91精品国产九九九久久久亚洲| 久久福利网址导航| 国产精品日日做人人爱| 伊人伊人伊人久久| 性日韩欧美在线视频| 国产69精品久久久久久| 国产精品丝袜久久久久久高清| 久久久久久久久久久久av| 亚洲国产精品人久久电影| 91成人免费观看网站| 久久免费成人精品视频| 国产香蕉97碰碰久久人人| 一区二区av在线| 欧美高跟鞋交xxxxxhd| 中文字幕精品一区二区精品| 国产精品日韩在线观看| 黑人精品xxx一区| 欧美日韩国产999| 国产精品一区二区三区成人| 日韩成人小视频| 一二美女精品欧洲| 精品国产91乱高清在线观看| 成人亲热视频网站| 欧美在线视频一区二区| 亚洲另类欧美自拍| 亚洲成人精品av| 国产亚洲视频在线观看| 久久精品91久久久久久再现| 亚洲石原莉奈一区二区在线观看| 亚洲成人精品视频| 国产日韩欧美在线看| 九九热这里只有精品6| 在线精品播放av| 日本免费在线精品| www高清在线视频日韩欧美| 久久国产精品久久久久久| 亚洲精品久久久久中文字幕欢迎你| 国产精品免费观看在线| 精品视频久久久久久| 欧美午夜丰满在线18影院| 久久久久久91| 韩国国内大量揄拍精品视频| **欧美日韩vr在线| 亚洲激情在线视频| 国模叶桐国产精品一区| 91影院在线免费观看视频| 精品欧美aⅴ在线网站| 欧美日韩一区二区在线播放| 日韩电影免费在线观看| 欧美理论电影在线播放| 亲子乱一区二区三区电影| 国产拍精品一二三| 91av在线免费观看| 高清一区二区三区日本久| 亚洲国产精品悠悠久久琪琪| 91亚洲精品一区二区| 日韩精品欧美国产精品忘忧草| 精品国产乱码久久久久久婷婷| 成人网在线免费看| 亚洲国产天堂网精品网站| 亚洲人成伊人成综合网久久久| 国产一区二区三区在线观看网站| 国产日韩专区在线| 国产成人亚洲综合91精品| 亚洲激情视频在线观看| 欧美一区在线直播| 国产精品一区二区三区在线播放| 国产精品扒开腿做爽爽爽男男| 欧美日韩国产色视频| 欧美裸体xxxx极品少妇| 欧美极品少妇xxxxⅹ喷水| 国产成人精品电影久久久| 96sao精品视频在线观看| 国产欧美一区二区三区在线看| 7m第一福利500精品视频| 亚洲伊人一本大道中文字幕| 日韩在线国产精品| 亚洲视频国产视频| 国产成人精品综合久久久| 欧美成人激情视频免费观看| 国产成人aa精品一区在线播放| 97成人在线视频| 色妞欧美日韩在线| 亚洲午夜未删减在线观看| 精品久久久视频| 国产成人精品综合| 中文字幕亚洲综合久久筱田步美| 亚洲精品suv精品一区二区| 亚洲精品视频播放| 亚洲韩国欧洲国产日产av| 亚洲社区在线观看| 91成人在线观看国产| 亚洲日本中文字幕免费在线不卡| 国产精自产拍久久久久久| 国产成+人+综合+亚洲欧洲| 日韩高清中文字幕| 亚洲欧美日韩网| 在线播放国产精品| 人九九综合九九宗合| 国产精品青青在线观看爽香蕉| 成人性生交大片免费看视频直播| 久热国产精品视频| 中文字幕在线看视频国产欧美| 国模吧一区二区三区| 国产免费观看久久黄| 亚洲成**性毛茸茸| 国产精品久久久一区| 国产精品99久久99久久久二8| 最近2019年日本中文免费字幕| 国产精品久久999| 欧美成人午夜激情视频| 成人黄色网免费| 欧美成人免费网| 国产精品久久久久av| 国产精品久久久久久婷婷天堂| 91精品国产91久久久久久最新| 欧美大胆在线视频| 久久久国产视频91| 国产精品久久9| 日本sm极度另类视频| 久久黄色av网站| 欧美在线播放视频| 欧美在线视频观看免费网站| 麻豆乱码国产一区二区三区| 久久久久久久久亚洲| 91精品久久久久久久久中文字幕| 美女999久久久精品视频| 欧美丰满片xxx777| 日韩欧美主播在线| 欧美激情性做爰免费视频| 日韩精品视频在线观看免费| 成人疯狂猛交xxx| 欧美壮男野外gaytube| 欧洲精品毛片网站| 中文字幕免费精品一区高清| 国产精品综合久久久| 国产精品mp4| 国产亚洲福利一区| 九九热最新视频//这里只有精品| 91av中文字幕| 在线精品91av| 国产在线观看91精品一区| 久久久亚洲福利精品午夜| 中文字幕一区日韩电影| 欧美日韩激情小视频| 欧美激情图片区| 欧美精品免费在线| 亚洲最新中文字幕| 日韩高清av一区二区三区| 中文字幕久热精品在线视频| 2019中文字幕在线| 日本免费久久高清视频| 欧美激情一区二区久久久| 91精品91久久久久久| 亚洲精品成a人在线观看| 国产欧美 在线欧美| 色婷婷综合久久久久| 亚洲成av人片在线观看香蕉| 久久久人成影片一区二区三区观看| 久久影视三级福利片| 日韩欧美在线国产|