中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

MySQL數(shù)據(jù)庫char與varchar的區(qū)別分析及使用建議
來源:易賢網(wǎng) 閱讀:856 次 日期:2014-09-26 08:29:49
溫馨提示:易賢網(wǎng)小編為您整理了“MySQL數(shù)據(jù)庫char與varchar的區(qū)別分析及使用建議”,方便廣大網(wǎng)友查閱!

在數(shù)據(jù)庫中,字符 型的數(shù)據(jù)是最多的,可以占到整個(gè)數(shù)據(jù)庫的80%以上。為此正確處理字符型的數(shù)據(jù),對(duì)于提高數(shù)據(jù)庫的性能有很大的作用。在字符型數(shù)據(jù)中,用的最多的就是 Char與Varchar兩種類型。前面的是固定長(zhǎng)度,而后面的是可變長(zhǎng)度?,F(xiàn)在我們需要考慮的是,在什么情況下使用Char字符型數(shù)據(jù),什么情況下采用 Varchar字符型數(shù)據(jù)。

一、VARCHAR與CHAR字符型數(shù)據(jù)的差異

在MySQL數(shù)據(jù)庫中,用的最多的字符型數(shù)據(jù)類型就是Varchar和Char.。這兩種數(shù)據(jù)類型雖然都是用來存放字符型數(shù)據(jù),但是無論從結(jié)構(gòu)還是 從數(shù)據(jù)的保存方式來看,兩者相差很大。而且其具體的實(shí)現(xiàn)方式,還依賴與存儲(chǔ)引擎。我這里就以大家最常用的MYISAM存儲(chǔ)引擎為例,談?wù)勥@兩種數(shù)據(jù)類型的 差異。在后續(xù)建議中,也是針對(duì)這種存儲(chǔ)類型而言的。

這里首先需要明白的一點(diǎn)是,這兩種數(shù)據(jù)類型,無論采用哪一種存儲(chǔ)引起,系統(tǒng)存儲(chǔ)數(shù)據(jù)的方式都是不同的。正是因?yàn)槿绱?,我們才有必要研究?jī)烧叩牟煌H缓笤诤线m的情況下,采用恰當(dāng)?shù)姆绞?。了解這一點(diǎn)之后,我們?cè)賮砜春罄m(xù)的內(nèi)容。

Varchar往往用來保存可變長(zhǎng)度的字符串。簡(jiǎn)單的說,我們只是給其固定了一個(gè)最大值,然后系統(tǒng)會(huì)根據(jù)實(shí)際存儲(chǔ)的數(shù)據(jù)量來分配合適的存儲(chǔ)空間。為 此相比CHAR字符數(shù)據(jù)而言,其能夠比固定長(zhǎng)度類型占用更少的存儲(chǔ)空間。不過在實(shí)際工作中,由于某系特殊的原因,會(huì)在這里設(shè)置例外。如管理員可以根據(jù)需要 指定ROW_FORMAT=FIXED選項(xiàng)。利用這個(gè)選項(xiàng)來創(chuàng)建MyISAM表的話,系統(tǒng)將會(huì)為每一行使用固定長(zhǎng)度的空間。此時(shí)會(huì)造成存儲(chǔ)空間的損耗。通 常情況下,VARCHAR數(shù)據(jù)類型能夠節(jié)約磁盤空間,為此往往認(rèn)為其能夠提升數(shù)據(jù)庫的性能。不過這里需要注意的是,這往往是一把雙刃劍。其在提升性能的同 時(shí),往往也會(huì)產(chǎn)生一些副作用。如因?yàn)槠溟L(zhǎng)度是可變的,為此在數(shù)據(jù)進(jìn)行更新時(shí)可能會(huì)導(dǎo)致一些額外的工作。如在更改前,其字符長(zhǎng)度是10位(Varchar規(guī) 定的最長(zhǎng)字符數(shù)假設(shè)是50位),此時(shí)系統(tǒng)就只給其分配10個(gè)存儲(chǔ)的位置(假設(shè)不考慮系統(tǒng)自身的開銷)。更改后,其數(shù)據(jù)量達(dá)到了20位。由于沒有超過最大 50位的限制,為此數(shù)據(jù)庫還是允許其存儲(chǔ)的。只是其原先的存儲(chǔ)位置已經(jīng)無法滿足其存儲(chǔ)的需求。此時(shí)系統(tǒng)就需要進(jìn)行額外的操作。如根據(jù)存儲(chǔ)引擎不同,有的會(huì) 采用拆分機(jī)制,而有的則會(huì)采用分頁機(jī)制。

CHAR數(shù)據(jù)類型與VARCHAR數(shù)據(jù)類型不同,其采用的是固定長(zhǎng)度的存儲(chǔ)方式。簡(jiǎn)單的說,就是系統(tǒng)總為其分配最大的存儲(chǔ)空間。當(dāng)數(shù)據(jù)保存時(shí),即使 其沒有達(dá)到最大的長(zhǎng)度,系統(tǒng)也會(huì)為其分配這么多的存儲(chǔ)空間。顯然,這種存儲(chǔ)方式會(huì)造成磁盤空間的浪費(fèi)。這里筆者需要提醒的一點(diǎn)是,當(dāng)字符位數(shù)不足時(shí),系統(tǒng) 并不會(huì)采用空格來填充。相反,如果在保存CHAR值的時(shí)候,如果其后面有空值,系統(tǒng)還會(huì)自動(dòng)過濾其空格。而在進(jìn)行數(shù)據(jù)比較時(shí),系統(tǒng)又會(huì)將空格填充到字符串 的末尾。

顯然,VARCHAR與CHAR兩種字符型數(shù)據(jù)類型相比,最大的差異就是前者是可變長(zhǎng)度,而后者則是固定長(zhǎng)度。在存儲(chǔ)時(shí),前者會(huì)根據(jù)實(shí)際存儲(chǔ)的數(shù)據(jù) 來分配最終的存儲(chǔ)空間。而后者則不管實(shí)際存儲(chǔ)數(shù)據(jù)的長(zhǎng)度,都是根據(jù)CHAR規(guī)定的長(zhǎng)度來分配存儲(chǔ)空間。這是否意味著CHAR的數(shù)據(jù)類型劣于VARCHAR 呢?其實(shí)不然。否則的話,就沒有必要存在CHAR字符類型了。雖然VARCHAR數(shù)據(jù)類型可以節(jié)省存儲(chǔ)空間,提高數(shù)據(jù)處理的效率。但是其可變長(zhǎng)度帶來的一 些負(fù)面效應(yīng),有時(shí)候會(huì)抵消其帶來的優(yōu)勢(shì)。為此在某些情況下,還是需要使用Char數(shù)據(jù)類型。

二、項(xiàng)目建議

根據(jù)上面的分析,我們知道VARCHAR數(shù)據(jù)類型是一把雙刃劍,其在帶來性能提升的同時(shí),也可能會(huì)存在著一些額外的消耗。我們?cè)谠u(píng)估到底是使用VARCHAR數(shù)據(jù)類型還是采用CHAR數(shù)據(jù)類型時(shí),就需要進(jìn)行均衡。在實(shí)際項(xiàng)目中,我們會(huì)考量如下情況。

一是根據(jù)字符的長(zhǎng)度來判斷。如某個(gè)字段,像人的名字,其最長(zhǎng)的長(zhǎng)度也是有限的。如我們給其分配18個(gè)字符長(zhǎng)度即可。此時(shí)雖然每個(gè)人的名字長(zhǎng)度有可能 不同,但是即使為其分配了固定長(zhǎng)度的字符類型,即18個(gè)字符長(zhǎng)度,最后浪費(fèi)的空間也不是很大。而如果采用NVARCHAR數(shù)據(jù)類型時(shí),萬一以后需要改名, 而原先的存儲(chǔ)空間不足用來容納新的值,反而會(huì)造成一些額外的工作。在這種情況下,進(jìn)行均衡時(shí),會(huì)認(rèn)為采用CHAR固定長(zhǎng)度的數(shù)據(jù)類型更好。在實(shí)際項(xiàng)目中, 如果某個(gè)字段的字符長(zhǎng)度比較短此時(shí)一般是采用固定字符長(zhǎng)度。

二是考慮其長(zhǎng)度的是否相近。如果某個(gè)字段其長(zhǎng)度雖然比較長(zhǎng),但是其長(zhǎng)度總是近似的,如一般在90個(gè)到100個(gè)字符之間,甚至是相同的長(zhǎng)度。此時(shí)比較 適合采用CHAR字符類型。比較典型的應(yīng)用就是MD5哈希值。當(dāng)利用MD5哈希值來存儲(chǔ)用戶密碼時(shí),就非常使用采用CHAR字符類型。因?yàn)槠溟L(zhǎng)度是相同 的。另外,像用來存儲(chǔ)用戶的身份證號(hào)碼等等,一般也建議使用CHAR類型的數(shù)據(jù)。

另外請(qǐng)大家考慮一個(gè)問題,CHAR(1)與VARCHAR(1)兩這個(gè)定義,會(huì)有什么區(qū)別呢?雖然這兩個(gè)都只能夠用來保存單個(gè)的字符,但是 VARCHAR要比CHAR多占用一個(gè)存儲(chǔ)位置。這主要是因?yàn)槭褂肰ARCHAR數(shù)據(jù)類型時(shí),會(huì)多用1個(gè)字節(jié)用來存儲(chǔ)長(zhǎng)度信息。這個(gè)管理上的開銷CHAR 字符類型是沒有的。

三是從碎片角度進(jìn)行考慮。使用CHAR字符型時(shí),由于存儲(chǔ)空間都是一次性分配的。為此某個(gè)字段的內(nèi)容,其都是存儲(chǔ)在一起的。單從這個(gè)角度來講,其不 存在碎片的困擾。而可變長(zhǎng)度的字符數(shù)據(jù)類型,其存儲(chǔ)的長(zhǎng)度是可變的。當(dāng)其更改前后數(shù)據(jù)長(zhǎng)度不一致時(shí),就不可避免的會(huì)出現(xiàn)碎片的問題。故使用可變長(zhǎng)度的字符 型數(shù)據(jù)時(shí),數(shù)據(jù)庫管理員要時(shí)不時(shí)的對(duì)碎片進(jìn)行整理。如執(zhí)行數(shù)據(jù)庫導(dǎo)出導(dǎo)入作業(yè),來消除碎片。

四是即使使用Varchar數(shù)據(jù)類型,也不能夠太過于慷慨。這是什么意思呢?如現(xiàn)在用戶需要存儲(chǔ)一個(gè)地址信息。根據(jù)評(píng)估,只要使用100個(gè)字符就可 以了。但是有些數(shù)據(jù)庫管理員會(huì)認(rèn)為,反正Varchar數(shù)據(jù)類型是根據(jù)實(shí)際的需要來分配長(zhǎng)度的。還不如給其大一點(diǎn)的呢。為此他們可能會(huì)為這個(gè)字段一次性分 配200個(gè)字符的存儲(chǔ)空間。這VARCHAR(100)與VARCHAR(200)真的相同嗎?結(jié)果是否定的。雖然他們用來存儲(chǔ)90個(gè)字符的數(shù)據(jù),其存儲(chǔ) 空間相同。但是對(duì)于內(nèi)存的消耗是不同的。對(duì)于VARCHAR數(shù)據(jù)類型來說,硬盤上的存儲(chǔ)空間雖然都是根據(jù)實(shí)際字符長(zhǎng)度來分配存儲(chǔ)空間的,但是對(duì)于內(nèi)存來 說,則不是。其時(shí)使用固定大小的內(nèi)存塊來保存值。簡(jiǎn)單的說,就是使用字符類型中定義的長(zhǎng)度,即200個(gè)字符空間。顯然,這對(duì)于排序或者臨時(shí)表(這些內(nèi)容都 需要通過內(nèi)存來實(shí)現(xiàn))作業(yè)會(huì)產(chǎn)生比較大的不利影響。所以如果某些字段會(huì)涉及到文件排序或者基于磁盤的臨時(shí)表時(shí),分配VARCHAR數(shù)據(jù)類型時(shí)仍然不能夠太 過于慷慨。還是要評(píng)估實(shí)際需要的長(zhǎng)度,然后選擇一個(gè)最長(zhǎng)的字段來設(shè)置字符長(zhǎng)度。如果為了考慮冗余,可以留10%左右的字符長(zhǎng)度。千萬不能認(rèn)為其為根據(jù)實(shí)際 長(zhǎng)度來分配存儲(chǔ)空間,而隨意的分配長(zhǎng)度,或者說干脆使用最大的字符長(zhǎng)度。

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看腳本欄目
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲午夜av电影| 国产综合18久久久久久| 国内精品视频久久| 国产亚洲精品久久久久动| 国产欧美亚洲精品| **网站欧美大片在线观看| 精品成人免费| 国产一区视频在线观看免费| 国产欧美日韩精品专区| 国产精品羞羞答答| 在线观看欧美| 国产日韩欧美在线看| 国产日韩精品久久| 一区在线视频| 欧美在线观看一区二区| 欧美天天影院| 国产香蕉97碰碰久久人人| 国产真实乱偷精品视频免| 蜜桃久久av一区| 欧美视频中文一区二区三区在线观看 | 最新国产成人在线观看| 久久精品亚洲国产奇米99| 免费在线亚洲欧美| 欧美日韩免费观看一区| 中国成人黄色视屏| 久久久久久夜精品精品免费| 亚洲午夜日本在线观看| 国模一区二区三区| 91久久精品日日躁夜夜躁欧美| 99精品欧美一区| 久久xxxx精品视频| 欧美人妖在线观看| 狠狠色2019综合网| 亚洲一区欧美一区| 久久免费视频观看| 欧美日韩一区二区三区| 在线精品国精品国产尤物884a| 亚洲线精品一区二区三区八戒| 久久久精品一区二区三区| 欧美激情在线| 亚洲国产99精品国自产| 亚洲一区免费视频| 欧美日韩在线观看一区二区三区 | 欧美天堂在线观看| 亚洲国产天堂久久综合| 亚洲欧美不卡| 欧美日韩直播| 在线观看91精品国产入口| 午夜精品视频在线| 欧美日韩一区二区三区免费| 亚洲第一中文字幕在线观看| 先锋资源久久| 欧美福利一区二区| 在线成人小视频| 午夜精品在线看| 欧美精品在线免费观看| 国内成+人亚洲| 亚洲精品在线二区| 亚洲国产精品成人一区二区 | 久久精品国产96久久久香蕉| 欧美日韩在线综合| 一区二区冒白浆视频| 蜜桃av一区二区三区| 国产精品ⅴa在线观看h| 99国产精品国产精品久久| 欧美激情1区2区3区| 亚洲高清网站| 久久久久国产成人精品亚洲午夜| 国内精品伊人久久久久av一坑| 亚洲自拍偷拍网址| 国产精品成人在线| 亚洲精品日韩激情在线电影 | 欧美片第1页综合| 一区二区在线视频观看| 久久成人免费| 国内成人在线| 在线免费高清一区二区三区| 久久久精品视频成人| 一本久久综合| 国产精品对白刺激久久久| 亚洲视频精品| 欧美性大战久久久久| 亚洲日韩欧美视频一区| 久久综合九色九九| 一区二区三区高清在线| 国语自产精品视频在线看| 黄色精品一区二区| 亚洲欧美日韩电影| 亚洲欧美一区二区在线观看| 欧美一区二区三区在线视频| 欧美在线不卡| 香蕉久久夜色| 欧美精品久久久久久| 国产午夜亚洲精品不卡| 国产欧美日韩亚洲精品| 久久只有精品| 亚洲欧洲一区二区在线观看| 国产精品福利影院| 性欧美大战久久久久久久久| 亚洲国内精品在线| 欧美激情四色| 久久久久国产精品一区三寸| 在线精品视频在线观看高清| 欧美视频在线观看 亚洲欧| 亚洲婷婷综合色高清在线| 在线免费高清一区二区三区| 欧美国产丝袜视频| 久久精品日产第一区二区| 亚洲国内欧美| 亚洲无人区一区| 狠狠爱www人成狠狠爱综合网| 美女被久久久| 亚洲调教视频在线观看| 亚洲精品乱码久久久久久按摩观| 欧美新色视频| 欧美日韩国产不卡在线看| 亚洲欧美中文字幕| av成人毛片| 国产婷婷色一区二区三区在线| 欧美三级中文字幕在线观看| 久久er精品视频| 亚洲一区国产| 尤物在线精品| 国内精品久久久久影院优| 欧美日韩妖精视频| 亚洲日本久久| 国产视频一区欧美| 欧美诱惑福利视频| 亚洲欧美一区二区激情| 欧美资源在线| 欧美一区影院| 影院欧美亚洲| 一区二区三区精品视频| 欧美精品三级日韩久久| 免费在线成人av| 欧美日韩国产丝袜另类| 先锋影音国产精品| 樱桃国产成人精品视频| 男人的天堂亚洲| 亚洲黄色在线看| 欧美人与性动交α欧美精品济南到| 91久久国产综合久久91精品网站| 性亚洲最疯狂xxxx高清| 国产自产在线视频一区 | 久久只精品国产| 国自产拍偷拍福利精品免费一| 亚洲欧美日韩直播| 亚洲第一天堂无码专区| 国产欧美日韩精品a在线观看| 久久美女性网| 亚洲欧美视频在线观看视频| 亚洲国产精品va在线看黑人动漫| 欧美巨乳在线观看| 久久在线免费观看视频| 亚洲一区免费在线观看| 在线观看亚洲视频| 韩国三级在线一区| 一区二区三区欧美| 国产日韩精品在线观看| 国产精品中文字幕欧美| 欧美一级大片在线免费观看| 亚洲精品国产精品国产自| 伊人久久男人天堂| 亚洲永久在线| 亚洲在线观看视频网站| 欧美人在线观看| 久久伊人一区二区| 亚洲一区二区黄色| 久久成人免费电影| 亚洲国产成人精品女人久久久 | 亚洲精选一区二区| 黄色日韩网站| 国产九色精品成人porny| 国产精品v欧美精品v日韩精品| 国产精品青草综合久久久久99| 国产精品av免费在线观看| 欧美日韩1080p| 亚洲天堂网站在线观看视频| 在线观看日韩精品| 亚洲国产成人在线| 亚洲国产小视频| 亚洲欧洲综合另类| 国产情侣一区| 黄色成人在线网站| 亚洲精品美女久久久久| 亚洲黄一区二区三区| 亚洲精品1区| 亚洲精品资源| 这里只有精品丝袜| 亚洲自拍偷拍色片视频| 一区二区三区视频在线| 免费成人av资源网| 免费在线观看精品| 国产精品美女| 国产亚洲第一区| 99亚洲视频| 久久精品中文| 欧美日韩亚洲成人| 国产精品日韩在线播放| 国产午夜精品久久|