MySQL中TEXT與BLOB欄位型別的區別

2022-04-02 07:01:19 字數 1262 閱讀 3520

這篇文章主要介紹了mysql中text與blob欄位型別的區別,本文總結了6大區別,需要的朋友可以參考下

在mysql中有兩個字段型別容易讓人感覺混淆,那就是text與blob,特別是自己寫部落格程式的博主不知道改為自己的部落格正文本段選擇text還是blob型別。

下面給出幾點區別:

一、主要差別

text與blob的主要差別就是blob儲存二進位制資料,text儲存字元資料。目前幾乎所有部落格內容裡的都不是以二進位制儲存在資料庫的,而是把上傳到伺服器然後正文裡使用

標籤引用,這樣的部落格就可以使用text型別。而blob就可以把換算成二進位制儲存到資料庫中。

二、型別區別

blob有4種型別:tinyblob、blob、mediumblob和longblob。它們只是可容納值的最大長度不同。

text也有4種型別:tinytext、text、mediumtext和longtext。這些型別同blob型別一樣,有相同的最大長度和儲存需求。

三、字符集

blob列沒有字符集,並且排序和比較基於列值位元組的數值值。text列有乙個字符集,並且根據字符集的校對規則對值進行排序和比較

四、大小寫

在text或blob列的儲存或檢索過程中,不存在大小寫轉換,都一樣!

五、嚴格模式

執行在非嚴格模式時,如果你為blob或text列分配乙個超過該列型別的最大長度的值值,值被擷取以保證適合。如果截掉的字元不是空格,將會產生一條警告。使用嚴格sql模式,會產生錯誤,並且值將被拒絕而不是擷取並給出警告。

六、其它

當儲存或檢索blob和text列的值時不刪除尾部空格。

對於blob和text列的索引,必須指定索引字首的長度。

blob和text列不能有預設值。

當排序時只使用該列的前max_sort_length個位元組。max_sort_length的 預設值是1024。

當你想要使超過max_sort_length的位元組有意義,對含長值的blob或text列使用group by或order by的另一種方式是將列值轉換為固定長度的物件。標準方法是使用substring函式。

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

MySQL中TEXT與BLOB欄位型別的區別

一 型別。blob是乙個二進位製大物件,可以容納可變數量的資料。有4種 blob型別 tinyblob blob mediumblob和longblob。它們只是可容納值的最大長度不同。有4種text型別 tinytext text mediumtext和longtext。這些對應4種blob型別,...

MySQL中TEXT與BLOB欄位型別的區別

這篇文章主要介紹了mysql中text與blob欄位型別的區別,本文總結了6大區別,需要的朋友可以參考下 在mysql中有兩個字段型別容易讓人感覺混淆,那就是text與blob,特別是自己寫部落格程式的博主不知道改為自己的部落格正文本段選擇text還是blob型別。下面給出幾點區別 一 主要差別 t...

MySQL中TEXT與BLOB欄位型別的區別

在mysql中有兩個字段型別容易讓人感覺混淆,那就是text與blob,特別是自己寫部落格程式的博主不知道改為自己的部落格正文本段選擇text還是blob型別。下面給出幾點區別 一 主要差別 text與blob的主要差別就是blob儲存二進位制資料,text儲存字元資料。目前幾乎所有部落格內容裡的都...