大约sql声明优化
最近做的mysql数据库优化,并sql声明优化指南。我写了一个小文件。这种互相鼓励有关!
数据库参数获得的性能优化升级都在一起只占数据库应用系统的性能改进40%左右。其余60%的系统性能提升所有来自相应用程序的优化。很多优化专家甚至觉得相应用程序的优化能够得到80%的系统性能提升。因此能够肯定。通过优化应用程序来对数据库系统进行优化能获得更大的收益。
通常可分为两个方面: SQL语句的优化和数据库性能调优。
应用程序对数据库的操作终于要表现为SQL语句对数据库的操作。而数据库性能调优是结合硬件,软件,数据量等的一个综合解决方式,这个须要測试人员进行性能測试。和开发者配合进行性能调优。
SQL语句优化
3.1关键词优化
全部关键词都大写。如:SELECT,FORM,WHERE,AND,CREATE,TABLE等等,比如:使用mysql管理工具导出sql文件,我们能够看到大部分关键词都是大写。例如以下图:
解释:这是由于,sql的处理底层。默认就将全部的sql语句,进行大写转换。
3.2 sql语句中不能存在*
在所有的查询sql语句中。不能存在*符号。
即,SELECT *FORM 。
举例我们的部门表的查询。错误写法:SELECT * FROM tdepartment 正确写法:SELECT idepartmentid,scompanycode,sdepartmentname,iparentdepartmentid,sdeptposttype,sifdeleted,sleafnode,sdesc FROM tdepartment。原因:*号会检索所有字段,
用*号效率低,就相当于for循环和foreach一样。用*号。sql语句查询底层会默认去字
典库里查询公有多少个字段,然后在一个一个的取。
假设不使用*,就不是去先查字典库。
3.3 COUNT(*)使用
项目中不能使用COUNT(*)的sql语句。
COUNT(*)所有替换成COUNT(1)。这在数据量比較小的情况下,不明显。可是在表中数据较多的情况下,效果很明显。
3.4多用匹配查询,少用like查询
原因,like查询会直接放弃索引。
3.5主键索引使用
全部表的主键全是索引。应尽量使用主键查询。如:SELECT * FROM tusers ORDER BY dregistertime DESC效率低于SELECT * FROM tusers ORDER BY iuserid DESC。这是由于全部的主键都默认是索引。
而注冊时间不是索引字段。
3.6第1第2索引排列使用
如果我们的用户表中的scompanycode,dregistertime两个字段都创建了索引。而scompanycode是第一索引。dregistertime是第二索引。
那么查询时:SELECT * FROM tusers ORDER BY scompanycode,dregistertime DESC的效率高于SELECT * FROM tusers ORDER BY dregistertime,scompanycode DESC。这是由于第一索引将首先被检索。
3.7建表不要给字段设置默认值
如:`sifaudited` varchar(2) default '0' COMMENT '0:未审核。1:已审核'。默认值会在插入数据时,添加数据库底层推断是否有值情况,进行赋默认值。
3.8字段不要留null值
这是由于null值占用的数据大小比較大。
Null和空一般占4到8个字节。如:`scompanycode` varchar(16) default NULL COMMENT '公司编号(唯一识别)',对于这种,我们一般把空值改为0,你们应该懂的。
3.9多用子查询
子查询性能高于连接查询。
子查询性能高于左联接、右连接、全连接查询。
3.10连接查询性能高于循环查询
对于部门查询。我们通常是查询根文件夹,然后循环查询子部门。一直循环到查询结束。性能较低。
我们应该採用,连接查询。
或者写函数,存储过程进行查询。
4.设计优化
4.1 日志模块。新增队列。当日志达到100条或者200、500条的时候,我们採用批量插入n条,降低磁盘的io次数。这样能够延长磁盘的寿命,同一时候对数据的插入也有了明显的提高。
5.数据库引擎使用
5.1 ENGINE = innodb
Innodb数据库引擎是对外键。事务进行过优化。
我们对创建全部的表都使用innodb引擎。这是错误的,应该对每个表的用途相应一个不同的数据库引擎。
5.2 ENGINE = MyISAM
MyISAM类型不支持事务处理等高级处理。
MyISAM类型的表强调的是性能,其运行数度比InnoDB类型更快,可是不提供事务支持。
MyISAM类型的二进制数据文件能够在不同操作系统中迁移。也就是能够直接从Windows系统复制到linux系统中使用。
这个是默认类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的 顺序訪问方法) 的缩写,它是存储记录和文件的标准方法.与其它存储引擎比較,MyISAM具有检查和修复表格的大多数工具. MyISAM表格能够被压缩,并且它们支持全文搜索.它们不是事务安全的,并且也不支持外键。假设事物回滚将造成不全然回滚,不具有原子性。
假设运行大量 的SELECT。MyISAM是更好的选择。这个类型东海们项目使用的多。最经常使用的引擎之中的一个。
5.3 ENGINE = BDB
BDB:可替代InnoDB的事务引擎,支持COMMIT、ROLLBACK和其它事务特性。
5.4 ENGINE = Memory
Memory:将全部数据保存在RAM中,在须要高速查找引用和其它类似数据的环境下,可提供极快的訪问。
5.5 ENGINE = Merge
Merge:同意MySQL DBA或开发者将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。
对于诸如数据仓储等VLDB环境十分适合。
5.6 ENGINE = Archive
Archive:为大量非常少引用的历史、归档、或安全审计信息的存储和检索提供了完美的解决方式。
5.7 ENGINE = Federated
Federated:可以将多个分离的MySQLserver链接起来,从多个物理server创建一个逻辑数据库。十分适合于分布式 环境或数据集市环境。
5.8 ENGINE =Cluster/NDB
Cluster/NDB:MySQL的簇式数据库引擎,尤其适合于具有高性能查找要求的应用程序,这类查找需求还要求具有最高的正常工作时间和可用性
5.9 Other:其它存储引擎包含CSV(引用由逗号隔开的用作数据库表的文件)。Blackhole(用于暂时禁止对数据库的应用程序输入)。以及Example引擎(可为高速创建定制的插件式存储引擎提供帮助)。
6.表字段设计
6.1对于类型限制。是否删除字段。如:`sifdeleted` varchar(2) default '0' COMMENT '0:正常;1:已删除',使用int(1)类型标识。不要使用varchar(2)多占用空间。
6.2 对于字段长度限制,如手机号11位。我们就没有必要设计很多其它位数。公司编号能够仅仅设定8位。username限制32位等等。
6.3 少用外键限制
我们能够使用代码限制。
如:级联删除,级联新增,改动等等操作。
最好不要设计外键,外键对新增数据不利。
6.4 少用约束,如:唯一约束。
6.5 少用自己主动增长
在圆通主键没有自己主动增长,而是使用uuid,java自己主动生成。考虑到我们数据表数据较少,少用。
6.6 对于内容较少的表,没有必要创建索引。由于索引浪费空间。
6.7 表分区使用
对于日志表,我们能够使用表分区。表分区之后。对于查询效率有非常高的提升。默认有时间分区。大小分区。类型分区等等。
6.8 对表的内容进行限制。如:日志表能够限制条数。
再创建表时。我们使用MAX_ROWS进行限制。
7.其它请遵守建表规则
如:三范式等。
好吧就到这里,欢迎大家关注我的个人博客!
如有疑问,请加qq群: 共同学习!
点击下载文档:
版权声明:本文博客原创文章。博客,未经同意,不得转载。
大约sql声明优化的更多相关文章
- SQL Server SQL性能优化之--通过拆分SQL提高执行效率,以及性能高低背后的原因
复杂SQL拆分优化 拆分SQL是性能优化一种非常有效的方法之一, 具体就是将复杂的SQL按照一定的逻辑逐步分解成简单的SQL,借助临时表,最后执行一个等价的逻辑,已达到高效执行的目的 一直想写一遍通过 ...
- SQL性能优化
引言: 以前在面试的过程中,总有面试官问道:你做过sql性能优化吗?对此,我的答复是没有.一次没有不是自己的错误,两次也不是,但如果是多次呢?今天痛下决心,把有关sql性能优化的相关知识总结一下,以便 ...
- 如何进行正确的SQL性能优化
在SQL查询中,为了提高查询的效率,我们常常采取一些措施对查询语句进行SQL性能优化.本文我们总结了一些优化措施,接下来我们就一一介绍. 1.查询的模糊匹配 尽量避免在一个复杂查询里面使用 LIKE ...
- ORACLE性能优化之SQL语句优化
版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 操作环境:AIX +11g+PLSQL 包含以下内容: 1. SQL语句执行过程 2. 优化器及执行计划 3. 合 ...
- MySQL数据库SQL层级优化
本篇主涉及MySQL SQL Statements层面的优化. 首先,推荐一个链接为万物之始:http://dev.mysql.com/doc/refman/5.0/en/optimization.h ...
- 如何进行SQL性能优化
在SQL查询中,为了提高查询的效率,我们常常采取一些措施对查询语句进行SQL性能优化.本文我们总结了一些优化措施,接下来我们就一一介绍. 1.查询的模糊匹配 尽量避免在一个复杂查询里面使用 LIKE ...
- 关于SQL性能优化的十条经验
1.查询的模糊匹配 尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用. 解决办法: 其实只需要对该脚本略做改进,查询速度便会 ...
- ORACLE数据库学习之SQL性能优化详解
Oracle sql 性能优化调整 ...
- SQL通用优化方案(where优化、索引优化、分页优化、事务优化、临时表优化)
SQL通用优化方案:1. 使用参数化查询:防止SQL注入,预编译SQL命令提高效率2. 去掉不必要的查询和搜索字段:其实在项目的实际应用中,很多查询条件是可有可无的,能从源头上避免的多余功能尽量砍掉, ...
随机推荐
- vim ---- 自己主动的按钮indent该命令
当使用vim一段代码的副本到一个程序时,有,经常indent会有一些问题. . 下面的这个强大的命令,使您可以一键码具有很好的格式. gg=G 样品:
- android 如何分析java.lang.IllegalArgumentException: Cannot draw recycled bitmaps异常
这类问题的分析,通常你需要找到bitmap对象已经在那个位置recyle,然后检查代码. 如何定位的位置,其中代码具有对bitmap 目的recyle.能够 Bitmap.java的recycle方法 ...
- How to Compile Java DBus
1 download or git clone Java DBus git clone git://anongit.freedesktop.org/dbus/dbus-java dbus-java 2 ...
- [转载] C++11新特性
C++11标准发布已有一段时间了, 维基百科上有对C++11新标准的变化和C++11新特性介绍的文章. 我是一名C++程序员,非常想了解一下C++11. 英文版的维基百科看起来非常费劲,而中文版维基百 ...
- SQL server 表数据改变触发发送邮件
今天遇到一个问题,原有生产系统正在健康运行,现需要监控一张数据表,当增加数据的时候,给管理员发送邮件. 领到这个需求后,有同事提供方案:写触发器触发外部应用程序.这是个大胆的想法啊,从来没写过这样的触 ...
- 80x86汇编小站站长简单介绍-2014年08月23日
[序言] 旧版的"80x86汇编小站站长简单介绍"已经过时了, 因此于2013年10月01日花费1个小时又一次更新和排版一次. [人生格言] 1] 一生都用头脑而不是情绪解决这个 ...
- 请注意CSDN社区微通道,许多其他的精彩等着你
CSDN社区微信公众号"程序人生"(微信ID:coder_life)来了,每天我们会将CSDN社区中大量的优质内容浓缩成1~3篇文章.推送到您的手机中,让您不管何时何地都能感受到知 ...
- 【Linux探索之旅】第二部分第三课:文件和目录,组织不会亏待你
内容简介 1.第二部分第三课:文件和目录,组织不会亏待你 2.第二部分第四课预告:文件操纵,鼓掌之中 文件和目录,组织不会亏待你 上一次课我们讲了命令行,这将成为伴随我们接下来整个Linux课程的一个 ...
- BeagleBone Black教训四局:简单LED对照实验
BBB教训四局:简单LED对照实验 学习BBB董事会最终目的是做同样的想象单片机控制.但控制是不一样的想法,在所有(Linux在本质上,硬件设备的控制,以虚拟文件有关的设备下的读写),研究了几天头都大 ...
- NTVS:把Visual Studio变成Node.js IDE 的工具
NTVS(Node.js Tools for Visual Studio) 运行于VS2012或者VS2013.一些node.js的爱好者已经从PTVS(Python Tools for Visual ...