位置: 编程技术 - 正文

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

  • 一般纳税人如何做账报税
  • 财务软件怎么样从捷软系统导出数据
  • 固定资产的进项税额可以抵扣吗
  • 股东权益是资产吗
  • 承租承包经营所得
  • 应收票据背书转让分录
  • 房地产企业固定资产的折旧
  • 收到发票付款是抹了零头怎么做账
  • 工业企业购进货物进项税额抵扣的时限
  • 股本权益性投资是什么
  • 募集资金怎么算
  • 车间停产期间设施有哪些
  • 购买的商品赠送如何做账
  • 利息费用需要取消吗
  • 拓展培训费如何开票
  • 支付职工补贴计入什么科目
  • 不动产增值税总结
  • 办理核定企业所需资料
  • 公司经营情况说明怎么写模板
  • 只有发票才能税前扣除吗
  • 生产活动产生的正的消费外部效应
  • 购买增值税专用发票会判刑吗
  • 苹果系统如何访问相册
  • 发生以前年度损益调整
  • php调用mysql索引查询
  • 工业厂房修建需要哪些手续
  • 怎么更改win7
  • 有关应付债券的法律规定
  • 超市进货产品
  • 微芯片技术
  • opencv如何使用
  • smiles查询
  • framework3.5怎么打开
  • 蓝桥杯2021出结果
  • css中文字垂直排列
  • 往来款项清查账务处理
  • 进项发票是专票吗
  • sql2008安装出现以下错误
  • phpcms程序
  • 影响留存收益变动的选折题
  • 小企业会计准则没有以前年度损益调整科目
  • 收到固定资产抵账账务处理
  • 从物资公司购入原木的进项税额
  • 增值税纳税申报表在哪里查询
  • 增值税是指怎样计算的
  • 应交增值税进项税额转出账务处理
  • 合理损耗如何处理
  • 医院药品进销差价会计核算
  • 出口退税分类管理三类企业
  • 未发货未收款先开具发票怎么账务处理
  • 公司投资款怎么算
  • 农民合作社入股倡议书
  • 发票的抵扣期限是多少天
  • 结算专用章是财务章吗
  • 预付款项给供应商合法吗
  • sql server重新安装步骤
  • XP系统怎么调节屏幕亮度
  • debian更新软件
  • linux开机启动ftp
  • ubuntu18.04启用root
  • root linux
  • ubuntu搜索工具
  • ubuntu20.04怎么用
  • exe是什么进程
  • [置顶]电影名字《收件人不详》
  • 如何优化资本结构
  • exceltype函数的用法
  • myeclipse创建
  • python 单例
  • 如何用vs默认打开unity脚本
  • [置顶]游戏名 TentacleLocker
  • 在文本输入框中的输入内容是
  • css下margin、padding、border、background和font缩写示例
  • 用python编写程序
  • unity简单小游戏案例
  • node.js怎么用
  • jquery点击方法
  • 住宿发票税率1%怎么回事
  • 加油发票如何抵扣
  • 电子税务局开发票流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设