日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

MySQL中的char和varchar类型

發布時間:2025/4/5 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL中的char和varchar类型 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

    • 1 MySQL中的char和varchar類型

1 MySQL中的char和varchar類型

CHAR類型和VARCHAR類型都在創建表時指定了最大長度,其基本形式如下:

  • 字符串類型(M)

其中,“字符串類型”參數指定了數據類型為CHAR類型還是VARCHAR類型;M參數指定了該字符串的最大長度為M。

  • 例如,CHAR(4)就是數據類型為CHAR類型,其最大長度為4。注意:這里的長度是指字符的長度,而不是字節長度!默認編碼格式為utf-8格式,插入漢字時為3個字節。

CHAR類型的長度是固定的,在創建表時就指定了。其長度可以是0~255的任意值。

  • 例如,CHAR(100)就是指定CHAR類型的長度為100。CHAR 存儲值時,它們會用空格右填充到指定的長度。

VARCHAR類型的長度是可變的,在創建表時指定了最大長度。定義時,其最大值可以取0~65535之間的任意值。指定VARCHAR類型的最大值以后,其長度可以在0到最大長度之間。

  • 例如,VARCHAR(100)的最大長度是100,但是不是每條記錄都要占用100個字節,而是在這個最大值范圍內使用多少就分配多少。VARCHAR類型實際占用的空間為字符串的實際長度加1或2,這樣即可有效節約系統的空間。
mysql> use test; #選擇數據庫test mysql> create table char_example(e_char char(5), v_char varchar(5)); #創建數據庫表 mysql> insert into char_example values('12345','12345'); #正常插入數據 mysql> insert into char_example values('1 2 ','1 2 '); #char類型會屏蔽后面隱藏的空格,varchar 不會 mysql>select concat('(',e_char, ')'), concat('(',v_char, ')') from char_example ; #讓char 后面屏蔽的空格原型畢露

實戰建議:

  • char一定會使用指定的空間,varchar是根據數據來定空間。
  • char的數據查詢效率比varchar高:varchar是需要通過后面的記錄數來計算。
  • 如果確定數據一定是占指定長度,那么使用char類型。
  • 如果不確定數據到底有多少,那么使用varchar類型。
  • 如果數據長度超過255個字符而在65535之內,直接使用varchar。
  • 如果字符串尾部要保留空格,必須選擇varchar。

  • 參考資料:

  • C/C++從入門到精通-高級程序員之路【奇牛學院】
  • 《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

    總結

    以上是生活随笔為你收集整理的MySQL中的char和varchar类型的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。