mysql中 text和blob欄位型別比較區別

2021-06-09 15:11:56 字數 1026 閱讀 2637

1.blob是二進位製大物件,可以容納可變數數量的資料,其中blob分為4中型別:tinyblob,blob,mediumblob和longblob,他們容納的長度是不同的.

text同樣也分為四種型別:tinytext、text、mediumtext和longtext

2.blob被視為二進位制字串,text被視為非二進位制字串;

blob列沒有字符集,並且排序和比較基於列值位元組的數值值。

text列有乙個字符集,並且根據字符集的校對規則對值進行排序和比較。

在text或blob列的儲存或檢索過程中,不存在大小寫轉換,當未執行在嚴格模式時,如果你為blob或text列分配乙個超過該列型別的最大長度的值值,值被擷取以保證適合。如果截掉的字元不是空格,將會產生一條警告。使用嚴格sql模式,會產生錯誤,並且值將被拒絕而不是擷取並給出警告.在大多數方面,可以將blob列視為能夠足夠大的varbinary列。同樣,可以將text列視為varchar列。

3.blob和text在以下幾個方面不同於varbinary和varchar.

blob和text列不能有預設值.

當儲存或檢索blob和text列的值時不刪除尾部空格。(這與varbinary和varchar列相同).

對於blob和text列的索引,必須指定索引字首的長度。對於char和varchar,字首長度是可選的.

long和long varchar對應mediumtext資料型別。這是為了保證相容性。如果text列型別使用binary屬性,將為列分配列字符集的二元校對規則.

mysql連線程式/odbc將blob值定義為longvarbinary,將text值定義為longvarchar。由於blob和text值可能會非常長,使用它們時可能遇到一些約束.

blob或text物件的最大大小由其型別確定,但在客戶端和伺服器之間實際可以傳遞的最大值由可用記憶體數量和通訊快取區大小確定。你可以通過更改max_allowed_packet變數的值更改訊息快取區的大小,但必須同時修改伺服器和客戶端程式。例如,可以使用 mysql和mysqldump來更改客戶端的max_allowed_packet值.

Mysql中的text和blob型別

blob與text是為了儲存極大的字串而設計的資料型別,採用二進位制與字串方式儲存。一 主要差別 text與blob的主要差別就是blob儲存二進位制資料,text儲存字元資料。把上傳到伺服器然後正文裡使用標籤引用,這樣就可以使用text型別。而blob就可以把換算成二進位制儲存到資料庫中。二 選擇...

MySQL資料型別 BLOB和TEXT

blob binary large object 是用來儲存二進位製大資料型別的。根據儲存長度的不同,text型別和blob型別都可細分為4種型別 tinyblob 最大長度為255 2 8 1 位元組的blob列。tinytext 最大長度為255 2 8 1 字元的text列。blob m 最大...

Mysql的Text和Blob的比較

1 相同 2 相異 text blob 3 其他 varchar,blob 和text型別是變長型別,對於其儲存需求取決於列值的實際長度 在前面的 中用l表示 而不是取決於型別的最大可能尺寸。例如,乙個 varchar 10 列能儲存最大長度為10個字元的乙個字串,實際的儲存需要是字串的長度 加上1...