mysql中使用select的正确姿势你知道吗?
引言
大家在开发中,还有很多童鞋在写查询语句的时候,习惯写下面这种不规范sql
而不写成下面的这种规范方式
我也知道,这些童鞋是图方便,毕竟再敲一堆的列名,嫌麻烦!
你们上班可以问问自己的同事
我也知道,很多人至今都没有搞懂select *和selct 所有字段的区别
因此,我开一文来说明一下。另外,我选的是自己最熟悉的mysql数据库,此文的结论在oralce,sqlserver上是否成立,博主没做过测试。
正文
(select所有字段)性能高?
网络上流传着一种说法说是
然而,实际上呢?效率是相差不大的!。
取博客
http://flysnowxf.iteye.com/blog/1125032
的测试结果
mysql 5.1.37
表记录数41,547,002,即4000w行
使用远程客户端取1000条数据,统计时间:
时间2.218s,网络消耗0.547s
取出所有字段,时间2.250s,网络消耗0.578s
可以看出,这二者的时间差几乎可以忽略,另外还有一本书上的内容也可以佐证我的话。
《SQL CookBook》第一章 检索记录中1.1小节(原书第十五页内容如下):
此书也说明了,两种方式在性能上几乎是没有差距的。
那为什么还是不推荐select * ?
网络IO问题
很多文章里说什么,会带来额外的内存、磁盘、cpu的开销。对此,我有自己的观点。我觉得这不是主要原因。主要原因是带来了额外的网络开销。
在一个系统中,内存、磁盘、cpu的开销,不过是微秒级。造成系统的延迟的重头戏是网络开销。网络开销可能带来秒级的延迟。当然,如果你的应用程序和数据库是在同一台机器上的,那当我没说这句话!
select *会查询出不需要的、额外的数据,那么这些额外的数据在网络上进行传输,必定会造成性能延迟。假设你的table中,有一个列的类型为binary。此时,你的select *操作,就会十分缓慢,并且会造成额外的网络开销。
索引问题
仔细看下面的两句sql
如果col1字段包含索引信息,那么此时,这两句的sql执行时间可能会有几十上百倍的差异。
在col1字段有索引的情况下,mysql是可以不用读data,直接使用index里面的值就返回结果的。但是一旦用了select *,就会有其他列需要读取,这时在读完index以后还需要去读data才会返回结果。这样就造成了额外的性能开销。
ps:我不想在这里扯什么覆盖索引,辅助索引的概念。其实要讲的很专业,扯一堆高大上的名词,我也可以。只是这样徒增读者的理解难度,尽量用通俗的方式来讲。
扩展性问题
有的人会觉得
然而实际上,你的sql是不用改了,但是对你的程序代码是有很大的影响的!
身为一名21世纪的优良程序员,我们是不能获取自己需要的东西的!你因为一时高兴,执行了select *,如果增加或删除列,会对你的代码有着极大的影响。
反过来,如果你select 指定列,只获取自己需要的几列,表结构的修改,对你代码的影响就会小很多。相比之下,风险就没有那么大了!
另外就是,对于其他人接手你项目的人来说,看到select 指定列的方式,可读性更强,对于他们来说更好上手!
欢迎工作一到五年的Java工程师朋友们加入Java填坑之路:860113481
群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
深受程序员鄙视的外行语录,你被哪句话打击过?
最近,有几位程序员朋友,向我吐槽,经常有人和他说一些让他恼怒的话,他听完都想打人啦。我听完之后也是哭笑不得,将这些程序员朋友的话给整理出来了,大家以后在程序员面前说话可得小心点。 借此机会,今天给大家总结下,深受我们程序员鄙视的一些外行语录!让他们“反省”下! 01 头一条就是很多公司的招聘信息中写“公司内美女很多”,还配上所谓公司美女照片的。没人关心这个好吧。想用美色可以诱惑程序员来干活,程序员才没这么猥琐好吧! 2 你写软件?那你写个微信出来呗~ 你写网站?写个淘宝出来看看啊! 你学计算机的?那买些电子元件你能做出个电脑的吧? 对此,我**真想说:你会写汉字?咋不写个红楼梦出来!!!! 3 别给人打工了,你写点软件搞个专利,出来开公司呗~ 整天盯着电脑,辐射大,死得早吧? 你们理工科的,情商很低吧? 对此,我还想说:嗯,听你说话看得出来你情商很高! 04 以及这些: 帮我抢个火车票/抢个单/抢个红包/抢个小米呗! 帮我下个XXX软件/装个软件/装机/清理内存吧! 我密码忘了,你帮我找回来。 你知道我开机密码/邮箱密码/QQ密码是多少吗? 我邮箱被盗了,你帮我盗回来。 我不小心删了x...
- 下一篇
ADO.net学习
<1>在VS2017中建立Windows 窗体应用(.NET Framework)项目。 <2>在解决方案资源管理器中,打开Form1.cs,主题窗口会出现Form1.cs[设计]的标题。 <3>打开工具栏,找到Button控件,将该控件拖拽到设计面板中,右键这个控件,点击属性,在Text栏目中输入该按钮的名称。在"设计"的(Name)栏目中输入该按钮的响应函数的名字。我设计的是:btnCreateConnection。软后双击这个按钮,就会转向Form.cs中的btnCreateConnection_Click。也就是该按钮的点击的响应函数。设置这个函数的目的是第一次连接数据库。 <4>[注:本文连接的是SQLserver数据库]。 <5>增加命名空间: System.Data.SqlClient命名空间是用于 SQL Server 的 .NET 数据提供程序 System.Data.Common用于使用DbConnection,DbCommand,DbDataReader类等。 System.Configuration命名...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS8编译安装MySQL8.0.19
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Red5直播服务器,属于Java语言的直播服务器
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作