SQL Server與Access數(shù)據(jù)庫ASP代碼的比較詳解
在用ASP開發(fā)網(wǎng)站時,后臺數(shù)據(jù)庫的選擇常常有兩種,一種是SQL Server,另一種就是Access,那么這兩種數(shù)據(jù)庫在ASP開發(fā)網(wǎng)站的過程中有什么不同的地方嗎?本文我們就來介紹這一部分內(nèi)容,希望能夠?qū)δ兴鶐椭?/p>
后臺數(shù)據(jù)庫:[Microsoft Access]與[Microsoft Sql Server]更換之后,ASP代碼應(yīng)注意要修改的一些地方:
一、連接問題(舉例)
- [Microsoft Access]
- constr = "DBQ=c:\data\clwz.mdb; DRIVER={Microsoft Access Driver (*.mdb)}"
- [Microsoft Sql Server]
- constr = "DRIVER={SQL Server};SERVER=host;DATABASE=mydata;uid=sa;pwd="
二、相似函數(shù)(舉例)
[1]DATEDIFF(datepart, startdate, enddate),其中“datepart”參數(shù)可選項如下:
- 設(shè)置 描述
- ————————————
- [Microsoft Access]
- 年 yyyy
- 季度 q
- 月 m
- 一年的日數(shù) y
- 日 d
- 一周的日數(shù) w
- 周 ww
- 小時 h
- 分鐘 n
- 秒 s
- [Microsoft Sql Server]
- year yy, yyyy
- quarter qq, q
- month mm, m
- dayofyear dy, y
- day dd, d
- week wk, ww
- hour hh
- minute mi, n
- second ss, s
- millisecond ms
基本上差不多,但注意的是在寫的時候,[Microsoft Access]要加引號,如:datediff('d',enddate,'2004/08/01'),[Microsoft Sql Server]則不需要,如:datediff(d,enddate,'2004/08/01')
[2][Microsoft Access]中可用如cstr等轉(zhuǎn)數(shù)據(jù)類型函數(shù),而[Microsoft Sql Server]中則用convert或cast函數(shù),如:convert(varchar,[amount])等。
[3][Microsoft Sql Server]取當(dāng)前時間用getdate等等...
三、語句
[Microsoft Sql Server]可以用
- CASE
- WHEN THEN
- WHEN THEN
- ...
- ELSE
- END
語句,而[Microsoft Access]不支持。[Microsoft Access]也不支持between語句,[Microsoft Sql Server]則可以這樣寫:[date] between @date1 and @date2。
四、查詢表
[Microsoft Sql Server]可三個及以上表join查詢,而[Microsoft Access]好像只能兩個表聯(lián)接查詢(待權(quán)威確認(rèn)),而且[Microsoft Sql Server]可用“*=”和“=*”連接符。
五、除零問題
[Microsoft Access]在碰到除數(shù)為零時,自動丟掉相關(guān)記錄,而[Microsoft Sql Server]則會報錯,且查詢中止。刪除代碼:[Microsoft Access]可以這樣寫:delete * from [table],[Microsoft SQL Server]只能這樣寫:delete from [table]多*會報錯。
當(dāng)前日期:[Microsoft Access]用date(),[Microsoft SQL Server],用getdate()如果數(shù)據(jù)庫可能會更換類型的話,可以在ASP代碼中加上如這樣:
- if inStr(constr,"Microsoft Access") > 0 then
- sqlstr=[Microsoft Access][sql代碼]
- else
- sqlstr=[Microsoft Sql Server][sql代碼]
- end if
這樣即使改了數(shù)據(jù)庫,也不用改數(shù)據(jù)庫查詢更新代碼了。再加:access中有true、false的字段記錄,而sql里只有smallint,對應(yīng)如果在access里有“字段名=true”的,在sql里要改成“字段名=1” ,網(wǎng)上大部分的免費asp程序使用的是access數(shù)據(jù)庫。但是access數(shù)據(jù)庫作為一個中小型的單機數(shù)據(jù)庫系統(tǒng),在承擔(dān)訪問量、數(shù)據(jù)量大的網(wǎng)站應(yīng)用時,往往就不堪重負(fù)了。
一般認(rèn)為,超過50M的access數(shù)據(jù)庫性能就開始明顯下降,超過100M以后,出錯、運行慢的問題會更加突出。盡管可以如動網(wǎng)7.0以后那樣,從程序的角度盡量優(yōu)化以圖提高性能,但是不能從根本上解決問題。這時也許使用微軟的SQL Server數(shù)據(jù)庫就是最可能的辦法,當(dāng)然也可以使用其它的如Oracle、MySQL等等,但是作為改寫來說,由于同為微軟的產(chǎn)品,改寫成SQL Server應(yīng)該是最省力的辦法。
關(guān)于SQL Server與Access數(shù)據(jù)庫ASP代碼的比較的相關(guān)知識就介紹到這里了,希望本次的介紹能夠?qū)δ兴斋@!
【編輯推薦】






