a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > 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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日本妇人成熟免费视频 | 亚洲福利在线观看 | 91色电影| 日韩av在线电影 | 超碰在线影院 | 91免费观看在线 | 国产精品理论 | 最新免费av网站 | 香蕉视频在线播放 | 日韩精品一区二区三区在线 | 日本激情在线 | 99精品国自产在线观看 | 日韩一区二区三区免费观看 | 国产精品久久久久久久久免费 | 久久精品欧美一区二区三区不卡 | 日韩欧美中文字幕在线观看 | 免费在线a | 少妇av片 | 久久免费精品视频 | 国产综合精品 | 国产精品久久久久aaaa九色 | 一区二区三区免费 | 久久九九国产精品 | 国产成人午夜精品影院游乐网 | 日韩精品一区二区三区免费观看视频 | 天天澡天天狠天天天做 | 亚洲不卡在线观看 | av影院在线观看 | 亚洲色图第一区 | 久久久成 | 亚洲人成人一区二区在线观看 | 草逼视频免费观看 | 亚洲成人av | 日本中文字幕在线视频 | 欧美国产高清 | 日韩成人免费视频 | 一区在线视频 | 一级毛片,一级毛片 | 午夜免费片| av电影中文字幕在线观看 | 欧美一区永久视频免费观看 |