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

您的位置:首頁技術文章
文章詳情頁

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

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

問題描述

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

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

問題解答

回答1:

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

主站蜘蛛池模板: 国产成人精品免费视频网页大全 | 亚洲精品麻豆一区二区 | 草草视频在线播放 | 毛片一级在线观看 | 国产精品成人扳一级aa毛片 | 91无套极品外围在线播放 | 国产精品免费福利 | 久久久久女人精品毛片九一 | 曰本一级毛片免费播放 | 国产视频高清在线 | 久久久久免费精品视频 | 高清国产天干天干天干不卡顿 | 香蕉手机网| 亚洲 欧美 激情 另类 自拍 | 欧美曰b| 国产亚洲欧美另类第一页 | 国产精品天天看特色大片不卡 | 国内视频一区二区 | 在线视频97 | 亚洲午夜视频 | 国产91po在线观看免费观看 | 伊人色综合久久天天网蜜月 | 日本毛片在线观看 | 99久久国产综合精品网成人影院 | 成人免费视频一区二区 | 亚洲国产精品67194成人 | 欧美黄色片免费 | 亚洲免费在线看 | 欧美一区二区高清 | 亚洲精品va| 国产精品高清一区二区三区 | 亚洲第一页在线视频 | 麻豆精品视频 在线视频 | 激情亚洲婷婷 | 草草影院国产 | 新26uuu在线亚洲欧美 | 国产乱人伦精品一区二区 | 亚洲加勒比久久88色综合一区 | 国产99精品一区二区三区免费 | 久久本道综合色狠狠五月 | 在线观看国产精成人品 |