亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

mysql優(yōu)化 - mysql 一張表如果不能確保字段列長度一致,是不是就不需要用到char。

瀏覽:150日期:2022-06-12 11:31:09

問題描述

在一個數(shù)據(jù)表里,如果每一個數(shù)據(jù)列的長度都是固定的,那么每一個數(shù)據(jù)行的長度也將是固定的,只要數(shù)據(jù)表里有一個數(shù)據(jù)列的長度的可變的,那么各數(shù)據(jù)行的長度都是可變的,如果某個數(shù)據(jù)表里的數(shù)據(jù)行的長度是可變的,那么,為了節(jié)約存儲空間,MySQL會把這個數(shù)據(jù)表里的固定長度類型的數(shù)據(jù)列轉(zhuǎn)換為相應(yīng)的可變長度類型,長度小于4個字符的char數(shù)據(jù)列不會被轉(zhuǎn)換為varchar類型

如果一張表有一個字段是varchar,那么這張表建立char字段還有意義嗎?

問題解答

回答1:

第一你要理解清楚char和varchar的區(qū)別。1.CHAR的長度是固定的,而VARCHAR2的長度是可以變化的, 比如,存儲字符串“abc',對于CHAR (10),表示你存儲的字符將占10個字節(jié)(包括7個空字符),而同樣的VARCHAR2 (10)則只占用3個字節(jié)的長度,10只是最大值,當(dāng)你存儲的字符小于10時,按實際長度存儲。 2.CHAR的效率比VARCHAR2的效率稍高。 3.目前VARCHAR是VARCHAR2的同義詞。工業(yè)標(biāo)準(zhǔn)的VARCHAR類型可以存儲空字符串,但是oracle不這樣做,盡管它保留以后這樣做的權(quán)利。Oracle自己開發(fā)了一個數(shù)據(jù)類型VARCHAR2,這個類型不是一個標(biāo)準(zhǔn)的VARCHAR,它將在數(shù)據(jù)庫中varchar列可以存儲空字符串的特性改為存儲NULL值。如果你想有向后兼容的能力,Oracle建議使用VARCHAR2而不是VARCHAR。 何時該用CHAR,何時該用varchar2? CHAR與VARCHAR2是一對矛盾的統(tǒng)一體,兩者是互補(bǔ)的關(guān)系. VARCHAR2比CHAR節(jié)省空間,在效率上比CHAR會稍微差一些,即要想獲得效率,就必須犧牲一定的空間,這也就是我們在數(shù)據(jù)庫設(shè)計上常說的‘以空間換效率’。 VARCHAR2雖然比CHAR節(jié)省空間,但是如果一個VARCHAR2列經(jīng)常被修改,而且每次被修改的數(shù)據(jù)的長度不同,這會引起‘行遷移’(Row Migration)現(xiàn)象,而這造成多余的I/O,是數(shù)據(jù)庫設(shè)計和調(diào)整中要盡力避免的,在這種情況下用CHAR代替VARCHAR2會更好一些。這個答案是引用百度答案https://zhidao.baidu.com/ques...我覺得回答好詳盡

主站蜘蛛池模板: 青青国产成人精品视频 | 伊人丁香婷婷综合一区二区 | 欧美精品国产第一区二区 | 理论亚洲区美一区二区三区 | 国产精品区牛牛影院 | 中文国产成人精品少久久 | 国产精品亚洲综合第一区 | 国产精品视频无圣光一区 | 欧美在线乱妇一级毛片 | 手机看片久久国产免费不卡 | 国产精品揄拍100视频 | 亚洲福利秒拍一区二区 | 羞羞答答免费人成黄页在线观看国产 | 国产精品美女自在线观看免费 | 亚洲综合日韩 | 欧美久久伊人 | 久久成人18| 国产白嫩美女在线观看 | 香蕉国产 | 在线高清视频18jin观看 | 国产日韩精品视频一区二区三区 | 精品一区二区日本高清 | 黄色大片在线免费观看 | 黄色网址免费大全 | 91久久青草精品38国产 | 久久久久久久国产精品 | 在线观看免费网址大全 | 欧美一级毛片做受 | 国产高清免费视频 | 四虎永久免费地址ww 41.6 | a级国产片免费观看 | 免费无遮挡十八女禁污污网站 | www永久免费视频 | 国产福利写真视频在线观看 | 11111日本网站 | 免费可在线观看黄的视频 | 国产情侣自拍偷拍 | 99久久免费精品高清特色大片 | 成人在线播放av | 国产福利片在线 易阳 | 国产96福利视频在线观看 |