热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Mysql优化原则_MySQL

原则1、仅列出需要查询的字段,这对速度不会明显的影响,主要是考虑节省应用程序服务器的内存。
二、原则总结

原则1、仅列出需要查询的字段,这对速度不会明显的影响,主要是考虑节省应用程序服务器的内存。

原来语句: select * from admin

优化为: select admin_id,admin_name,admin_password from admin

原则2、尽量避免在列上做运算,这样导致索引失效。

原语句: select * from admin where year(admin_time)>2014

优化为: select * from admin where admin_time> '2014-01-01′

原则3、使用JOIN 时候,应该用小的结果驱动大的结果(left join 左边表结果尽量小 如果有条件应该放到左边先处理,right join 同理反向),同事尽量把牵涉到多表联合的查询拆分多个query(多个连表查询效率低,容易到之后锁表和阻塞)。

原来语句 select * from admin left join log on admin.admin_id = log.admin_id where log.admin_id>10

优化为: select * from (select * from admin where admin_id>10) T1 lef join log on T1.admin_id = log.admin_id

原则 4、注意LIKE 模糊查询的使用, 避免使用 %% ,可以使用 后面带% ,双%是不走索引的。

原来语句: select * from admin where admin_name like ‘%de%'

优化为: select * from admin where admin_name >=&#39;de&#39; and admin_nam <&#39;df&#39; (注意不是等效的这里试试提供优化的思路)

原则5、使用批量插入节省交互 (当如如果使用存储过程来处理批量的sql 各种逻辑是更好的选择)。

原来语句:insert into admin(admin_name,admin_password) values (‘test1′,&#39;pass1′);

insert into admin(admin_name,admin_password) values (‘test2′,&#39;pass2′);

insert into admin(admin_name,admin_password) values (‘test3′,&#39;pass3′)

优化为: insert into admin(admin_name,admin_password) values(‘test1′,&#39;pass1′),(‘test2′,&#39;pass2′),(‘test3′,&#39;pass3′)

原则6、limit 的基数比较大时使用between。

原来语句:select * from admin order by admin_id limit 100000,10

优化为: select * from admin where admin_id between 100000 admin 100010 order by admin_id

原则7、不要使用rand函数获取多条随机记录。

原来语句: select * from admin order by rand() limit 20

优化为: select * from admin as t1 Join(select round(rand()*((select max(admin_id) from admin)-(select min(id) from admin))+(select min(id) from admin)) as id) as t2 where t1.id>=t2.id order by t1.id limit

原则8、避免使用NULL。

原则9. 不要使用 count(id) 使用 count(*)。

原则10、不要做无谓的排序操作,而应该使用索引完成排序。

三、总结

数据库优化包括两个方面,一方面是SQL程序优化,另一方面是数据库配置的优化。另外在MySQL可以通过以下语句来查看帮助SQL进行优化:

代码如下:
set @@profiling = 1;
select * from typecho_comments order mail limit 10,30;
show profiles;

show profile for query

mysql

用那个

关键字分析

sql

语句性能

mysql

用那个

关键字分析

sql

语句性能

mysql

用那个

关键字分析

sql

语句性能

mysql用那个关键字分析sql语句性能?

如上 用 show profiles;

mysql

用那个

关键字分析

sql

语句性能





mysql

用那个

关键字分析

sql

语句性能




mysql

用那个

关键字分析

sql

语句性能



mysql

用那个

关键字分析

sql

语句性能

推荐阅读
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • MVC模式下的电子取证技术初探
    本文探讨了在MVC(模型-视图-控制器)架构下进行电子取证的技术方法,通过实际案例分析,提供了详细的取证步骤和技术要点。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
  • 【MySQL】frm文件解析
    官网说明:http:dev.mysql.comdocinternalsenfrm-file-format.htmlfrm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果 ... [详细]
  • 本文介绍了MySQL窗口函数的基本概念、应用场景及常见函数的使用方法。窗口函数在处理复杂查询时非常有用,例如计算每个用户的订单排名、环比增长率、以及动态聚合等。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • 解决ADODB连接Access时出现80004005错误的方法
    本文详细介绍了如何解决在使用ADODB连接Access数据库时遇到的80004005错误,包括错误原因分析和具体的解决步骤。 ... [详细]
  • binlog2sql,你该知道的数据恢复工具
    binlog2sql,你该知道的数据恢复工具 ... [详细]
  • 本文详细解析了MySQL中常见的几种错误,并提供了具体的解决方法,帮助开发者快速定位和解决问题。 ... [详细]
  • 搭建个人博客:WordPress安装详解
    计划建立个人博客来分享生活与工作的见解和经验,选择WordPress是因为它专为博客设计,功能强大且易于使用。 ... [详细]
  • 七大策略降低云上MySQL成本
    在全球经济放缓和通胀压力下,降低云环境中MySQL数据库的运行成本成为企业关注的重点。本文提供了一系列实用技巧,旨在帮助企业有效控制成本,同时保持高效运作。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
author-avatar
nd子听雨
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有