數(shù)據(jù)庫探索之旅——數(shù)據(jù)類型

目錄

1. 何為數(shù)據(jù)類型
2. 數(shù)據(jù)類型列表
3. 用戶自定義數(shù)據(jù)類型
4. 數(shù)據(jù)類型優(yōu)先級

在學(xué)習(xí)基本表之前杏慰,需要先了解一下數(shù)據(jù)類型干旁,一便更好的學(xué)習(xí)基本表魏烫。此處的數(shù)據(jù)類型基于 SQL Server 2012沐悦。

1. 何為數(shù)據(jù)類型

數(shù)據(jù)類型是一種屬性侥蒙,是用來限定表中的列的數(shù)據(jù)所允許存儲(chǔ)的數(shù)據(jù)的類型绳军,一列中的所有數(shù)值都應(yīng)該是同一種數(shù)據(jù)類型印机,除非該列指定為 sql_variant 數(shù)據(jù)類型的值。

數(shù)據(jù)類型一般分為數(shù)字類型门驾、日期和時(shí)間類型射赛、字符串類型、Unicode 字符串類型奶是、二進(jìn)制字符串類型楣责、空間類型、其他數(shù)據(jù)類型七大類聂沙。

2. 數(shù)據(jù)類型列表

數(shù)字類型
日期和時(shí)間類型
字符串類型
Unicode 字符串類型
二進(jìn)制字符串
空間類型
其他類型

幾點(diǎn)說明:

  1. Unicode 是計(jì)算機(jī)上的一種編碼方式秆麸。有興趣的書友可以到Unicode@字符百科查看各種字符對應(yīng)的編碼。
  2. 有一些數(shù)據(jù)類型都會(huì)有默認(rèn)值及汉,需要自定義長度的數(shù)據(jù)類型沮趣,在用戶不定義的時(shí)候,他會(huì)自動(dòng)給一個(gè)默認(rèn)值坷随。

3. 用戶自定義數(shù)據(jù)類型

用戶自定義數(shù)據(jù)類型是指用戶基于系統(tǒng)的數(shù)據(jù)類型而設(shè)計(jì)并實(shí)現(xiàn)的數(shù)據(jù)類型房铭。創(chuàng)建用戶自定義類型時(shí)必須提供數(shù)據(jù)類型的名稱驻龟、所基于的系統(tǒng)數(shù)據(jù)類型是否允許為空三個(gè)參數(shù)。

通過圖形界面創(chuàng)建

對象資源管理器下某個(gè)數(shù)據(jù)庫中找的可編程性節(jié)點(diǎn)缸匪,展開后右擊類型翁狐,如下圖:

用戶自定義數(shù)據(jù)類型

然后在界面上設(shè)置前面所說的三個(gè)參數(shù),名稱設(shè)為 mycs凌蔬,所基于的系統(tǒng)數(shù)據(jù)類型為 text露懒,是否允許為空選擇 √ 允許。如下圖:
設(shè)置類型參數(shù)

確定后可在可編程性下找到該數(shù)據(jù)類型砂心。
查看結(jié)果

通過T-SQL語句創(chuàng)建

需要調(diào)用 sp_addtype 存儲(chǔ)過程隐锭,基本語法如下:
sp_addtype [ @typename = ] type, [ @phystype = ] system_data_type [ , [@nulltype = ] 'null_type' ]

語法說明:

  1. [ @typename = ] type:自定義數(shù)據(jù)類型的名稱,該名稱在每個(gè)數(shù)據(jù)庫中是唯一的计贰。該類型無默認(rèn)值钦睡。
  2. [ @phystype = ] system_data_type:自定義數(shù)據(jù)類型所基于物理數(shù)據(jù)類型或 SQL Server 提供的數(shù)據(jù)類型。該類型無默認(rèn)值躁倒。
  3. [@nulltype = ] 'null_type':指定自定義數(shù)據(jù)類型處理空值的方式荞怒。null_type 的數(shù)據(jù)了行為 varchar(8),默認(rèn)值為 NULL秧秉,并且必須用單引號引起來('NULL'褐桌、'NOT NULL'或'NONULL')。

【實(shí)例】在 practice 數(shù)據(jù)庫中自定義基于 float 的不允許為空值的mysc1 數(shù)據(jù)類型象迎。
在查詢窗口鍵入命令:

USE practice;
GO
EXEC sp_addtype mysc1 ,'float','NOT NULL';

調(diào)試后可得結(jié)果如下圖:

成功創(chuàng)建 mysc1 數(shù)據(jù)類型

若要?jiǎng)h除用戶自定義的數(shù)據(jù)類型荧嵌,可通過如下方式:
sp_droptype [ @typename = ] 'type'
【實(shí)例】刪除 practice 數(shù)據(jù)庫中的 mysc1 數(shù)據(jù)類型。在查詢窗口鍵入如下命令:

USE practice;
GO
EXEC sp_droptype mysc

4. 數(shù)據(jù)類型的優(yōu)先級

當(dāng)兩個(gè)不同數(shù)據(jù)類型的表達(dá)式用運(yùn)算符結(jié)合后砾淌,數(shù)據(jù)類型優(yōu)先級規(guī)則將優(yōu)先級較低的數(shù)據(jù)類型轉(zhuǎn)換為優(yōu)先級較高的數(shù)據(jù)類型啦撮。如果此轉(zhuǎn)換不是所支持的飲食轉(zhuǎn)換,則會(huì)返回錯(cuò)誤汪厨。當(dāng)兩個(gè)操作數(shù)表達(dá)式具有相同的數(shù)據(jù)類型時(shí)赃春,運(yùn)算的結(jié)果便為該數(shù)據(jù)類型。

優(yōu)先級該地順序如下:
(最高)用戶自定義數(shù)據(jù)類型 > sql_variant > xml > datetimeoffset > datetime2 > datetime > smalldatetime > date > time > floart > real > decimal > money > smallmoney > bigint > int > smallint > tinyint > bit > ntext > text > image > timestamp > uniqueidentifier > nvarchar > nchar > varchar > char > varbinary > binary (最低)


以往的文章:

數(shù)據(jù)庫探索之旅——初識數(shù)據(jù)庫
數(shù)據(jù)庫探索之旅——數(shù)據(jù)庫管理系統(tǒng)
數(shù)據(jù)庫探索之旅——連接數(shù)據(jù)庫
數(shù)據(jù)庫探索之旅——對數(shù)據(jù)庫的簡單操作


如果覺得本文對你有用劫乱,請點(diǎn)擊收藏织中。(給點(diǎn)贊賞也不介意哦●0●)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市衷戈,隨后出現(xiàn)的幾起案子狭吼,更是在濱河造成了極大的恐慌,老刑警劉巖殖妇,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件刁笙,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)采盒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蔚润,“玉大人磅氨,你說我怎么就攤上這事〉站溃” “怎么了烦租?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長除盏。 經(jīng)常有香客問我叉橱,道長,這世上最難降的妖魔是什么者蠕? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任窃祝,我火速辦了婚禮,結(jié)果婚禮上踱侣,老公的妹妹穿的比我還像新娘粪小。我一直安慰自己,他們只是感情好抡句,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布探膊。 她就那樣靜靜地躺著,像睡著了一般待榔。 火紅的嫁衣襯著肌膚如雪逞壁。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天锐锣,我揣著相機(jī)與錄音腌闯,去河邊找鬼。 笑死雕憔,一個(gè)胖子當(dāng)著我的面吹牛绑嘹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播橘茉,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼工腋,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了畅卓?” 一聲冷哼從身側(cè)響起擅腰,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎翁潘,沒想到半個(gè)月后趁冈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年渗勘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了沐绒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,617評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡旺坠,死狀恐怖乔遮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情取刃,我是刑警寧澤蹋肮,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站璧疗,受9級特大地震影響坯辩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜崩侠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一漆魔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧却音,春花似錦有送、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至八拱,卻和暖如春阵赠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背肌稻。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工清蚀, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人爹谭。 一個(gè)月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓枷邪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親诺凡。 傳聞我的和親對象是個(gè)殘疾皇子东揣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容