欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中l(wèi)ength()、char_length()的區(qū)別

 更新時(shí)間:2023年05月24日 09:38:13   作者:_陳哈哈  
在MySQL中l(wèi)ength(str)、char_length(str)都屬于判斷長(zhǎng)度的內(nèi)置函數(shù),本文主要介紹了MySQL中l(wèi)ength()、char_length()的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

在MySQL中l(wèi)ength(str)、char_length(str)都屬于判斷長(zhǎng)度的內(nèi)置函數(shù),根據(jù)其得到字符串的長(zhǎng)度。這兩個(gè)方法的區(qū)別是我們面向SQL編程時(shí)容易采坑的地方,本文帶你通俗易懂的了解這兩個(gè)知識(shí)點(diǎn)。

方法概述

char_length(str)

  • 計(jì)算單位:字符
  • 不管漢字還是數(shù)字或者是字母都算是一個(gè)字符

length(str)

  • 計(jì)算單位:字節(jié)
  • utf8編碼:一個(gè)漢字三個(gè)字節(jié),一個(gè)數(shù)字或字母一個(gè)字節(jié)。
  • gbk編碼:一個(gè)漢字兩個(gè)字節(jié),一個(gè)數(shù)字或字母一個(gè)字節(jié)。

用法示例

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

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

(2)查詢(xún)應(yīng)用表(app_info)中標(biāo)題(appName)最長(zhǎng)的10篇文章

length(str):

-- appName字節(jié)長(zhǎng)度前10;
SELECT appName FROM app_info ORDER BY LENGTH(appName) LIMIT 10;

char_length(str):

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

(3)查出用戶(hù)名長(zhǎng)度小于6個(gè)字符的用戶(hù)列表

-- appName字節(jié)長(zhǎng)度小于5的;
SELECT appName FROM app_info WHERE LENGTH(appName) < 5;

-- appName字符長(zhǎng)度小于5的;
SELECT appName FROM app_info WHERE CHAR_LENGTH(appName) < 5;

(4)通過(guò)length()<>char_length()可以用來(lái)檢驗(yàn)是否含有中文字符

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

擴(kuò)展

MySQL5.0.3版本之后varchar類(lèi)型大小的計(jì)算方式有所變化,從最早的按字節(jié)算大小varchar(length)改成了varchar(char_length)。

1)MySQL 5.0.3 之前:

  • 數(shù)據(jù)類(lèi)型大?。?--255字節(jié)
  • 詳解:varchar(20)中的20表示字節(jié)數(shù),如果存放utf-8編碼的話(huà)只能放6個(gè)漢字。varchar(n),這里的n表示字節(jié)數(shù)。

2)MySQL 5.0.3之后:

  • 數(shù)據(jù)類(lèi)型大?。?--65535字節(jié),但最多占65532字節(jié)(其中需要用兩個(gè)字節(jié)存放長(zhǎng)度,小于255字節(jié)用1個(gè)字節(jié)存放長(zhǎng)度)
  • 詳解:varchar(20)表示字符數(shù),不管什么編碼,不管是英文還是中文都可以存放20個(gè)。

到此這篇關(guān)于MySQL中l(wèi)ength()、char_length()的區(qū)別的文章就介紹到這了,更多相關(guān)MySQL length() char_length()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論