深入研究mysql中的varchar和limit(容易被忽略的知識)
為什么標題要起這個名字呢?commen sence指的是那些大家都應該知道的事情,但往往大家又會會略這些東西,或者對這些東西一知半解,今天我總結(jié)下自己在mysql中遇到的一些commen sense類型的問題。
1、varchar(5)可以存儲多少個漢字,多少個字母數(shù)字?
相信有好多人應該跟我一樣,對這個已經(jīng)很熟悉了,根據(jù)經(jīng)驗我們能很快的做出決定,比如說用varchar(200)去存儲url等等,但是,即使你用了很多次也很熟悉了,也有可能對上面的問題做出錯誤的回答。
這個問題我查了好多資料,有的人說是可以存儲5個字符,2.5個漢字(每個漢字占用兩個字節(jié)的話),有的人說這個要區(qū)分版本,5.0是個分界限,5.0之前是前面說的那樣,5.0之后是可以存儲5個“字”,不區(qū)分是數(shù)字、英文、漢字,果真是這樣嗎,我們來做個實驗:
CREATE TABLE `test` (
`name` varchar(5) NOT NULL DEFAULT '',
`info` char(5) NOT NULL DEFAULT '',
PRIMARY KEY (`name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

可以看出varchar(5)中的5代表的是5個“字”,而不是5個字節(jié)(bytes),當我們存儲長度超過制定長度的時候會將超過的部分“咔嚓”掉,我的mysql版本是5.6,字符集(charset)utf8和gbk是一樣的。

其他版本我電腦上沒有,去官方文檔看看有沒有什么說明,在官方文檔中查了半天終于發(fā)現(xiàn)了點區(qū)別:
下面這段來自http://dev.mysql.com/doc/refman/4.1/en/char.html,是對mysq4.1的說明:
The CHAR and VARCHAR types are declared with a length that indicates the maximum number of characters you want to store. For example, CHAR(30) can hold up to 30 characters. (Before MySQL 4.1, the length is interpreted as number of bytes.)
再看看其他版本的類似的說明:
The CHAR and VARCHAR types are declared with a length that indicates the maximum number of characters you want to store. For example, CHAR(30) can hold up to 30 characters.
顯而易見了,官方文檔說了,mysql版本小于4.1的時候存儲的時候符合說法:varchar(5)保存5個bytes,及5個英文數(shù)字或者2.5個漢字(假設一個漢字2個字節(jié));
mysql版本大于等于4.1的時候varchar(5)中的5不再是字節(jié)數(shù)了,應該理解為“字”這里的字的意思是一個漢字和一個英文或者數(shù)字“相同對待”
2、mysql中的limit,你真的會用嗎?
你在項目中怎么使用limit?limit num?還是limit num1,num2?還是其他的?要知道limit使用不同的形式性能差距很大的。
我自己測試了下,在一張innodb表中去使用limit,表中10000條數(shù)據(jù),四個字段,id(int)、time(int)、title(varchar)、body(mediumtext),大小大約170M左右,首先關掉查詢緩存,免得查詢緩存對查詢時間有影響,這里要注意time字段上面加了索引,
SET @@query_cache_type=ON;
SET GLOBAL query_cache_size=0;
打開Query profiler來查看語句執(zhí)行所花費的時間
set profiling=1;
接下來對下面幾個語句進行執(zhí)行
a、SELECT id,TIME,title FROM cnblogs WHERE TIME>=1315646940 ORDER BY TIME ASC LIMIT 2000,10
b、SELECT id,TIME,title FROM cnblogs WHERE TIME>=1315646940 ORDER BY TIME ASC LIMIT 10
c、 SELECT id,TIME,title FROM cnblogs ORDER BY TIME ASC LIMIT 3000,10
執(zhí)行順序a,b,c,a,b,c,c,a,a(這里需要注意下,雖然我關閉了緩存,但是上一次的查詢還是會緩存,這個可以從Query profiler中看出來,所以進行交叉執(zhí)行),使用下面的語句查看結(jié)果
SHOW profiles;

從上面的語句執(zhí)行時間分析可以看出,不考慮緩存因素,當使用limit的時候,"limit begin,num"這種形式比"limit num"這種形式效率低很多,因此,在使用的時候盡可能的使用第二種形式,比如說要循環(huán)獲取一個表里面的數(shù)據(jù),一次取出來內(nèi)從放不下,這個時候就要按照id(或者其他排序字段)進行l(wèi)imit了,我們就可以通過獲取上次的該字段臨界值作為下次取數(shù)據(jù)的最小值,使用limit num這種形式效率會高很多。
- MYSQL中 char 和 varchar的區(qū)別
- MySQL中字段類型char、varchar和text的區(qū)別
- mysql varchar類型求和實例操作
- 對比MySQL中int、char以及varchar的性能
- MySQL動態(tài)修改varchar長度的方法
- Mysql中varchar長度設置方法
- Mysql數(shù)據(jù)庫中把varchar類型轉(zhuǎn)化為int類型的方法
- MySQL數(shù)據(jù)庫中把int轉(zhuǎn)化varchar引發(fā)的慢查詢
- MySQL中把varchar類型轉(zhuǎn)為date類型方法詳解
- MySQL中VARCHAR與CHAR格式數(shù)據(jù)的區(qū)別
- 探究MySQL中varchar的定義長度
- MySQL CHAR和VARCHAR存儲、讀取時的差別
相關文章
CentOS7.5 安裝 Mysql8.0.19的教程圖文詳解
這篇文章主要介紹了CentOS7.5 安裝 Mysql8.0.19的教程,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
MySql 5.7.20安裝及data和my.ini文件的配置
本文通過圖文并茂的形式給大家介紹了MySql 5.7.20安裝及data和my.ini文件的配置方法,本文給大家介紹的非常詳細,需要的朋友參考下吧2017-11-11
Mysql慢查詢?nèi)罩疚募D(zhuǎn)Excel的方法
面對公司生產(chǎn)環(huán)境中慢SQL問題的排查工作,由于日志文件格式混亂,相關資料無法提供便捷的格式化處理工具,故而自主編寫一套Java讀取慢SQL日志轉(zhuǎn)為Excel的小工具,該工具可以有效提升排查工作的效率,方便快捷地解決問題2024-10-10
MySQL中實現(xiàn)多表查詢的操作方法(配sql+實操圖+案例鞏固 通俗易懂版)
本文主要講解了MySQL中的多表查詢,包括子查詢、笛卡爾積、自連接、多表查詢的實現(xiàn)方法以及多列子查詢等,通過實際例子和操作,幫助讀者理解如何合并多個表的數(shù)據(jù),并進行復雜的查詢操作,感興趣的朋友一起看看吧2025-03-03

