VARCHAR 和 CHAR 是兩種主要的字符串類型,用于存儲字符。不幸的是,由于實(shí)現(xiàn)的方式依賴于存儲引擎,因此很難解釋這些字符串在磁盤和內(nèi)存中如何存儲,除了除了常用的 InnoDB 和 MyISAM 外,假設(shè)你使用了其他存儲引擎,應(yīng)當(dāng)仔細(xì)閱讀存儲引擎的文檔。

創(chuàng)新互聯(lián)公司成都企業(yè)網(wǎng)站建設(shè)服務(wù),提供做網(wǎng)站、成都做網(wǎng)站網(wǎng)站開發(fā),網(wǎng)站定制,建網(wǎng)站,網(wǎng)站搭建,網(wǎng)站設(shè)計(jì),成都響應(yīng)式網(wǎng)站建設(shè)公司,網(wǎng)頁設(shè)計(jì)師打造企業(yè)風(fēng)格網(wǎng)站,提供周到的售前咨詢和貼心的售后服務(wù)。歡迎咨詢做網(wǎng)站需要多少錢:18982081108
VARCHAR 存儲可變長度的字符串,也是最常用的字符數(shù)據(jù)類型。相比固定長度的類型,VARCHAR 所需的存儲空間更小,它會盡可能少地使用存儲空間(例如,短的字符串占據(jù)的空間)。對于 MyISAM 來說,如果創(chuàng)建表的時候指定了 ROW_FORMAT=FIXED 的話,那么會使用固定的空間存儲字段而導(dǎo)致空間浪費(fèi)。VARCHAR 使用1-2個額外的字節(jié)存儲字符串的長度:當(dāng)最大長度低于255字節(jié)的時候使用1個字節(jié),如果更多的話就使用2個字節(jié)。因此,拉丁字符集的 VARCHAR(10)會使用11個字節(jié)的存儲空間,而 VARCHAR(1000)則會使用1002個字節(jié)的存儲空間。
VARCHAR 由于能夠節(jié)省空間,因此可以改善性能。但是,由于長度可變,當(dāng)更新數(shù)據(jù)表的時候數(shù)據(jù)行的存儲空間會變化,這一定程度上會帶來額外的開銷。如果數(shù)據(jù)行的長度導(dǎo)致原有的存儲位置無法存放,那么不同的存儲引擎會做不同的處理。例如 MyISAM 可能產(chǎn)生數(shù)據(jù)行的碎片,而 InnoDB 需要進(jìn)行磁盤分頁來存放更新后的數(shù)據(jù)行。
通常,如果最大的列長度遠(yuǎn)遠(yuǎn)高于平均長度的話(例如可選的備注字段),使用 VARCHAR 是劃算的,同時如果更新的頻次很低,那么碎片化也不會是一個問題。需要注意的是,如果使用的是 UTF-8字符集,則實(shí)際存儲的字節(jié)長度是根據(jù)字符定的。對于中文,推薦的存儲字符集是 utf8mb4。
CHAR 類型的長度是固定的,MySQL 會對每個字段分配足夠的存儲空間。 存儲CHAR 類型值的時候,MySQL 會移除后面多出來的空字符 。值是使用空字符進(jìn)行對齊以便進(jìn)行比較。對于短的字符串來說,使用 CHAR 更有優(yōu)勢,而如果所有的值的長度幾乎一致的話,就可以使用 CHAR。例如存儲用戶密碼的MD5值時使用 CHAR 就更合適,這是因?yàn)?MD5的長度總是固定的。同時,對于字段值經(jīng)常改變的數(shù)據(jù)類型來說,CHAR 相比 VARCHAR 也更有優(yōu)勢,因?yàn)?CHAR 不會產(chǎn)生碎片。對于很短的數(shù)據(jù)列,使用 CHAR 比 VARCHAR更高效,例如使用CHAR(1)存儲邏輯值的 Y 和 N,這種情況下只需要1個字節(jié),而 VARCHAR 需要2個字節(jié)。
對于移除空字符這個特性會感覺奇怪,我們舉個例子:
按上面的結(jié)果插入數(shù)據(jù)表后,string2中的前置空格不會移除,但使用 CHAR 類型存儲時,string3尾隨空格會被移除,使用 SQL 查詢結(jié)果來檢驗(yàn)一下:
得出來的結(jié)果如下,可以看到 CHAR 類型的 string3后面的空格被移除了,而 VARCHAR類型的沒有。這種情況大多數(shù)時候不會有什么問題,實(shí)際在應(yīng)用中也經(jīng)常會使用 trim 函數(shù)移除兩端的空字符,但是如果確實(shí)需要存儲空格的時候,那就需要注意不要選擇使用 CHAR 類型:
數(shù)據(jù)如何存儲是由存儲引擎決定的,而且存儲引擎處理固定長度和可變長度的數(shù)據(jù)的方式并不相同。Memory 引擎使用固定大小的行,因此它需要分配最大可能的存儲空間——即便數(shù)據(jù)長度是可變的。但是,對于字符串的對齊和空字符截?cái)嗍怯?MySQL 服務(wù)端完成的,因此所有存儲引擎都是一樣的。
與 CHAR 和 VARCHAR 相似的是 BINARY和 VARBINARY,用于存儲二進(jìn)制字節(jié)字符,BINARY 的對齊使用字符0的字節(jié)值來對齊,并且再獲取值的時候不會截?cái)唷H绻枰褂米址淖止?jié)值而不是字符的話,使用 BINARY 會更高效,這是因?yàn)楸容^時,一方面不需要考慮大小寫,另一方面是MySQL一次只比較一個字節(jié)。
云數(shù)據(jù)庫MySQL是一款開箱即用、性能卓越、安全可靠的在線數(shù)據(jù)庫服務(wù),實(shí)例秒級開通、性能百萬QPS、安全企業(yè)級標(biāo)準(zhǔn)。產(chǎn)品支持MySQL數(shù)據(jù)庫主流版本引擎,可以提供異地高可用、彈性伸縮、智能運(yùn)維等云原生高級特性,滿足全行業(yè)數(shù)據(jù)庫的需求。目前,主要有通用型、通用入門型、獨(dú)享型、專家服務(wù)等類型可以選擇。通用型SSD云盤、通用型本地SSD盤、獨(dú)享型SSD云盤等都是成本最低的云數(shù)據(jù)庫類型。云數(shù)據(jù)庫MySQL也參加了此次云領(lǐng)校園的活動(),甚至可以免費(fèi)試用三個月的時間。
對于游戲幣等代幣,一般存儲為int類型是可行的。問題在于越界,int類型長度為11位。
在存儲人民幣相關(guān)的金額的時候,則只能存儲到9長度的人民幣,也就是說,最大只能存儲999999999,不到10億的數(shù)值,如果業(yè)務(wù)增長很快的話,就會給自己留下隱患。
Decimal:Decimal為專門為財(cái)務(wù)相關(guān)問題設(shè)計(jì)的數(shù)據(jù)類型。
DECIMAL從MySQL5.1引入,列的聲明語法是DECIMAL(M,D)。在MySQL5.1中,參量的取值范圍如下:M是數(shù)字的最大數(shù)(精度)。其范圍為1~65(在較舊的MySQL版本中,允許的范圍是1~254),M的默認(rèn)值是10。
D是小數(shù)點(diǎn)右側(cè)數(shù)字的數(shù)目(標(biāo)度)。其范圍是0~30,但不得超過M。說明:float占4個字節(jié),double占8個字節(jié),decimail(M,D)占M+2個字節(jié)。
如DECIMAL(5,2)的最大值為9999.99,因?yàn)橛?個字節(jié)可用。能夠解決數(shù)據(jù)的范圍和精度的問題。
擴(kuò)展資料
MySQL數(shù)據(jù)類型DECIMAL用法:
MySQL?DECIMAL數(shù)據(jù)類型用于在數(shù)據(jù)庫中存儲精確的數(shù)值。我們經(jīng)常將DECIMAL數(shù)據(jù)類型用于保留準(zhǔn)確精確度的列,例如會計(jì)系統(tǒng)中的貨幣數(shù)據(jù)。
要定義數(shù)據(jù)類型為DECIMAL的列,請使用以下語法:column_name??DECIMAL(P,D);
在上面的語法中:
P是表示有效數(shù)字?jǐn)?shù)的精度。?P范圍為1?65。
D是表示小數(shù)點(diǎn)后的位數(shù)。?D的范圍是0~30。MySQL要求D小于或等于(=)P。
DECIMAL(P,D)表示列可以存儲D位小數(shù)的P位數(shù)。十進(jìn)制列的實(shí)際范圍取決于精度和刻度。
與INT數(shù)據(jù)類型一樣,DECIMAL類型也具有UNSIGNED和ZEROFILL屬性。如果使用UNSIGNED屬性,則DECIMALUNSIGNED的列將不接受負(fù)值。
如果使用ZEROFILL,MySQL將把顯示值填充到0以顯示由列定義指定的寬度。另外,如果我們對DECIMAL列使用ZEROFILL,MySQL將自動將UNSIGNED屬性添加到列。
文章題目:mysql數(shù)據(jù)類怎么選 數(shù)據(jù)庫的數(shù)據(jù)類型怎么選
文章轉(zhuǎn)載:http://chinadenli.net/article16/higjgg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、微信公眾號、建站公司、電子商務(wù)、網(wǎng)站排名、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)