mysql怎麼儲存長字元-----MySQL text與blob欄位類型的不同之處

來源:互聯網
上載者:User

標籤:

欄位類型選text型 或blog區別見:

以下的文章主要介紹的是MySQL text與blob欄位類型的不同之處的比較,同時本文也有對MySQL text與blob欄位類型的實際應用的介紹,如果你對MySQL text與blob欄位類型相關的實際操作有興趣的話,你就可以對以下的文章點擊觀看了。

1.

blob是二進位大對象,可以容納可變數數量的資料,其中blob分為4中類型:TINYBLOB,BLOB,mediumblob和LongBlob,他們容納的長度是不同的.

Text同樣也分為四種類型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT

2.

blob被視為二進位字串,Text被視為非二進位字串;

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

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

在MySQL TEXT或BLOB列的儲存或檢索過程中,不存在大小寫轉換,當未運行在strict 模式時,如果你為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值.




mysql怎麼儲存長字元-----MySQL text與blob欄位類型的不同之處

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.