位置: 编程技术 - 正文

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

  • 纳税检查调整的销售额确认收入吗
  • 免税收入怎么做会计分录
  • 增值税价外税是什么税种
  • 固定资产清理期末余额在借方是什么意思
  • 事业单位法人证书查询
  • 减免的附加税怎么做会计分录
  • 冲红发票怎么填写信息
  • 发票上盖财务章吗
  • 客户能把货款打给个人吗
  • 工程款抵房款账务怎么做
  • 资产资本化的借款费用如何写分录?
  • 租个人房子开发票税率是多少
  • 报企业所得税的利润总额怎么填
  • 合伙企业购买股票产生的收益需要缴纳税款吗
  • 建安企业需要交环保税吗
  • 净资产收益率计算公式用期末净资产
  • 广告服务增值税差额征税
  • 企业所得税年报错了怎么更正
  • 实验耗材发票内容怎么写
  • 采购的增值税
  • 销售退货怎么开红字
  • 公司注销清算企业所得税申报表怎么填
  • 计提员工社保拿什么做原始凭证?
  • 不同税率的发票可以合并入账吗
  • linux文本编辑器命令
  • 专用发票已认证怎么退回
  • 广告业财政拨款包括哪些
  • win10自动关机方法
  • 营业外支出与营业收入之比应小于1%的说明
  • reg.dll是什么
  • 公司股东转账进公司账户,会计分录
  • 财政拨款结转的明细科目中,年末结转后有余额的是
  • 购买加油卡能否抵扣
  • 公允价值变动损益在利润表哪里
  • vue动态组件component原理
  • 【机器学习】KNN算法及K值的选取
  • 520要来了要吵架的赶紧
  • 公链dapp
  • 《linux内核分析》
  • 投稿p2
  • 微软和梅赛德斯奔驰宣布合作
  • 社会保险费的征收机构由什么规定
  • 一般情况下公司为什么会吊销
  • 个体发票税率开错了怎么办
  • 加计抵减退税的会计分录
  • 哪些费用进项税额要转出
  • 所得税多交退回分录
  • mysql Event Scheduler: Failed to open table mysql.event
  • 交易性金融资产的入账价值
  • 工业企业制造费用具体怎么摊
  • 房租没发票怎么入账
  • 交房租会计分录怎么写好
  • 劳务公司到外地需要交的税
  • 无形资产达到可使用状态前如何入账
  • 装载机如何计提折旧费用
  • 总公司可以开发票给分公司吗
  • 银行汇票哪个科目
  • 计入福利费
  • phpmyadmin配置文件
  • mysql5.7.17安装
  • 数据库账号密码怎么修改
  • windows如何安装安卓软件
  • 解析包错误怎么解除
  • win8如何添加启动项
  • linux用户管理器在哪
  • win7安装ubuntu20.10
  • ubuntu装eclipse
  • 免安装版怎么用
  • win8.1开机进入桌面
  • node.js连接数据库的代码
  • perl 排序
  • Node.js中的全局变量有哪些
  • unity射击游戏完整功能代码
  • js判断checkbox是否被选中
  • bootstrap快速入门
  • java 视频教程
  • jQuery.Uploadify插件实现带进度条的批量上传功能
  • 大连税务局王局长
  • 小规模纳税人土地使用税减免政策
  • 所得税与增值税区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设