字段類型選text型 或blog 區別見:
如下的文章主要介紹的是MySQL text與blob字段類型的不一樣之處的比較,同時本文也有對MySQL text與blob字段類型的實際應用的介紹,若是你對MySQL text與blob字段類型相關的實際操做有興趣的話,你就能夠對如下的文章點擊觀看了。緩存
1.服務器
blob是二進制大對象,能夠容納可變量數量的數據,其中blob分爲4中類型:TINYBLOB,BLOB,mediumblob和LongBlob,他們容納的長度是不一樣的.code
Text一樣也分爲四種類型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXThtm
2.對象
blob被視爲二進制字符串,Text被視爲非二進制字符串;blog
blob列沒有字符集,而且排序和比較基於列值字節的數值值。排序
TEXT列有一個字符集,而且根據字符集的校對規則對值進行排序和比較。索引
在MySQL 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,將MySQL TEXT值定義爲LONGVARCHAR。因爲BLOB和TEXT值可能會很是長,使用它們時可能遇到一些約束.
BLOB或TEXT對象的最大大小由其類型肯定,但在客戶端和服務器之間實際能夠傳遞的最大值由可用內存數量和通訊緩存區大小肯定。你能夠經過更改 max_allowed_packet變量的值更改消息緩存區的大小,但必須同時修改服務器和客戶端程序。例如,能夠使用 MySQL和MySQLdump來更改客戶端的max_allowed_packet值.