首页 数据库 mysql教程 mysql 优化(1)表的优化与列类型选择

mysql 优化(1)表的优化与列类型选择

Dec 29, 2016 pm 04:04 PM

表的优化:

1: 定长与变长分离

如 id int, 占4个字节, char(4)占4个字符长度,也是定长,
time 即每一单元值占的字节是固定的.

核心且常用字段,宜建成定长,放在一张表. 而varchar,
text,blob,这种变长字段,适合单放一张表,用主键与核心表关联起来.

sql 执行查询100000条数据 会因为所有都是定常而跳过的非常迅速 

2:常用字段和不常用字段要分离.

需要结合网站具体的业务来分析,分析字段的查询场景,查询频度低的字段,单拆出来.

3:在1对多,需要关联统计的字段上,添加冗余字段.
减少关联查询

看如下BBS的效果 统计的发帖数 不要数 而是通过在栏目下的添加冗余字段,每次发文章更新文章数+1 这样就会减少查询强度

列选择原则:

1:字段类型优先级 整型> date,time >enum,char>varchar > blob,text

列的特点分析:整型:定长,没有国家/地区之分,没有字符集的差异

比如 tinyint 1,2,3,4,5 <--> char(1) a,b,c,d,e, 从空间上,都是占1个字节,但是order
by 排序,前者快

原因: 后者需要考虑字符集与校对集(就是排序规则)

time定长,运算快,节省空间. 考虑时区,写sql时不方便 where
> ‘2005-10-12’; 时间存int 型;
enum: 能起来约束值的目的, 内部用整型来存储,但与char联查时,内部要经历串与值的转化
Char 定长, 考虑字符集和(排序)校对集
varchar, 不定长 要考虑字符集的转换与排序时的校对集,速度慢.
text/Blob 无法使用内存临时表(排序等操作只能在磁盘上进行)

性别: 以utf8为例

char(1) , 3个字长字节

enum(‘男’,’女’); // 内部转成数字来存,多了一个转换过程

tinyint() , // 0 1 2 // 定长1个字节.

sql 优化书籍 《MYSQL 高性能优化》

关于date/time的选择,大师的明确意见,直接选int unsgined not null ,存储时间戳http://www.xaprb.com/blog/2014/01/30/timestamps-in-mysql/

时间--->存成整型

2: 恰好够用就行,不要慷慨(如smallint,varchar(N))

原因: 大的字段浪费内存,影响速度,

以年龄为例 tinyint unsigned not null ,可以存储255岁,足够.用int浪费了3个字节

以varchar(10) ,varchar(300)存储的内容相同,但在表联查时,varchar(300)要花更多内存

3: 尽量避免用NULL()

原因: NULL不利于索引,要用特殊的字节来标注.

在磁盘上占据的空间其实更大.(mysql5.7已对null做的改进,但查询仍是不便)

实验:

可以建立2张字段相同的表,一个允许为null,一个不允许为Null,各加入1万条,查看索引文件的大小.可以发现,为null的索引要大些.(mysql5.5里,关于null已经做了优化,大小区别已不明显)

另外: null也不便于查询,

where 列名=null; 

where 列名!=null;都查不到值,

where 列名 is null ,或is not null才可以查询.

create table dictnn (
id int,
word varchar(14) not null default &#39;&#39;,
key(word)
)engine myisam charset utf8;
登录后复制
create table dictyn (
id int,
word varchar(14),
key(word)
)engine myisam charset utf8;
登录后复制
alter table dictnn disable keys;
alter table dictyn disable keys;
登录后复制
insert into dictnn select id,if(id%2,word,&#39;&#39;) from dict limit 10000;
insert into dictyn select id,if(id%2,word,null) from dict limit 10000;
登录后复制
alert table dictnn enable keys;
alter table dictyn enable keys;
登录后复制



Enum列的说明

1: enum列在内部是用整型来储存的

2: enum列与enum列相关联速度最快

3: enum列比(var)char的弱势---在碰到与char关联时,要转化.要花时间.

4: 优势在于,当char非常长时,enum依然是整型固定长度.

当查询的数据量越大时,enum的优势越明显.

5: enum与char/varchar关联,因为要转化,速度要比enum->enum,char->char要慢,

但有时也这样用-----就是在数据量特别大时,可以节省IO.

试验:

create table t2 (
id int,
gender enum(&#39;man&#39;,&#39;woman&#39;),
key(gender)
)engine myisam charset utf8;
登录后复制
create table t3 (
id int,
gender char(5) not null default &#39;&#39;,
key(gender)
)engine myisam charset utf8;
登录后复制
alter table t2 disable keys;
alter table t3 disable keys;
登录后复制
insert into t2 select id,if(id%2,&#39;man&#39;,&#39;woman&#39;) from dict limit 10000;
insert into t3 select id,if(id%2,&#39;man&#39;,&#39;woman&#39;) from dict limit 10000;
登录后复制
alter table t2 enable keys;
alter table t3 enable keys;
mysql> select count(*) from t2 as ta,t2 as tb where ta.gender=tb.gender
mysql> select count(*) from t3 as ta,t3 as tb where ta.gender=tb.gender
登录后复制

列<---->列

   时间

   

Enum<--->enum

   10.53

   

Char<---->char

   24.65

   

Enum<---->char

   18.22

   

如果t2表的优势不明显,加大t3的gender列,char(15),
char(20)...

随着t3 gender列的变大,t2表优势逐渐明显.



原因----无论enum(‘manmaman’,’womanwomanwoman’)枚举的字符多长,

内部都是用整型表示, 在内存中产生的数据大小不变,

而char型,却在内存中产生的数据越来越多.



总结: enum 和enum类型关联速度比较快

Enum 类型 节省了IO

 以上就是mysql 优化(1)表的优化与列类型选择的内容,更多相关内容请关注PHP中文网(www.php.cn)!


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
<🎜>掩盖:探险33-如何获得完美的色度催化剂
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1677
14
CakePHP 教程
1430
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
如何通过MySQL对AVG函数优化来提高性能 如何通过MySQL对AVG函数优化来提高性能 May 11, 2023 am 08:00 AM

如何通过MySQL对AVG函数优化来提高性能MySQL是一款流行的关系型数据库管理系统,其中包含了许多强大的函数以及功能。其中AVG函数被广泛使用在计算平均值的情形,但是由于这个函数需要遍历整个数据集,所以在大规模数据的情况下会导致性能问题。本文将详细介绍如何通过MySQL对AVG函数进行优化,从而提高性能。1.使用索引索引是MySQL优化中最重要的一部分,

基于TokuDB引擎的MySQL优化:提升写入和压缩性能 基于TokuDB引擎的MySQL优化:提升写入和压缩性能 Jul 25, 2023 pm 11:45 PM

基于TokuDB引擎的MySQL优化:提升写入和压缩性能引言:MySQL作为一种常用的关系型数据库管理系统,在大数据时代的背景下,面临着越来越高的写入压力和存储需求。为了应对这一挑战,TokuDB引擎应运而生。本文将介绍如何利用TokuDB引擎来提升MySQL的写入性能和压缩性能。一、什么是TokuDB引擎?TokuDB引擎是一种面向大数据的、用于处理高写入

如何实现MySQL底层优化:SQL语句高级优化的技巧和最佳实践 如何实现MySQL底层优化:SQL语句高级优化的技巧和最佳实践 Nov 08, 2023 pm 04:32 PM

MySQL是一种广泛使用的关系型数据库管理系统,常用于Web应用程序的开发和数据存储。在实际应用中,对MySQL的底层优化尤为重要,其中SQL语句的高级优化是提升数据库性能的关键所在。本文将介绍实现MySQL底层优化的一些技巧和最佳实践,以及具体的代码示例。确定查询条件在编写SQL语句时,首先要明确定义查询条件,避免使用无限制的通配符查询,即避免使用"%"开

MySQL在电子商务应用中的优化与安全项目经验解析 MySQL在电子商务应用中的优化与安全项目经验解析 Nov 03, 2023 am 10:42 AM

MySQL是一种广泛应用于电子商务领域的关系型数据库管理系统。在电子商务应用中,对MySQL进行优化和安全工作是至关重要的。本文将解析MySQL在电子商务应用中的优化与安全项目经验。一、性能优化数据库架构设计:在电子商务应用中,数据库的设计是关键。合理的表结构设计和索引设计能够提高数据库的查询性能。同时,使用分表和分区技术可以减少单一表的数据量,提高查询效率

如何优化MySQL连接数管理 如何优化MySQL连接数管理 Mar 16, 2024 am 08:12 AM

如何优化MySQL连接数管理MySQL是一种流行的关系型数据库管理系统,广泛应用于各种网站和应用程序中。在实际的应用过程中,MySQL连接数管理是一个非常重要的问题,尤其是在高并发情况下,合理管理连接数可以提高系统的性能和稳定性。本文将介绍如何优化MySQL连接数管理,包括详细的代码示例。一、理解连接数管理在MySQL中,连接数是指系统能够同时连

优化MySQL查询性能:从储存引擎到查询语句的全方位技巧 优化MySQL查询性能:从储存引擎到查询语句的全方位技巧 Jul 26, 2023 pm 01:05 PM

优化MySQL查询性能:从储存引擎到查询语句的全方位技巧概要:MySQL是一个广泛使用的开源关系型数据库管理系统,是许多应用程序的首选数据库。但是,随着数据量的增大和查询负载的增加,查询性能可能会成为一个问题。本文将介绍一系列的优化技巧,从储存引擎的选择到查询语句的优化,帮助提高MySQL的查询性能。使用合适的储存引擎MySQL提供了多种储存引擎,如M

MySQL常见问题解决方法大全 MySQL常见问题解决方法大全 Jun 15, 2023 am 09:51 AM

MySQL是一种广泛使用的开源数据库管理系统,用于存储和管理大量数据。但是,使用MySQL时,您可能会遇到各种各样的问题,从简单的语法错误到更复杂的性能问题和故障。在本文中,我们将探讨一些最常见的MySQL问题和解决方法。连接问题连接问题很常见。如果您无法连接到MySQL服务器,请检查以下几点:1)MySQL服务器是否正在运行2)网络连接是否正常3)MySQ

在解释中使用临时状态以及如何避免它是什么? 在解释中使用临时状态以及如何避免它是什么? Apr 15, 2025 am 12:14 AM

Usingtemporary在MySQL查询中表示需要创建临时表,常见于使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通过优化索引和重写查询避免其出现,提升查询性能。具体来说,Usingtemporary出现在EXPLAIN输出中时,意味着MySQL需要创建临时表来处理查询。这通常发生在以下情况:1)使用DISTINCT或GROUPBY时进行去重或分组;2)ORDERBY包含非索引列时进行排序;3)使用复杂的子查询或联接操作。优化方法包括:1)为ORDERBY和GROUPB

See all articles