您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)SQL Server中怎么實(shí)現(xiàn)數(shù)據(jù)類型轉(zhuǎn)換,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
1 顯式轉(zhuǎn)換
顯示轉(zhuǎn)換是將某種數(shù)據(jù)類型的表達(dá)式顯式轉(zhuǎn)換為另一種數(shù)據(jù)類型。常用的是CAST 和 CONVERT 函數(shù)。
CAST: CAST ( expression AS data_type )CONVERT: CONVERT (data_type[(length)], expression [, style])
參數(shù) expression 是任何有效的 Microsoft SQL Server表達(dá)式。data_type 目標(biāo)系統(tǒng)所提供的數(shù)據(jù)類型,不能使用用戶定義的數(shù)據(jù)類型。
2 隱性轉(zhuǎn)換
隱性轉(zhuǎn)換對(duì)于用戶是不可見的,由SQL Server 引擎自動(dòng)處理。 隱性轉(zhuǎn)換自動(dòng)將數(shù)據(jù)從一種數(shù)據(jù)類型轉(zhuǎn)換成另一種數(shù)據(jù)類型。例如,如果一個(gè) smallint 變量和一個(gè) int 變量相比較,這個(gè) smallint 變量在比較前即被隱性轉(zhuǎn)換成 int 變量。 當(dāng)從一個(gè) SQL Server 對(duì)象的數(shù)據(jù)類型向另一個(gè)轉(zhuǎn)換時(shí),一些隱性和顯式數(shù)據(jù)類型轉(zhuǎn)換是不支持的。例如,nchar 數(shù)值根本就不能被轉(zhuǎn)換成 image 數(shù)值。nchar 只能顯式地轉(zhuǎn)換成 binary,隱性地轉(zhuǎn)換到 binary 是不支持的。nchar 可以顯式地或者隱性地轉(zhuǎn)換成 nvarchar。
3 隱性轉(zhuǎn)換的風(fēng)險(xiǎn)
隱性轉(zhuǎn)換有的時(shí)候非常方便,可以簡(jiǎn)化SQL 腳本,但是這里面也孕育著潛在的風(fēng)險(xiǎn),可能會(huì)出現(xiàn)在腳本一開始運(yùn)行的時(shí)候都是正常的,但卻某一個(gè)時(shí)間點(diǎn)之后,程序莫名出現(xiàn)錯(cuò)誤。下面舉一個(gè)現(xiàn)實(shí)項(xiàng)目中的例子來說明。在SQL Server 2008中有一個(gè)表,需要從兩個(gè)不同的數(shù)據(jù)表中拉取數(shù)據(jù),由于這兩個(gè)數(shù)據(jù)表屬于不同的系統(tǒng),其主鍵類型是不同的,一個(gè)是int類型,一個(gè)是GUID,一開始想著這兩個(gè)都可以轉(zhuǎn)換成字符類型進(jìn)行存儲(chǔ)。所以就在表中建立一個(gè)nvarchar(50)的混合ID列作為主鍵。如下圖所示:
一開始拉取的數(shù)據(jù)并未有GUID的值,都是INT類型轉(zhuǎn)換過來的數(shù)據(jù),所以SQL腳本運(yùn)行的正常,但是突然某一次運(yùn)行時(shí),出現(xiàn)了“在將 nvarchar 值 '4C185367-F004-41FE-8A0A-DB4E819B1FF2' 轉(zhuǎn)換成數(shù)據(jù)類型 int 時(shí)失敗。”的錯(cuò)誤。如下圖所示:
定位到腳本,執(zhí)行的SQL如下:
select * from dbo.Demo where 混合ID=305
其中主鍵中的數(shù)據(jù)有GUID轉(zhuǎn)換的字符型,也有INT轉(zhuǎn)換的字符串,示例數(shù)據(jù)如下:
但是如果執(zhí)行下面的SQL,則都是正常執(zhí)行:
select * from dbo.Demo where 混合ID=305 and 名稱='INT'select * from dbo.Demo where 混合ID=305 and 序號(hào)='2'select * from dbo.Demo where 混合ID=305 and 序號(hào)=2select * from dbo.Demo where 混合ID='305' and 名稱='INT'select * from dbo.Demo where 混合ID='305'
select * from dbo.Demo where 混合ID=305在執(zhí)行時(shí),SQL Server會(huì)將nvarchar類型的隱性轉(zhuǎn)換成int類型,如果數(shù)據(jù)中沒有GUID類型的字符,則轉(zhuǎn)換正常,如果有,當(dāng)進(jìn)行GUID字符到INT的隱性轉(zhuǎn)換時(shí),則轉(zhuǎn)換失敗。
關(guān)于SQL Server中怎么實(shí)現(xiàn)數(shù)據(jù)類型轉(zhuǎn)換就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。