位置: 编程技术 - 正文

MYSQL WHERE语句优化(mysql where join)

编辑:rootadmin
但请注意,下面的优化并不是完全的。MYSQL实施了许多优化,但我没时间全部测试. MySQL的一些优化列在下面: 删除不必要的括号: ((a AND b) AND c OR (((a AND b) AND (c AND d)))) -> (a AND b AND c) OR (a AND b AND c AND d) 常数调入: (a<b AND b=c) AND a=5 -> b>5 AND b=c AND a=5 删除常数条件: (B>=5 AND B=5) OR (B=6 AND 5=5) OR (B=7 AND 5=6) -> B=5 OR B=6 索引使用的常数表达式仅计算一次。 在一个单个表上的没有一个WHERE的COUNT(*)直接从表中检索信息。当仅使用一个表时,对任何NOT NULL表达式也这样做。 无效常数表达式的早期检测。MySQL快速检测某些SELECT语句是不可能的并且不返回行。 如果你不使用GROUP BY或分组函数(COUNT()、MIN()……),HAVING与WHERE合并。 为每个子联结(sub join),构造一个更简单的WHERE以得到一个更快的WHERE计算并且也尽快跳过记录。 所有常数的表在查询中的在其他任何表之前被读出。 一个常数的表是: 一个空表或一个有1行的表。 与在一个UNIQUE索引、或一个PRIMARY KEY的WHERE子句一起使用的表,这里所有的索引部分使用一个常数表达式并且索引部分被定义为NOT NULL。 所有下列的表用作常数表: mysql> SELECT * FROM t WHERE primary_key=1; mysql> SELECT * FROM t1,t2 WHERE t1.primary_key=1 AND t2.primary_key=t1.id; 对联结表的最好联结组合是通过尝试所有可能性来找到:(。如果所有在ORDER BY和GROUP BY的列来自同一个表,那么当联结时,该表首先被选中。 如果你使用SQL_SMALL_RESULT,MySQL将使用一个在内存中的表。 如果有一个ORDER BY子句和一个不同的GROUP BY子句,或如果ORDER BY或GROUP BY包含不是来自联结队列中的第一个表的其他表的列,创建一个临时表。 因为DISTINCT被变换到在所有的列上的一个GROUP BY,DISTINCT与ORDER BY结合也将在许多情况下需要一张临时表。 每个表的索引被查询并且使用跨越少于% 的行的索引。如果这样的索引没能找到,将使用一个快速的表扫描。 在一些情况下,MySQL能从索引中读出行,甚至不用查询数据文件。如果索引使用的所有列是数字的,那么只有索引树被用来解答查询。 在每个记录被输出前,那些不匹配HAVING子句的行将被跳过。 下面是一些快速的查询例子: mysql> SELECT COUNT(*) FROM tbl_name; mysql> SELECT MIN(key_part1),MAX(key_part1) FROM tbl_name; mysql> SELECT MAX(key_part2) FROM tbl_name WHERE key_part_1=constant; mysql> SELECT ... FROM tbl_name ORDER BY key_part1,key_part2,... LIMIT ; mysql> SELECT ... FROM tbl_name ORDER BY key_part1 DESC,key_part2 DESC,... LIMIT ; 下列查询仅使用索引树就可解决(假设索引列是数字的): mysql> SELECT key_part1,key_part2 FROM tbl_name WHERE key_part1=val; mysql> SELECT COUNT(*) FROM tbl_name WHERE key_part1=val1 AND key_part2=val2; mysql> SELECT key_part2 FROM tbl_name GROUP BY key_part1; 下列查询使用索引以排序顺序检索,不用一次另外的排序: mysql> SELECT ... FROM tbl_name ORDER BY key_part1,key_part2,... mysql> SELECT ... FROM tbl_name ORDER BY key_part1 DESC,key_part2 DESC,...

推荐整理分享MYSQL WHERE语句优化(mysql where join),希望有所帮助,仅作参考,欢迎阅读内容。

MYSQL WHERE语句优化(mysql where join)

文章相关热门搜索词:mysql where sum,mysql where clause,mysql中where的用法,mysql where isnull,mysql的where语句,mysql中的where,mysql的where语句,mysql中where的用法,内容如对您有帮助,希望把文章链接给更多的朋友!

MySQL 服务器参数说明及查看 设置方法 查看参数:SHOWVARIABLES;设置参数:SETGLOBAL参数名称=value;如设置数据库最大连接数为:SETGLOBALmax_connections=。用shellmysqld-help这个命令可以得到一张所

MySQL 实用命令 一)连接MYSQL:格式:mysql-h主机地址-u用户名-p用户密码1、例1:连接到本机上的MYSQL首先在打开DOS窗口,然后进入mysql安装目录下的bin目录下,例如:D:m

Mysql 默认字符集设置方法(免安装版) 以mysql-noinstall-5.0.-win为例,解压缩后会看到mysql-5.0.-win文件夹下面,有五个ini格式的文件,把my-medium.ini文件拷贝一份,改名为my.ini,打开my.ini文件

标签: mysql where join

本文链接地址:https://www.jiuchutong.com/biancheng/319948.html 转载请保留说明!

上一篇:mysql 终结点映射器中没有更多的终结点可用的解决方法(mysql终端操作)

下一篇:MySQL 服务器参数说明及查看 设置方法(mysql服务器硬件配置)

  • 饮食企业简介
  • 如何理解增值税中性特点
  • 反避税定义
  • 支付办公楼维修费
  • 房地产按揭是什么意思
  • 外汇结汇成人民币违法吗
  • 小微企业开票多少算小规模纳税人
  • 月收入不足10万免增值税的账务处理
  • 进项税转出主要内容包括
  • 营业账簿是什么意思
  • 某公司是一家刚成立的大型化妆品生产企业
  • 进口增值税发票图片
  • 以公司股权作价入股母公司
  • 摊销土地使用权和专利权会计分录怎么写
  • 公司债权转让如何处理
  • 结算纪律与法律责任表格
  • 2017年广告费税率
  • 发票校验码后六位在哪个位置图片
  • 数量和单价的乘积
  • 退税指导
  • 营业外收入政府补贴要交税吗
  • 合同付款会计分录
  • 苹果x如何显示电量数字
  • 表格关闭函数
  • 劳务公司开发票,劳务公司怎么转取收入
  • 接入设备检测
  • win10平板模式怎么改回来
  • win7安装netframework4.5
  • uniapp中的onload
  • 报销差旅费怎么算
  • 每月分配利润如何做账
  • 固定资产后续支出一律计入固定资产成本
  • vue调整图标大小
  • php strlen 中文
  • 用php做计算
  • 增值税检查后的调账方法
  • 微信小程序计算器代码
  • php solr
  • 非贸付汇代扣代交哪些税
  • 网络工程师笔记大全
  • vue 长列表优化
  • php提供的字符串函数
  • 前端面试题什么是网络协议
  • php die exit
  • php处理并发有哪些技术
  • 差旅费用不用交税
  • 单位为职工订做活动通知
  • 劳保统筹费计入什么科目
  • 税务维护费抵扣分录
  • 费用票有什么用处
  • 房产税的计算器
  • 什么是企业贷款余额
  • mysql innodb锁
  • 幼儿园伙食账目
  • 个人所得税的征收模式为()A
  • 税收返还会计处理方法
  • 出口不报关账务处理
  • 营销策划费用是
  • 应付账款一直挂着,怎么消掉
  • mysql 5.7.11 winx64安装配置方法图文教程
  • sql server无法连接服务器的原因
  • 判断某个字段的值是否在指定的范围内
  • winpe如何使用
  • win10系统开机密码设置方法
  • XP IIS5.1 + PHP 5.2.1 + MySQL 5.0.37 + Zend 3.2.6 + phpMyAdmin-2.10.0.2环境配置
  • linux 常用命令大全及其详解
  • win8如何设置
  • win8屏幕分辨率显示不全
  • window10自动维护功能有什么用
  • Android Chronometer(定时器)
  • shell 查找文件并赋值shell变量
  • js插件大全
  • 安卓手机管家删除的照片怎么恢复
  • unity3d物理现象模拟
  • android单选
  • 如何用python编写一个程序
  • js获取当前月份的天数
  • js图片预览
  • linux中安装python的工具包
  • 企业少缴社保怎么补偿
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设