1、varchar(5)可以存储多少个汉字,多少个字母数字?
相信有好多人应该跟我一样,对这个已经很熟悉了,根据经验我们能很快的做出决定,比如说用varchar(200)去存储url等等,但是,即使你用了很多次也很熟悉了,也有可能对上面的问题做出错误的回答。
这个问题我查了好多资料,有的人说是可以存储5个字符,2.5个汉字(每个汉字占用两个字节的话),有的人说这个要区分版本,5.0是个分界限,5.0之前是前面说的那样,5.0之后是可以存储5个“字”,不区分是数字、英文、汉字,果真是这样吗,我们来做个实验:
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个字节(bytes),当我们存储长度超过制定长度的时候会将超过的部分“咔嚓”掉,我的mysql版本是5.6,字符集(charset)utf8和gbk是一样的。
其他版本我电脑上没有,去官方文档看看有没有什么说明,在官方文档中查了半天终于发现了点区别:
下面这段来自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个英文数字或者2.5个汉字(假设一个汉字2个字节);
mysql版本大于等于4.1的时候varchar(5)中的5不再是字节数了,应该理解为“字”这里的字的意思是一个汉字和一个英文或者数字“相同对待”
2、mysql中的limit,你真的会用吗?
你在项目中怎么使用limit?limit num?还是limit num1,num2?还是其他的?要知道limit使用不同的形式性能差距很大的。
我自己测试了下,在一张innodb表中去使用limit,表中10000条数据,四个字段,id(int)、time(int)、title(varchar)、body(mediumtext),大小大约170M左右,首先关掉查询缓存,免得查询缓存对查询时间有影响,这里要注意time字段上面加了索引,
SET @@query_cache_type=ON;
SET GLOBAL query_cache_size=0;
打开Query profiler来查看语句执行所花费的时间
set profiling=1;
接下来对下面几个语句进行执行
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
执行顺序a,b,c,a,b,c,c,a,a(这里需要注意下,虽然我关闭了缓存,但是上一次的查询还是会缓存,这个可以从Query profiler中看出来,所以进行交叉执行),使用下面的语句查看结果
SHOW profiles;
从上面的语句执行时间分析可以看出,不考虑缓存因素,当使用limit的时候,"limit begin,num"这种形式比"limit num"这种形式效率低很多,因此,在使用的时候尽可能的使用第二种形式,比如说要循环获取一个表里面的数据,一次取出来内从放不下,这个时候就要按照id(或者其他排序字段)进行limit了,我们就可以通过获取上次的该字段临界值作为下次取数据的最小值,使用limit num这种形式效率会高很多。
相关推荐
以下是对这两个知识点的详细解析。 首先,VARCHAR是一种变长字符串类型,它在MySQL中用于存储可变长度的数据,如文本或字符串。在定义VARCHAR时,我们会指定一个长度,例如VARCHAR(5),这表示该字段最多可以存储5个...
在部署MySQL时,还需要注意数据处理的两个重要概念:联机事务处理(OLTP)和联机分析处理(OLAP)。OLTP主要用于处理日常事务,例如银行交易,强调的是事务处理的实时性和快速响应;而OLAP则更侧重于支持复杂的分析操作...
SqlBalance4MySQL_setup 是一款专为MySQL数据库设计的对比工具,旨在帮助用户高效地比较和分析两个数据库的结构差异。这款软件提供了详细且直观的对比报告,能够清晰地标识出不同之处,使得数据库管理员和开发人员...
### MySQL基础知识及操作指南 #### 一、MySQL配置与启动 **配置文件**: 在MySQL的配置过程中,`my.ini` 文件扮演着至关重要的角色。它主要用于定义MySQL服务器的各种配置选项。 - **`[mysqld]`**: 这是服务端配置...
在IT行业中,PHP和MySQL是两个非常重要的技术,它们在构建动态、数据驱动的网站方面发挥着关键作用。本文将深入探讨"phpmysql网站设计"的相关知识点,旨在为课程设计和自我学习提供详尽的指导。 PHP(Hypertext ...
3.6.7. 根据两个键搜索 3.6.8. 根据天计算访问量 3.6.9. 使用AUTO_INCREMENT 3.7. 孪生项目的查询 3.7.1. 查找所有未分发的孪生项 3.7.2. 显示孪生对状态的表 3.8. 与Apache一起使用MySQL 4. MySQL程序概述 4.1. ...
- **内连接(INNER JOIN)**:只返回两个表中满足连接条件的记录,忽略不匹配的记录。 - **左外连接(LEFT JOIN)**:返回左表的所有记录,即使在右表中没有匹配项,右表中未找到对应项的数据以NULL填充。 - **右...
3.6.7. 根据两个键搜索 3.6.8. 根据天计算访问量 3.6.9. 使用AUTO_INCREMENT 3.7. 孪生项目的查询 3.7.1. 查找所有未分发的孪生项 3.7.2. 显示孪生对状态的表 3.8. 与Apache一起使用MySQL 4. MySQL程序概述 4.1. ...
在数据库管理领域,SQL(Structured Query Language)是用于管理和处理...在实际操作中,应充分理解两个系统的差异,并根据业务需求制定详尽的转换计划,确保转换过程的顺利进行,同时保持数据库系统的稳定性和效率。
Mysql 执行脚本步骤详解 ...Mysql 执行脚本步骤是一个非常重要的知识点,它可以帮助我们快速地执行 SQL 语句,从而提高工作效率。但需要注意的是,在执行 SQL 脚本文件时,我们需要格外小心,以免出现错误。
接下来,我将基于这个假设来展开一些重要的知识点。 ### PHP基础 1. **PHP概述**:PHP(Hypertext Preprocessor)是一种通用开源脚本语言,语法吸收了C语言、Java和Perl的特点,利于学习,使用广泛,主要适用于Web...
根据两个键搜索 3.6.8. 根据天计算访问量 3.6.9. 使用AUTO_INCREMENT 3.7. 孪生项目的查询 3.7.1. 查找所有未分发的孪生项 3.7.2. 显示孪生对状态的表 3.8. 与Apache一起使用MySQL 4. MySQL...
- replicate-do-db和replicate-ignore-db:用于指定哪些数据库需要同步,哪些数据库需要被忽略。 5. Mycat的安装与配置: Mycat1.6.0版本用于搭建中间件层,需要部署并配置Mycat的server.xml和schema.xml两个核心...
3. **创建表结构**:假设`sql_city.txt`包含创建表的SQL语句,如创建`provinces`和`cities`两个表: ```sql -- 假设表结构如下: CREATE TABLE provinces ( id INT PRIMARY KEY, name VARCHAR(50) NOT NULL );...
3.6.7. 根据两个键搜索 3.6.8. 根据天计算访问量 3.6.9. 使用AUTO_INCREMENT 3.7. 孪生项目的查询 3.7.1. 查找所有未分发的孪生项 3.7.2. 显示孪生对状态的表 3.8. 与Apache一起使用MySQL 4. MySQL程序概述 4.1. ...
3.6.7. 根据两个键搜索 3.6.8. 根据天计算访问量 3.6.9. 使用AUTO_INCREMENT 3.7. 孪生项目的查询 3.7.1. 查找所有未分发的孪生项 3.7.2. 显示孪生对状态的表 3.8. 与Apache一起使用MySQL 4. MySQL程序概述 4.1. ...
总结来说,"php+mysql网上购物系统"是一个涵盖了Web开发基础、数据库设计、安全防护以及前后端交互等多个知识点的综合实践项目。对于初学者,可以从中学习到Web开发的基本技能;对于经验丰富的开发者,也可以借鉴其...