mysql varchar 非空判断_工资从1万到3万,你还差mysql数据库优化之系列三

查询性能的优化

优化查询分析的步骤:

1.应用查询是否检索超过需要的数据

2.mysql服务器是否在分析超过需要的数据

正确使用索引:

1.like语句操作

一般不使用%或_开头例如: select * from tableName where name like '%cn';只能使用like 'aaa%';

2.组合索引

例如索引index index_name (a, b, c)  只支持a 或 a, b 或 a, b, c者三种组合,不支持b,c, 最左前缀

3.避免在where子句中对null进行判断

例如:select id from t where num is null修改:可以num上设置默认值为0select id from t where num=0;

4.尽量避免使用where子句使用!=,<>,or

5.in和not in也要谨慎使用

例如:select id from t where num in(1,2,3);修改:对于连续的数值,可以使用betweenselect id from t where num between 1 and 3;

6.如果在where子句中使用参数,也会导致全表扫描

mysql在运行时候才会解析变量,sql语句的优化在编译的时候就进行了,但是编译的时候这个变量还是未知的例如: select id from t where num=@num;修改:强制使用索引select id from t with(index(索引名)) where num=@num;

7.尽量避免在where子句的=左面进行运算

例如:select id from t where num/2=100;修改:select id from t where num = 100*2;例如:select id from t where substring(name, 1, 3)='abc';修改:select id from t where name like 'abc%';
eb3d3cc9ce9def325def404991176908.png

其他的优化点:

1.尽量使用数字类型的字段

2.把ip存储为unsigned int

使用int类型4个字节,比char/varchar更节省空间,查询时候也会占用优势

3.在join表要使用相当类型的列,并将其建立索引

例如:select * from users left join company on users.state=company.state两个state都要建立索引,并且使用相当类型,使用相同的字符集

4.尽量避免使用order by rand()

例子: explain select * from test order by rand();

5.避免使用select *

6.一定要为每张表设置id为主键,最好是int类型,并且最好设置auto_increment

7.优化count()查询

统计某列值的数量,要求列值为非空,也就是不会统计null统计行数如果确定count()没有空值,实际是在统计行数统计行数时候直接使用count(*)

8.不要添加冗余或者是重复索引,删除长期不用的索引

例如:创建了联合索引(A,B), 不要再单独为(A)创建索引

9.尽量避免使用游标,因为通常情况下游标的效率比较差

10.尽量避免大事务操作,会降低并发性能

11.优化or条件

例如:create table test6(id int not null,name varchar(20) not null,index index_id (id),index index_name(name))插入数据:insert into test6 values(1, 'zhangsan');insert into test6 values(2, 'lisi');使用or查询:explain select * from test6 where id=1 or name='lisi';使用union all优化explain select * from test6 where id=1 union all select * from test6 where name='lisi';

12.优化分页查询(limit)

例子:创建表:create table test7(id int not null,username varchar(16) not null,index index_id(id))插入100000条数据的函数:DELIMITER #CREATE PROCEDURE pro2()BEGIN DECLARE i INT DEFAULT 0; WHILE i<10000 DO  INSERT INTO test7 VALUES(i, CONCAT('aa', i));    SET i=i+1; END WHILE;END #调用函数CALL pro2();分页查询数据:explain select * from test7 order by id limit 1000, 20;优化:explain select * from test7 inner join (select id from test7 order by id limit 1000, 20) as o using(id);上面的优化可以改写为:explain select * from test7 t inner join (select id from test7 order by id limit 1000, 20) as o on t.id=o.id;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/245527.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

etl数据抽取工具_数据同步工具ETL、ELT傻傻分不清楚?3分钟看懂两者区别

什么是数据同步工具(ETL、ELT)数据同步工具ETL或者ELT的作用是将业务系统的数据经过抽取、清洗转换之后加载到数据仓库的过程&#xff0c;目的是将企业中的分散、零乱、标准不统一的数据整合到一起&#xff0c;为企业的决策提供分析依据。数据同步是大数据项目重要的一个环节。…

oracle数据库查表_Oracle面试问题-技术篇

这也许是你一直期待的文章&#xff0c;在关注这部分技术问题的同时&#xff0c;请务必阅读有关面试中有关个人的问题和解答。和猎萝卜小编来一起了解。这里的回答并不是十分全面&#xff0c;这些问题可以通过多个角度来进行解释&#xff0c;也许你不必在面试过程中给出完全详尽…

uniapp怎么调起摄像头拍视频_抖音视频怎么拍?我们总结了10个手机视频拍摄小技巧...

抖音的很多功能与小咖秀类似,但不同的是,抖音用户可以通过视频拍摄的快慢、视频编辑和特效等技术让作品更具创造性,而不是简单地对嘴型。抖音短视频的10个拍摄技巧,帮助你方便、快捷地制作出更加优质的短视频内容。1.远程控制暂停更方便抖音视频怎么拍&#xff1f;在拍摄时,如果…

jdk 安装_Jdk 安装使用教程

java 程序员的第一个程序 hello worldpublic class MyFirstJavaProgram {public static void main(String []args) {System.out.println("Hello World");}}1、下载jdk连接地址&#xff1a;https://docs.oracle.com/javase/8/docs/technotes/guides/install/install_o…

win10计算机管理字体糊,win10字体模糊如何解决

win10系统是一款优秀的消费级别的系统&#xff0c;深受大家广泛好评。但是有些网友在使用时也会出现一些问题&#xff0c;比如win10字体模糊。接下来&#xff0c;我就给大家介绍一下解决win10字体模糊的解决方法&#xff0c;赶紧来瞧瞧吧近来有不少网友询问win10字体模糊的解决…

蓝字冲销是什么意思_梦见上学 做梦梦到上学是什么意思 梦到上学有哪些预兆...

点击上方蓝字关注我们 查看更多梦见上学是什么意思 做梦梦到上学是什么意思 梦到上学有哪些预兆梦见上学 做梦梦到念书是什么意思 梦见上学代表什么意思预兆梦见上学&#xff0c;吉兆&#xff0c;生活会幸福快乐。梦见上学&#xff0c;可能是因为你近期的生活工作压力导致的&am…

ffmpeg如何在结尾添加帧_一种“视频帧对齐”的测试方案实践

点击蓝字?关注【测试先锋】&#xff0c;不再迷路&#xff01;一起成为互联网测试精英&#xff0c;前瞻测试技术&#xff5e;导语全参考清晰度测算的时候&#xff0c;输入两个视频帧序列&#xff0c;但是视频帧序列没有对齐&#xff0c;怎么知道丢了哪帧&#xff1f;又怎么知道…

java mongo分组统计_探秘 Dubbo 的度量统计基础设施 - Dubbo Metrics

对服务进行实时监控&#xff0c;了解服务当前的运行指标和健康状态&#xff0c;是微服务体系中不可或缺的环节。Metrics 作为微服务的重要组件&#xff0c;为服务的监控提供了全面的数据基础。近日&#xff0c;Dubbo Metrics 发布了2.0.1版本&#xff0c;本文将为您探秘 Dubbo …

python可以做运动控制卡吗_今天,终于明白了运动控制器和运动控制卡的区别

原标题&#xff1a;今天&#xff0c;终于明白了运动控制器和运动控制卡的区别 运动控制器是完整的、独立的硬件平台&#xff0c;运动控制卡则需要一个载体(一个系统运行平台&#xff0c;必须基于PC)。 一、从安装使用方式来看 运动控制卡&#xff0c;一般是PCI插槽的&#xff0…

电子计算机技能竞赛数据,2015年浙江省中等职业学校计算机应用技术专业学生职业技能大赛“计算机检测维修与数据恢复”赛项规程.doc...

2015年浙江省中等职业学校计算机应用技术专业学生职业技能大赛“计算机检测维修与数据恢复”赛项规程.doc还剩8页未读&#xff0c;继续阅读下载文档到电脑&#xff0c;马上远离加班熬夜&#xff01;亲&#xff0c;喜欢就下载吧&#xff0c;价低环保&#xff01;内容要点&#x…

设备的dpr_湘潭污水处理设备_处理污水设备生产厂

湘潭污水处理设备_处理污水设备生产厂?氮磷过度排放导致水体富营养化仍是全球关注的水污染热点问题, 而对于传统城市污水处理厂来说, 污水的深度脱氮除磷和同步达标排放仍是需要攻克的难点问题.传统脱氮除磷工艺存在脱氮与除磷对有限碳源的竞争、硝化反应产物对厌氧释磷的抑制…

奥鹏大工17秋计算机文化基础,大工17秋《数字电路与系统》在线作业100分满分答案...

大工17秋《数字电路与系统》在线作业1一、单选题&#xff1a;1.实现与运算功能的逻辑器件称为( )。 (满分:5)A.与门B.或门C.非门D.与或门正确答案:——A——2.变量每增加一个&#xff0c;其函数卡诺图的小格数就增加( )倍。 (满分:5)A.0.5B.1C.1.5D.2正确答…

git 32位_编译64位的BorderlessGaming

BorderlessGaming确实是一款很好用的工具,我主要用来把AS的模拟器全屏,来把Surface当安卓平板用,但是这东西的官方Release和Steam版本都是32位的,不过好在它开源,那就自己动手魔改一份吧首先把源码clone到本地git clone https://github.com/Codeusa/Borderless-Gaming.git用VS打…

十分钟计算机说课稿,足球十分钟说课稿范文(精选3篇)

足球十分钟说课稿范文(精选3篇)作为一位杰出的老师&#xff0c;常常要写一份优秀的说课稿&#xff0c;编写说课稿助于积累教学经验&#xff0c;不断提高教学质量。怎样写说课稿才更能起到其作用呢&#xff1f;以下是小编为大家整理的足球十分钟说课稿范文&#xff0c;欢迎阅读与…

主叫号码未显示怎么设置_微信未授权抖音,应该怎么设置?

微信未授权抖音&#xff0c;应该如何设置&#xff1f;这篇文章&#xff0c;笔点酷玩手把手教你完成。首先我们要明确&#xff0c;这种设置属于将微信账户的授权给第三方&#xff0c;用于统一身份的登录&#xff0c;需要用户自己手动授权“绑定”&#xff0c;也可以随时进行解绑…

eclipse没有日志_「开源资讯」Jboot v3.3.6 发布,更强大的控制台请求日志

Jboot 是一个基于 JFinal、JFinal-Undertow、Dubbo、Seata、Sentinel、ShardingSphere、Nacos 等开发的微服务框架&#xff0c;帮助开发者降低微服务开发门槛。同时完美支持在 idea、eclipse 下多 maven 模块&#xff0c;对 java 代码、html、css、js 等资源文件进行热加载。爽…

计算机地址码特点,电脑摇头灯的地址码的设定问题你必须要注意的

原标题&#xff1a;电脑摇头灯的地址码的设定问题你必须要注意的在上一期文章中&#xff0c;我们广州舞台灯光设备批发厂家歌斯达为大家分享了电脑摇头灯的供电电源问题和信号线问题之后&#xff0c;这一次的文章&#xff0c;我们将继续为大家分享更多关于电脑摇头光束灯的相关…

java项目经验怎么写_模具工简历项目经验怎么写

项目经验(案例一)项目时间&#xff1a;2015-04 - 2015-05项目名称&#xff1a;活动策划项目描述&#xff1a;项目介绍通过策划一系列的活动来提高家具店的知名度&#xff0c;从而拔高家具店正式开业后的销售额。我的职责协助经理完成开业前后的活动策划以及提出个人见解&#x…

freemaker if 多个条件_第4天|14天搞定Vue3.0,条件渲染和template

所谓的条件&#xff0c;指的就是满足什么条件&#xff0c;允许做什么事&#xff0c;不满足时&#xff0c;是不允许做的。如共享单车&#xff0c;规定满12周岁或以上才可以骑行&#xff0c;没满的则不被允许。学每门编程语言&#xff0c;条件语句都是必须熟练掌握的&#xff0c;…

服务器用户配置文件在哪里找,管理远程桌面服务的用户配置文件

用户配置文件描述特定用户的配置&#xff0c;包括用户的环境和首选项设置。除非在 RD 会话主机 服务器环境中认真地规划和管理用户配置文件&#xff0c;否则&#xff0c;用户配置文件可能会变大&#xff0c;在用户连接到 RD 会话主机 服务器时可能会造成问题&#xff0c;例如登…