位置: 编程技术 - 正文

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服务器硬件配置)

  • 出售股东
  • 银行承兑汇票提前承兑收多少手续费
  • 工会经费计入成本费用
  • 银行汇票可以异地跨行使用吗
  • 固定资产一次性计入费用的账务处理
  • 依法确定的其他扣除项目包括
  • 保证金可以挪用吗
  • 缴纳的专利年费能退吗
  • 建筑企业增值税纳税义务发生时间如何确定
  • 个人所得税筹划节税
  • 公司车买保险怎么付款
  • 红字冲销是加还是减
  • 国家金库是什么税费
  • 收到公益性捐赠所得税
  • 自来水差额征税政策
  • 餐饮店投资入股注意事项
  • 公司为什么要员工提供房产证
  • 购买的认证标志入什么费用?
  • 工程结算审计费用谁承担
  • 工会筹备金和工会经费金额一样吗
  • 事业单位没有税号 选个人可以吗
  • 企业公司报税流程
  • 不能抵扣的进项发票怎么做分录
  • 下列各项支出中,允许用现金支付的有
  • 低值易耗品与固定资产有相同的特征,表现在哪里?
  • 香港企业股东分红税
  • 鸿蒙大文件夹怎么设置透明度
  • 总账建账科目顺序
  • 公司购买空调计入什么费用
  • Win10新版21364发布: 可直接运行Linux图形程序
  • 宏基笔记本一键恢复系统
  • 一公顷等于多少千米
  • 注册资本和投资总额的关系
  • 事业单位小规模纳税人缴纳附加税有什么,税率是多少
  • 原生微信小程序面试题
  • 员工宿舍的物业费能否抵扣
  • 公司买汽车计入什么费用
  • 支付水电费如何做账务处理
  • 房产税和城镇土地使用税需要计提吗
  • 日常费用明细表格式
  • 材料出入库的本质是什么
  • 工程结算科目
  • 利润表调整了资产负债表怎么调整
  • access的使用教程
  • 金税四期上线后对个人的影响
  • 小规模定额征收和查账征收哪个更好一些
  • 稳岗返还的概念
  • 如何区分生产类型
  • 无形资产专利技术属于
  • 营改增后土地出让增值税
  • 应付账款清账账务处理
  • 公司奖励员工制度
  • 会员卡充值赠送金额怎么做账
  • 公司社保外包了,没给我社保卡怎么办?
  • 代销手续费怎么做账
  • 原材料用于在建工程进项税可以抵扣吗
  • 当月进货没有认证怎么办
  • 商标使用权入股要交税吗
  • 员工体检费计入什么会计科目里
  • 给员工家人报销会计分录
  • centos 操作
  • WIN10开启高性能模式
  • windows xp死亡倒计时
  • linux分割分区
  • ubuntu和windows文件互传
  • 黑马一键重装
  • win7系统无法开机解决方法
  • cocos2dx游戏开发进阶卷这本书怎么样
  • cocos2dx入门
  • unity做cg
  • jquery table加载数据
  • 提高css文件可维性的方法
  • tree 怎么用
  • 快速使用流量
  • javascript教程
  • activate webstorm
  • python中的迭代器
  • apk反编译去广告教程
  • 深两优3117审定号
  • 什么是集体约谈制
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设