偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Access轉SQL Server數(shù)據(jù)庫的經(jīng)驗漫談

數(shù)據(jù)庫 SQL Server
下面的文章主要介紹的是Access轉SQL Server數(shù)據(jù)庫的幾個經(jīng)驗,以下就是Access轉SQL Server數(shù)據(jù)庫的經(jīng)驗具體方案的描述,希望在你今后的學習中會有所幫助。

以下的文章主要描述的是Access轉SQL Server數(shù)據(jù)庫的幾個經(jīng)驗漫談,Access數(shù)據(jù)庫作為一個中小型的單機數(shù)據(jù)庫系統(tǒng),在承擔訪問量、數(shù)據(jù)量大的網(wǎng)站應用時,往往就不堪重負了。一般認為。

超過50M的access數(shù)據(jù)庫性能就開始明顯下降,超過100M以后,出錯、運行慢的問題會更加突出。而我的BLOG數(shù)據(jù)庫已達到了四百多兆,痛定思痛,決定升級為SQL Server 2005。

這其中,走了好些彎路,起初我是直接利用企業(yè)管理器把Access導入SQL中,發(fā)現(xiàn)SQLl數(shù)據(jù)庫表是沒有自動字段的,原來Access中的自動字段被轉換成了普通字段,需要手工改成標識類型,增量為1。 所有的時間字段,如果定義了默認值,那么原來是now(),現(xiàn)在需要改成getdate() 。原來字段的默認值都不會自動引入,需要對照原表的字段手工添加。注釋在Access項目或SQLServer數(shù)據(jù)庫中,前綴“n”代表“國家/地區(qū)”,意思是這個數(shù)據(jù)類型是啟用Unicode的。在Access數(shù)據(jù)庫中,全部文本列在默認情況下都是啟用Unicode的。真費了我,好些光景。

如此這般數(shù)據(jù)庫可以調用,程序將就著能運行了,但發(fā)現(xiàn),原來的程序運行起來錯誤百出。

原來,Access與SQL程序中使用到的SQL查詢語句大體差不多,但是有一些微妙的差別,正是這些差別,造成了程序的不通用,一般要修改的部分如下:

(1)時間函數(shù)的問題:SQL數(shù)據(jù)庫的時間函數(shù)與access不同,最常見的是取現(xiàn)在時間的函數(shù),access是now(),SQL是getdate()。因此凡是在where子句中使用了now()的地方都要改成getdate();注意,now()函數(shù)在asp程序本身也要使用,凡是不在SQL Server數(shù)據(jù)庫查詢或執(zhí)行語句中使用的now()函數(shù)千萬不要改。

(2)時間比較函數(shù):datediff('d','時間1',‘時間2’)這是access查詢用的格式,SQl中這些引號都要去掉,同時時間格式的前后可能加上了#,這也要去掉。同樣這也是指在sql語句中的,在asp語句中的要保持原樣。

(3)空值的表示:在access中,判斷空值一般用是否=""來表示,但是這在SQL中往往出錯,如果遇到出錯的問題或者程序運行不正常,可以改成如這樣判斷:where (name is null)

(4)真假值判斷:access中可以用=true、=false來判斷,但是在SQL中就會出錯,因此在SQL查詢或執(zhí)行語句中這類判斷要分別改成=1、=0。注意一點:有些程序雖然寫成=“true”,但是由于有引號,所以這個字段是字符類型的,你不能改成=1,保持原樣即可。

(5)在對ACCESS數(shù)據(jù)庫進行刪除紀錄時用:"delete * from user where id=10",而對SQL Server數(shù)據(jù)庫進行刪除是用:"delete user where id=10"。

(6)在對ACCESS數(shù)據(jù)庫處理中,sql語句中直接可以用一些VB的函數(shù),像cstr()函數(shù),而對SQL Server數(shù)據(jù)庫處理中,卻不能用。

調試程序經(jīng)常遇到的出錯的語句是:conn.execute(sql),注意這句本身是沒有錯的,錯誤原因是里面的這個sql字符串,要向上看這個sql字符串是如何生成的,按照上面所說的程序修改辦法修改。

***向大家推薦一款工具,可以直接生成生成升遷 SQL腳本,保存為 *.sql文件后,SQL2000的查詢分析器里調入執(zhí)行,可以生成升遷 ASP腳本,這樣你可以用該腳本和相應MDB數(shù)據(jù)庫上傳到服務器在線升遷,可以直接執(zhí)行Access數(shù)據(jù)導入到SQL服務器(表結構和數(shù)據(jù))。

程序編制: V37 paintblue.net (2004-11-20)

版權所有: paintblue.net | blueidea.com

無論商業(yè)還是免費,你可以自由使用

 

  1. CooSel2.0 CreateSQL V1.05 

1.ACCESS的數(shù)據(jù)庫中的自動編號類型在轉化時,SQL Server并沒有將它設為自動編號型,我們需在SQL創(chuàng)建語句中加上identity,表示自動編號!

2.轉化時,跟日期有關的字段,SQL Server默認為smalldatetime型,我們***將它變?yōu)閐atetime型,因為datetime型的范圍比smalldatetime型大。我遇見這種情況,用smalldatetime型時,轉化失敗,而用datetime型時,轉化成功。

3.對此兩種數(shù)據(jù)庫進行操作的sql語句不全相同,例如:在對ACCESS數(shù)據(jù)庫進行刪除紀錄時用:"delete * from user where id=10",而對SQLSERVER數(shù)據(jù)庫進行刪除是用:"delete user where id=10".

4.日期函數(shù)不相同,在對ACCESS數(shù)據(jù)庫處理中,可用date()、time()等函數(shù),但對SQL Server數(shù)據(jù)庫處理中,只能用datediff,dateadd等函數(shù),而不能用date()、time()等函數(shù)。

5.在對ACCESS數(shù)據(jù)庫處理中,sql語句中直接可以用一些VB的函數(shù),像cstr()函數(shù),而對SQL Server數(shù)據(jù)庫處理中,卻不能用。

【編輯推薦】

  1. SQL Server 2000 數(shù)據(jù)倉庫中使用分區(qū)之分區(qū)的優(yōu)點
  2. SQL Server 2000 安裝時的一些癥狀歸納
  3. 啟動自動執(zhí)行SQL Server存儲過程的實際操作流程
  4. 對SQL Server引擎的介紹
  5. SQL Server數(shù)據(jù)庫與EXCEL數(shù)據(jù)導入與導出
責任編輯:佚名 來源: 服務器在線
相關推薦

2010-06-07 15:09:44

訪問MySQL數(shù)據(jù)庫

2010-11-08 16:04:06

SQL SERVER連

2010-10-22 11:22:33

SQL Server數(shù)

2011-03-28 17:12:36

sql server數(shù)優(yōu)化

2010-06-04 18:32:48

MySQL數(shù)據(jù)庫

2011-08-25 17:15:04

2010-07-06 16:24:53

SQL Server數(shù)

2009-08-03 14:17:18

C#連接AccessC#連接SQL Ser

2009-03-11 15:40:20

2010-07-21 14:11:36

SQL Server

2011-08-25 16:50:20

SQL ServerAccessASP

2010-07-15 17:28:50

SQL Server

2010-07-14 09:17:17

SQL Server數(shù)

2010-04-29 09:35:31

Oracle數(shù)據(jù)庫

2010-07-08 11:05:14

SQL Server數(shù)

2011-03-24 09:07:11

SQL Server數(shù)備份

2011-03-24 09:24:08

SQL Server數(shù)還原

2011-03-24 09:45:34

SQL Server數(shù)恢復

2011-03-23 17:10:41

ACCESSSQL數(shù)據(jù)庫

2021-05-17 06:57:34

SQLServer數(shù)據(jù)庫
點贊
收藏

51CTO技術棧公眾號