SQL Server與Access數據庫ASP代碼的比較詳解
在用ASP開發網站時,后臺數據庫的選擇常常有兩種,一種是SQL Server,另一種就是Access,那么這兩種數據庫在ASP開發網站的過程中有什么不同的地方嗎?本文我們就來介紹這一部分內容,希望能夠對您有所幫助。
后臺數據庫:[Microsoft Access]與[Microsoft Sql Server]更換之后,ASP代碼應注意要修改的一些地方:
一、連接問題(舉例)
- [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="
二、相似函數(舉例)
[1]DATEDIFF(datepart, startdate, enddate),其中“datepart”參數可選項如下:
- 設置 描述
- ————————————
- [Microsoft Access]
- 年 yyyy
- 季度 q
- 月 m
- 一年的日數 y
- 日 d
- 一周的日數 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等轉數據類型函數,而[Microsoft Sql Server]中則用convert或cast函數,如:convert(varchar,[amount])等。
[3][Microsoft Sql Server]取當前時間用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]好像只能兩個表聯接查詢(待權威確認),而且[Microsoft Sql Server]可用“*=”和“=*”連接符。
五、除零問題
[Microsoft Access]在碰到除數為零時,自動丟掉相關記錄,而[Microsoft Sql Server]則會報錯,且查詢中止。刪除代碼:[Microsoft Access]可以這樣寫:delete * from [table],[Microsoft SQL Server]只能這樣寫:delete from [table]多*會報錯。
當前日期:[Microsoft Access]用date(),[Microsoft SQL Server],用getdate()如果數據庫可能會更換類型的話,可以在ASP代碼中加上如這樣:
- if inStr(constr,"Microsoft Access") > 0 then
- sqlstr=[Microsoft Access][sql代碼]
- else
- sqlstr=[Microsoft Sql Server][sql代碼]
- end if
這樣即使改了數據庫,也不用改數據庫查詢更新代碼了。再加:access中有true、false的字段記錄,而sql里只有smallint,對應如果在access里有“字段名=true”的,在sql里要改成“字段名=1” ,網上大部分的免費asp程序使用的是access數據庫。但是access數據庫作為一個中小型的單機數據庫系統,在承擔訪問量、數據量大的網站應用時,往往就不堪重負了。
一般認為,超過50M的access數據庫性能就開始明顯下降,超過100M以后,出錯、運行慢的問題會更加突出。盡管可以如動網7.0以后那樣,從程序的角度盡量優化以圖提高性能,但是不能從根本上解決問題。這時也許使用微軟的SQL Server數據庫就是最可能的辦法,當然也可以使用其它的如Oracle、MySQL等等,但是作為改寫來說,由于同為微軟的產品,改寫成SQL Server應該是最省力的辦法。
關于SQL Server與Access數據庫ASP代碼的比較的相關知識就介紹到這里了,希望本次的介紹能夠對您有所收獲!
【編輯推薦】