ACCESS轉(zhuǎn)SQL數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能
本文主要介紹ACCESS轉(zhuǎn)SQL SERVER的數(shù)據(jù)庫(kù)的幾點(diǎn)經(jīng)驗(yàn)、把ACCESS轉(zhuǎn)成SQL數(shù)據(jù)庫(kù)連接的具體方法和把ACCESS轉(zhuǎn)成SQL數(shù)據(jù)庫(kù)。
ACCESS轉(zhuǎn)SQL SERVER的數(shù)據(jù)庫(kù)的幾點(diǎn)經(jīng)驗(yàn)
1.ACCESS的數(shù)據(jù)庫(kù)中的自動(dòng)編號(hào)類型在轉(zhuǎn)化時(shí),sql server并沒(méi)有將它設(shè)為自動(dòng)編號(hào)型,我們需在SQL創(chuàng)建語(yǔ)句中加上identity,表示自動(dòng)編號(hào)!
2.轉(zhuǎn)化時(shí),跟日期有關(guān)的字段,SQL SERVER默認(rèn)為smalldatetime型,我們最好將它變?yōu)閐atetime型,因?yàn)閐atetime型的范圍比smalldatetime型大。我遇見(jiàn)這種情況,用smalldatetime型時(shí),轉(zhuǎn)化失敗,而用datetime型時(shí),轉(zhuǎn)化成功。
3.對(duì)此兩種數(shù)據(jù)庫(kù)進(jìn)行操作的sql語(yǔ)句不全相同,例如:在對(duì)ACCESS數(shù)據(jù)庫(kù)進(jìn)行刪除紀(jì)錄時(shí)用:“delete * from user where id=10“,而對(duì)SQL SERVER數(shù)據(jù)庫(kù)進(jìn)行刪除是用:“delete user where id=10“.
4.日期函數(shù)不相同,在對(duì)ACCESS數(shù)據(jù)庫(kù)處理中,可用date()、time()等函數(shù),但對(duì)SQL SERVER數(shù)據(jù)庫(kù)處理中,只能用datediff,dateadd等函數(shù),而不能用date()、time()等函數(shù)。
;5.在對(duì)ACCESS數(shù)據(jù)庫(kù)處理中,sql語(yǔ)句中直接可以用一些VB的函數(shù),像cstr()函數(shù),而對(duì)SQL SERVER數(shù)據(jù)庫(kù)處理中,卻不能用。
如何實(shí)現(xiàn)ACCESS轉(zhuǎn)SQL數(shù)據(jù)庫(kù)連接?
其實(shí)兩者基本通用 步驟很簡(jiǎn)單3步:1,轉(zhuǎn)化MDB數(shù)據(jù)庫(kù)到SQL SQL工具里就有
2, 更改數(shù)據(jù)庫(kù)鏈接字串 以下為代碼:
以下為引用的內(nèi)容:Set Conn=Server.CreateObject("ADODB.Connection")SQL="Driver={SQL Server};Server=XD-Y1W9B7;UID=sa;PWD=sa;DataBase=ljl"Conn.Open(SQL)
最后是SQL與ACCESS差異的地方· 這個(gè)大家需要注意 下面為其詳細(xì)講解:
把ACCESS轉(zhuǎn)成SQL數(shù)據(jù)庫(kù)
很多朋友想用SQL2000數(shù)據(jù)庫(kù)的編程方法,但是卻又苦于自己是學(xué)ACCESS的,對(duì)SQL只是一點(diǎn)點(diǎn)的了解而已,這里我給大家提供以下參考---將ACCESS轉(zhuǎn)化成SQL2000的方法和注意事項(xiàng)。
一,首先,我說(shuō)的是在ACCESS2000,SQL2000之間轉(zhuǎn)換,其他的我也還沒(méi)有嘗試過(guò),希望大家多多試驗(yàn),肯定是有辦法的;
二,轉(zhuǎn)換的方法
1,打開(kāi)控制面板“下管理工具“中的數(shù)據(jù)庫(kù)源“;
2,按添加“添加一個(gè)新的數(shù)據(jù)源,在選擇欄里選Driver do microsoft Access (*.mdb),完成后將出現(xiàn)一個(gè)框, 在數(shù)據(jù)庫(kù)源“里面輸入你想寫(xiě)的名稱,我取名叫“ABC,說(shuō)明不需要填,接著,按下面的選擇,尋找你的數(shù)據(jù)庫(kù)地址和選中(注意,請(qǐng)先備份自己的ACCESS數(shù)據(jù)庫(kù)),然后確定。數(shù)據(jù)源在這里建好了,剩下轉(zhuǎn)換了。 3,打開(kāi)SQL2000企業(yè)管理器,進(jìn)入數(shù)據(jù)庫(kù),新建一個(gè)空的數(shù)據(jù)庫(kù)“ABC;
4,選擇新建立的數(shù)據(jù)庫(kù),按鼠標(biāo)右鍵,選擇“所有任務(wù)下“導(dǎo)入數(shù)據(jù),按“下一步繼續(xù);
5,在數(shù)據(jù)庫(kù)源下拉但中選擇Driver do microsoft Access(*.mdb)“,在用戶/系統(tǒng)DSN“中,選種你剛才添加的ABC“,按 下一步“;
6,“目的不需要修改,選擇服務(wù)器(一般下為自己的本機(jī)“local“,也可以選擇服務(wù)器地址或者局域網(wǎng)地址,確定你的權(quán)限是否可以操作,),“使用WINDOWS 身份驗(yàn)證“指用自己的系統(tǒng)管理員身份操作,“使用SQL身份操作驗(yàn)證“可以用于網(wǎng)站的操作,推薦用后者;
7,選上“使用SQL身份操作驗(yàn)證“后,填寫(xiě)你的用戶名和密碼,我自己選擇的是系統(tǒng)默認(rèn)號(hào)碼“sa“,“****“,數(shù)據(jù)庫(kù)選擇剛新建的“ABC“,按“下一步“;
8,這一步的兩個(gè)單項(xiàng)選擇,“從數(shù)據(jù)源復(fù)制表和視圖“與“用一條查詢指令指定要傳輸?shù)臄?shù)據(jù)“,選擇前者,按“下一步“繼續(xù);
9,這里將出現(xiàn)你自己ACCESS數(shù)據(jù)庫(kù)的表,按“全選“后,下一步;
10,“DTS導(dǎo)入/導(dǎo)出向?qū)?ldquo;,看“立即運(yùn)行“被選中按“下一步“,
11,按“完成“繼續(xù);
12,這個(gè)步驟你將看到你的數(shù)據(jù)被導(dǎo)入SQL2000里面,當(dāng)出現(xiàn)“已經(jīng)成功把XXX個(gè)表導(dǎo)入到數(shù)據(jù)庫(kù)“的字樣,而且所有的表前面都有綠色的勾,就表示成功導(dǎo)入所有數(shù)據(jù),如果中途出現(xiàn)問(wèn)題或者表前面有紅色的叉的話,說(shuō)明該表沒(méi)有成功導(dǎo)入,這時(shí)就要回去查看自己的操作是否正確了.
三,數(shù)據(jù)修改
1,由于SQL2000里面沒(méi)有“自動(dòng)編號(hào)“,所以你的以“自動(dòng)編號(hào)“設(shè)置的字段都會(huì)變成非空的字段,這就必須手工修改這些字段,并把他的“標(biāo)示“選擇“是“,種子為“1“,增量為“1“, 2,另外,ACCESS2000轉(zhuǎn)換成SQL2000后,原來(lái)屬性為“是/否“的字段將被轉(zhuǎn)換成非空的“bit“,這時(shí)候你必須修改成自己想要的屬性了; 3,另外,大家要注意對(duì)時(shí)間函數(shù)的把握.ACCESS與SQL是有很多不同的. ACCESS改為SQL需要注意哪幾個(gè)地方數(shù)據(jù)庫(kù)導(dǎo)入以后,自動(dòng)增加字段需要重寫(xiě),所有的數(shù)字類型需要增加長(zhǎng)度,最好用decimal。所有的默認(rèn)值都丟失了。主要是數(shù)字類型和日期類型。所有now(),time(),date()要改成getdate()。 所有datediff(‘d‘, time1, time2)要改成datediff(day, time1, time2) 有可能一些true/false類型不能使用,要變?yōu)?/0。
備注類型要通過(guò)cast(column as varchar)來(lái)使用。 CursorType要改成1,也就是打開(kāi)數(shù)據(jù)庫(kù)時(shí)要給出第一個(gè)數(shù)字參數(shù)為1,否則記錄可能顯示不完整。 isnull(rowname)要改成rowname = null ACCESS的數(shù)據(jù)庫(kù)中的自動(dòng)編號(hào)類型在轉(zhuǎn)化時(shí),sql server并沒(méi)有將它設(shè)為自動(dòng)編號(hào)型,我們需在SQL創(chuàng)建語(yǔ)句中加上identity,表示自動(dòng)編號(hào)! 轉(zhuǎn)化時(shí),跟日期有關(guān)的字段,SQL SERVER默認(rèn)為smalldatetime型,我們最好將它變?yōu)閐atetime型,因?yàn)閐atetime型的范圍比smalldatetime型大。有時(shí)用smalldatetime型時(shí),轉(zhuǎn)化失敗,而用datetime型時(shí),轉(zhuǎn)化成功。 對(duì)此兩種數(shù)據(jù)庫(kù)進(jìn)行操作的sql語(yǔ)句不全相同,例如:在對(duì)ACCESS數(shù)據(jù)庫(kù)進(jìn)行刪除紀(jì)錄時(shí)用:“delete * from user where id=10“,而對(duì)SQL SERVER數(shù)據(jù)庫(kù)進(jìn)行刪除是用:“delete user where id=10“. 日期函數(shù)不相同,在對(duì)ACCESS數(shù)據(jù)庫(kù)處理中,可用date()、time()等函數(shù),但對(duì)SQL SERVER數(shù)據(jù)庫(kù)處理中,只能用datediff,dateadd等函數(shù),而不能用date()、time()等函數(shù)。 在對(duì)ACCESS數(shù)據(jù)庫(kù)處理中,sql語(yǔ)句中直接可以用一些VB的函數(shù),像cstr()函數(shù),而對(duì)SQL SERVER數(shù)據(jù)庫(kù)處理中,卻不能用。
相關(guān)文章:
1. Microsoft Office Access修改代碼字體大小的方法2. mysql數(shù)據(jù)存放的位置在哪3. 恢復(fù)從 Access 2000、 Access 2002 或 Access 2003 中數(shù)據(jù)庫(kù)刪除表的方法4. MySQL中InnoDB和MyISAM類型的差別5. 啟動(dòng)MYSQL出錯(cuò) Manager of pid-file quit without updating file.6. MySQL 字符串函數(shù):字符串截取7. Mysql入門(mén)系列:MYSQL創(chuàng)建、刪除、索引和更改表8. Mysql入門(mén)系列:建立MYSQL客戶機(jī)程序的一般過(guò)程9. MySQL 8.0 之索引跳躍掃描(Index Skip Scan)10. MySQL基礎(chǔ)教程9 —— 函數(shù)之日期和時(shí)間函數(shù)
