日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MySQL字符串各列類型的區(qū)別

MySQL字符串的列類型很多,下面為您整理了MySQL字符串各列類型的區(qū)別,希望可以讓您對MySQL字符串類型有更深入的認識。

創(chuàng)新互聯(lián)建站從2013年開始,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目成都網(wǎng)站建設、網(wǎng)站建設網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元開平做網(wǎng)站,已為上家服務,為開平各地企業(yè)和個人服務,聯(lián)系電話:028-86922220

1.

首先CHAR, VARCHAR, TEXT和BINARY, VARBINARY, BLOB的區(qū)別:

HAR, VARCHAR, TEXT稱為非二進制字符串;

BINARY, VARBINARY, BLOB稱為二進制字符串;

二進制字符串和非二進制字符串的區(qū)別是:
二進制字符串包含的是字節(jié)字符串,非二進制字符串包含的是字符字符串;

后者可以定義字符集,前者不可以;

而且排序和比較前者基于列值字節(jié)的數(shù)值值,后者則根據(jù)字母順序進行排序或比較;

BINARY類似與CHAR類型,但是保存二進制字符串而不是非二進制字符串;

VARBINARY類似與VARCHAR類型,但是保存二進制字符串而不是非二進制字符串;
同樣類似的BLOB對應TEXT類型(相應的有TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB和TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT)

2.

CHAR和VARCHAR相同之處:

都可以定義字符串的長度,如CHAR(M), VARCHAR(M);

不同之處:

CHAR(M)定義的列的長度為固定的,M取值可以為0~255之間,當保存CHAR值時,在它們的右邊填充空格以達到指定的長度。當檢索到CHAR值時,尾部的空格被刪除掉。在存儲或檢索過程中不進行大小寫轉(zhuǎn)換。

VARCHAR(M)定義的列的長度為可變長字符串,M取值可以為0~65535之間,(VARCHAR的***有效長度由***行大小和使用的字符集確定。整體***長度是65,532字節(jié))。VARCHAR值保存時只保存需要的字符數(shù),另加一個字節(jié)來記錄長度(如果列聲明的長度超過255,則使用兩個字節(jié))。VARCHAR值保存時不進行填充。當值保存和檢索時尾部的空格仍保留,符合標準SQL。

注意:MySQL 數(shù)據(jù)庫的varchar類型在4.1以下的版本中的***長度限制為255,其數(shù)據(jù)范圍可以是0~255或1~255(根據(jù)不同版本數(shù)據(jù)庫來定)。在 MySQL5.0以上的版本中,varchar數(shù)據(jù)類型的長度支持到了65535,也就是說可以存放65532個字節(jié)的數(shù)據(jù),起始位和結(jié)束位占去了3個字 節(jié),也就是說,在4.1或以下版本中需要使用固定的TEXT或BLOB格式存放的數(shù)據(jù)可以使用可變長的varchar來存放,這樣就能有效的減少數(shù)據(jù)庫文 件的大小。

CHAR和VARCHAR***的不同就是一個是固定長度,一個是可變長度。由于是可變長度,因此實際存儲的時候是實際字符串再加上一個記錄字符串長度的字節(jié)(如果超過255則需要兩個字節(jié))

如果分配給CHAR或VARCHAR列的值超過列的***長度,則對值進行裁剪以使其適合。如果被裁掉的字符不是空格,則會產(chǎn)生一條警告。如果裁剪非空格字符,則會造成錯誤(而不是警告)并通過使用嚴格SQL模式禁用值的插入。

由于BINARY和VARBINARY分別與CHAR和VARCHAR對應,因此兩者的區(qū)別也和CHAR和VARCHAR的區(qū)別類似。

但是注意VARBINARY定義的M值范圍為0<=M<=255

3. VARCHAR和TEXT類型的區(qū)別:

TEXT類型不需要指定M值,其他方面與VARCHAR都類似:比如存儲的是可變長度,即不夠的部分不需要右邊空格填充;等等。

TEXT與VARCHAR類似,實際需要保存字符串本身外加兩個字節(jié)保存字符串的實際長度。

看下表容易理解上面講述的區(qū)別:

字符串類型的存儲需求(M為***長度,L實際存儲字符串的長度)


文章標題:MySQL字符串各列類型的區(qū)別
分享網(wǎng)址:http://www.5511xx.com/article/cohdpid.html