• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > mysql数据库优化需要遵守的原则

mysql数据库优化需要遵守的原则

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql数据库优化,mysql数据库优化方案,mysql数据库优化面试,mysql数据库优化like,mysql数据库优化工具等相关知识,希望本文的分享对您有所帮助
这是我在网上看到的一篇不错的mysql数据库优化文章,内容说的很全!
1、使用索引来更快地遍历表
缺省情况下建立的索引是非群集索引,但有时它并不是最佳的。在非群集索引下,数据在物理上随机存放在数据页上。合理的索引设计要建立在对各种查询的分析和预测上。一般来说:
a.有大量重复值、且经常有范围查询( > ,< ,> =,< =)和order by、group by发生的列,可考虑建立群集索引;
b.经常同时存取多列,且每列都含有重复值可考虑建立组合索引;
c.组合索引要尽量使关键查询形成索引覆盖,其前导列一定是使用最频繁的列。索引虽有助于提高性能但不是索引越多越好,恰好相反过多的索引会导致系统低效。用户在表中每加进一个索引,维护索引集合就要做相应的更新工作。
2、在海量查询时尽量少用格式转换
3、ORDER BY和GROPU BY:使用ORDER BY和GROUP BY短语,任何一种索引都有助于SELECT的性能提高。
4、任何对列的操作都将导致表扫描,它包括数据库函数、计算表达式等等,查询时要尽可能将操作移至等号右边。
5、IN、OR子句常会使用工作表,使索引失效。如果不产生大量重复值,可以考虑把子句拆开。拆开的子句中应该包含索引。
6、只要能满足你的需求,应尽可能使用更小的数据类型:例如使用MEDIUMINT代替INT
7、尽量把所有的列设置为NOT NULL,如果你要保存NULL,手动去设置它,而不是把它设为默认值。
8、尽量少用VARCHAR、TEXT、BLOB类型
9、如果你的数据只有你所知的少量的几个。最好使用ENUM类型
10、正如graymice所讲的那样,建立索引。
以下是我做的一个实验,可以发现索引能极大地提高查询的效率:
我有一个会员信息表users,里边有37365条用户记录:
在不加索引的时候进行查询:
sql语句A:
代码:
你用Mysql-Front是通过时长来比较,我觉得如果从查询时扫描字段的次数来比较更精确一些。 </div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 优化mysql数据库的经验总结
  • 基于MYSQL中优化的一些方法
  • mysql数据库优化需要遵守的原则
  • mysql 模糊搜索的方法介绍
  • mysql服务启动不了解决方案
  • Mysql启动与数据库的创建方法[图文]
  • Mysql 数据库更新错误的解决方法
  • 为mysql数据库添加添加事务处理的方法
  • MySQL数据库十大优化技巧
  • MySQL数据库优化经验详谈(服务器普通配置)第1/3页

相关文章

  • 2018-12-05MySQL 查询 批量插入 批量更新 优化的详情介绍
  • 2018-12-05sql 中 case when 语法使用方法
  • 2018-12-05Oracle下时间转换在几种语言中的实现_Oracle应用_脚本之家
  • 2018-12-05MySQL 存储过程的基本用法介绍
  • 2018-12-05MyISAM和InnoDB存储引擎的索引实现方式的区别
  • 2018-12-05Mysql5.7.11在windows10上的安装与配置(解压版)_MySQL
  • 2018-12-05数据库记录删除方式 有哪些
  • 2018-12-05Mysql-聚簇索排序慢案例分析
  • 2018-12-05Windows Oracle常见服务介绍
  • 2017-05-11mysql支持跨表delete删除多表记录

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 深入理解MySQL的数据库引擎的类型
    • mysql中的跨库关联查询方法详解
    • 用SQL语句实现随机查询数据并不显示错误数据的方法
    • Windows下ORACLE 10g完全卸载的方法分析
    • PDO操作MySQL基础教程
    • php下巧用select语句实现mysql分页查询
    • mysql数据库如何升级脚本制作过程分享
    • sql文件怎么打开
    • SQLServer Execpt和not in 性能区别
    • MySQL的字符集操作命令总结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有