MySQL中length()、char_length()的區別和用法

在MySQL中length(str)、char_length(str)都屬於判斷長度的內置函數,根據其得到字符串的長度。這兩個方法的區別是我們面向SQL編程時容易採坑的地方,本文帶你通俗易懂的瞭解這兩個知識點。

目錄

 

方法概述:

用法示例:

擴展:


方法概述:

  • char_length(str)
  1. 計算單位:字符
  2. 不管漢字還是數字或者是字母都算是一個字符
  • length(str)
  1. 計算單位:字節
  2. utf8編碼:一個漢字三個字節,一個數字或字母一個字節。
  3. gbk編碼:一個漢字兩個字節,一個數字或字母一個字節。

 

用法示例:

(1)查看某字符串的長度(比如本站網址)

SELECT LENGTH('www.baidu.com');
-- 返回值:13

(2)查詢應用表(app_info)中標題(appName)最長的10篇文章

length(str):

-- appName字節長度前10;
SELECT appName FROM app_info ORDER BY LENGTH(appName) LIMIT 10;

char_length(str):

-- appName字符長度前10;
SELECT appName FROM app_info ORDER BY CHAR_LENGTH(appName) LIMIT 10;


(3)查出用戶名長度小於6個字符的用戶列表

-- appName字節長度小於5的;
SELECT appName FROM app_info WHERE LENGTH(appName) < 5;

-- appName字符長度小於5的;
SELECT appName FROM app_info WHERE CHAR_LENGTH(appName) < 5;

(4)通過length()<>char_length()可以用來檢驗是否含有中文字符

-- 檢驗是否含有中文字符
SELECT
	NAME,
	LENGTH(NAME) AS NAME_length,
	CHAR_LENGTH(NAME) AS NAME_char_length
FROM
	student
WHERE
	LENGTH(NAME) <> CHAR_LENGTH(NAME);


擴展:

MySQL5.0.3版本之後varchar類型大小的計算方式有所變化,從最早的按字節算大小varchar(length)改成了varchar(char_length)。

1)MySQL 5.0.3 之前:

  • 數據類型大小:0--255字節
  • 詳解:varchar(20)中的20表示字節數,如果存放utf-8編碼的話只能放6個漢字。varchar(n),這裏的n表示字節數。

2)MySQL 5.0.3之後:

  • 數據類型大小:0--65535字節,但最多佔65532字節(其中需要用兩個字節存放長度,小於255字節用1個字節存放長度)
  • 詳解:varchar(20)表示字符數,不管什麼編碼,不管是英文還是中文都可以存放200個。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章