程序员,你还在 Select * 吗?

应用程序慢如牛,原因多多,可能是网络的原因、可能是系统架构的原因,还有可能是数据库的原因。

那么如何提高数据库SQL语句执行速度呢?有人会说性能调优是数据库管理员(DBA)的事,然而性能调优跟程序员们也有莫大的关系。

程序员,你还在 Select * 吗?

程序中嵌入的一行行的SQL语句,如果使用了一些优化小技巧,定能达到事半功倍的效果。

技巧1 比较运算符能用 “=”就不用“<>”

“=”增加了索引的使用几率。

技巧2 明知只有一条查询结果,那请使用 “LIMIT 1”

“LIMIT 1”可以避免全表扫描,找到对应结果就不会再继续扫描了。

技巧3 为列选择合适的数据类型

能用TINYINT就不用SMALLINT,能用SMALLINT就不用INT,道理你懂的,磁盘和内存消耗越小越好嘛。

技巧4 将大的DELETE,UPDATE or INSERT 查询变成多个小查询

能写一个几十行、几百行的SQL语句是不是显得逼格很高?然而,为了达到更好的性能以及更好的数据控制,你可以将他们变成多个小查询。

程序员,你还在 Select * 吗?

技巧5 使用UNION ALL 代替 UNION,如果结果集允许重复的话

因为 UNION ALL 不去重,效率高于 UNION。

技巧6 为获得相同结果集的多次执行,请保持SQL语句前后一致

这样做的目的是为了充分利用查询缓冲。

比如根据地域和产品id查询产品价格,第一次使用了:

程序员,你还在 Select * 吗?

那么第二次同样的查询,请保持以上语句的一致性,比如不要将where语句里面的id和region位置调换顺序。

技巧7 尽量避免使用 “SELECT *”

如果不查询表中所有的列,尽量避免使用 SELECT *,因为它会进行全表扫描,不能有效利用索引,增大了数据库服务器的负担,以及它与应用程序客户端之间的网络IO开销。

程序员,你还在 Select * 吗?

技巧8 WHERE 子句里面的列尽量被索引

只是“尽量”哦,并不是说所有的列。因地制宜,根据实际情况进行调整,因为有时索引太多也会降低性能。

技巧9 JOIN 子句里面的列尽量被索引

同样只是“尽量”哦,并不是说所有的列。

技巧10 ORDER BY 的列尽量被索引

ORDER BY的列如果被索引,性能也会更好。

技巧11 使用 LIMIT 实现分页逻辑

不仅提高了性能,同时减少了不必要的数据库和应用间的网络传输。

技巧12 使用 EXPLAIN 关键字去查看执行计划

EXPLAIN 可以检查索引使用情况以及扫描的行。

其他

SQL调优方法有很多种,同样的查询结果可以有很多种不同的查询方式。其实最好的方法就是在开发环境中用最贴近真实的数据集和硬件环境进行测试,然后再发布到生产环境中。

转载于:https://www.cnblogs.com/CQqf2019/p/11187128.html

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

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

相关文章

学习笔记-记ActiveMQ学习摘录与心得(二)

上个周末被我玩过去了&#xff0c;罪过罪过&#xff0c;现在又是一个工作日过去啦&#xff0c;居然有些烦躁&#xff0c;估计这几天看的东西有点杂&#xff0c;晚上坐下来把自己首要工作任务总结总结。上篇学习博客讲了ActiveMQ的特性及安装部署&#xff0c;下面先把我以前启动…

matlab删除、创建文件夹

在某一目录下&#xff0c;创建名字为1、2、3、4、5的五个文件夹&#xff1a; for i1:5 file_name sprintf(%s,num2str(i)); file_path_name strcat(savepath,file_name); file_path_name_ strcat(file_path_name,\); if exist(file_path_name_)0 %该文件…

谈谈C#中的三个关键词new , virtual , override(装载 Winner.Net)

C#支持单继承&#xff0c;说到继承就不得不说new&#xff0c;virtual和override这三个关键词&#xff0c;灵活正确的使用这三个关键词&#xff0c;可以使程序结构更加清晰&#xff0c;代码重用性更高。 以下是msdn中对new&#xff0c;virtual和override的定义&#xff1a; …

不同类型数据所占的字节数

以下内容源于网络资源的学习与整理&#xff0c;如有侵权请告知删除。 数据类型的长度&#xff08;所占的字节数&#xff09;&#xff0c;与机器字长及编译器都有关系。 所以&#xff0c;int、long int、short int等数据类型的长度可能随编译器而异。 几条铁定的原则&#xff08…

物联网概念升级,万物互联来袭

物联网概念尚在升温&#xff0c;万物互联又袭来。本月中旬&#xff0c;知名IT研究与咨询公司Gartner在2013 GartnerSymposium/Itxpo全球大会上向大家分享了他们对2014科技趋势的预测。在会上&#xff0c;Gartner提及的“万物互联”概念倍受科技界媒体关注。Gartner认为&#xf…

java遍历实体类的属性名称与值

//循环遍历OaInfoAssess实体中的属性与值for (Field field : oaInfoAssess.getClass().getDeclaredFields()){ //设置可以获取私人属性 field.setAccessible(true); try { Class type field.getType();// 得到此属性的类型 if(type String.class){ /…

unsigned char s1 : 2的用法

#include<stdio.h> #include<stdlib.h> //默认按照四字节对齐 //#pragma pack(1) union V {struct X{unsigned char s1 : 2;unsigned char s2 : 3;unsigned char s3 : 3;} x;unsigned char c; } v; //#pragma pack()int main(void) {v.c 100;//对应的二进制数字是…

MATLAB中排序函数sort()的用法

MATLAB中排序函数sort()可以对参数的元素进行升序排序或降序排序。 具体的用法如下&#xff1a; Ysort(X) sort()的参数可以是向量&#xff0c;矩阵&#xff0c;数组等等。当X是向量时&#xff0c;sort(X)对X的元素进行升序排序&#xff1b;当X是矩阵时&#xff0c;sort(X)对…

juc线程池原理(六):jdk线程池中的设计模式

一、jdk中默认线程池中的代理模式 单例类线程池只有一个线程&#xff0c;无边界队列&#xff0c;适合cpu密集的运算。jdk中创建线程池是通过Executors类中提供的静态的方法来创建的&#xff0c;其中的单例类线程池的方法如下&#xff1a; public static ExecutorService newSin…

Code First :使用Entity. Framework编程(6) ----转发 收藏

Chapter6 Controlling Database Location,Creation Process, and Seed Data 第6章 控制数据库位置&#xff0c;创建过程和种子数据 In previous chapters you have seen how convention and configuration can be used to affect the model and the resulting database schema.…

Hashtable的测试

Hashtable的测试 1 import java.util.Enumeration;2 import java.util.Hashtable;3 4 class TT {5 private String name null; //name和age是作为键的6 private Integer age 0;7 8 public TT(String name,int age) { //构造函数没有返回值9 this.nam…

截取AVI格式的视频C语言代码

首先在阅读本代码之前百度一下avi&#xff0c;虽然经过我验证上面有部分错误&#xff0c;但是不影响阅读。因为有些变量的注释我没有写&#xff0c;所以请读者自行搜索吧。下面是c语言文件&#xff0c;编译之后能够直接运行&#xff0c;用来截取开始时间&#xff08;单位s&…

C语言宏定义中UL的含义

1、U表示 unsigned 无符号&#xff0c;L表示 long 长整数。后缀大小写都可以&#xff0c;可以单独使用(100U)&#xff0c;也可以组合使用(100UL)。 2、F表示float&#xff0c;但是F不可以和U组合&#xff0c;因为浮点数没有unsigned。 3、后缀的作用是指明数据类型。因为单独…

查看CPU信息

1、查看物理cpu个数[rootwebserver ~]# cat /proc/cpuinfo|grep "physical id"|sort|uniq|wc -l 11. 查看物理CPU的个数#cat /proc/cpuinfo |grep "physical id"|sort |uniq|wc -l2. 查看逻辑CPU的个数#cat /proc/cpuinfo |grep "processor"|wc …

计算多个文档之间的文本相似程度

首先我们上代码&#xff1a; from sklearn.feature_extraction.text import CountVectorizer corpus [ UNC played Duke in basketball, Duke lost the basketball game, I ate a sandwich ] vectorizer CountVectorizer(binaryTrue,stop_wordsenglish)#设置停用词为英语&…

判断操作系统的位数

#include<stdio.h>int main(void) {unsigned int num ~0;if (num 0xffffffff)printf("32");elseif (num 0xffff)printf("16");elseprintf("64");getchar();return 0; } 以上是判断一个操作系统是多少位的代码。 附另一种解法&#xf…

几个ubuntu16.04镜像下载地址

中科大源 http://mirrors.ustc.edu.cn/ubuntu-releases/16.04/ 阿里云开源镜像站 http://mirrors.aliyun.com/ubuntu-releases/16.04/ 兰州大学开源镜像站 http://mirror.lzu.edu.cn/ubuntu-releases/16.04/ 北京理工大学开源 http://mirror.bit.edu.cn/ubuntu-releases…

转】未指定 INSTANCESHAREDWOWDIR 命令行值。如果指定INSTANCESHAREDDIR 值,则必须指定该值 ....

插入光盘后不要用autorun的安装&#xff0c;使用命令行安装&#xff01;cd进安装光盘的根目录&#xff0c;输入命令&#xff1a;setup.exe /INSTALLSHAREDDIR"D://Program Files//Microsoft SQL Server//" /INSTALLSHAREDWOWDIR"D://Program Files (x86)//Micro…

C#使用StreamReader类读取文件文件

输入流用于从外部源读取数据。在很多情况下&#xff0c;数据源是磁盘上的文件或网络的某些位置。任何可以发送数据的位置都可以是数据源&#xff0c;比如网络应用程序、Web服务&#xff0c;甚至是控制台。 用来从文件中读取数据的类是StreamReader。同StreamWriter一样&#xf…

三种不使用中间参数,交换两个参数的值的方法

第一种&#xff1a;要求必须是整数 int i 50&#xff0c;j 60&#xff1b; i i^j; j i^j; i i^j;第二种&#xff1a;可以不是整数类型 i i j; j i - j; i i - j;第三种&#xff1a;很巧妙 i i j - (j i);