最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

糟糕的sql语句_MySQL

来源:动视网 责编:小采 时间:2020-11-09 18:35:48
文档

糟糕的sql语句_MySQL

糟糕的sql语句_MySQL:bitsCN.com 糟糕的sql语句 同事传过来一个sql,说此sql运行期间大量占用服务器磁盘空间,大约将近10个G的空间,效率超慢 SELECT MIN(order_id), MAX(order_id) FROM (select *,date(order_creation_date) create_dat
推荐度:
导读糟糕的sql语句_MySQL:bitsCN.com 糟糕的sql语句 同事传过来一个sql,说此sql运行期间大量占用服务器磁盘空间,大约将近10个G的空间,效率超慢 SELECT MIN(order_id), MAX(order_id) FROM (select *,date(order_creation_date) create_dat


bitsCN.com

糟糕的sql语句

同事传过来一个sql,说此sql运行期间大量占用服务器磁盘空间,大约将近10个G的空间,效率超慢

SELECT MIN(order_id), MAX(order_id) FROM (select *,date(order_creation_date) create_date from orders where (1 = 1) ) AS t1

1 又是一个糟糕的sql,select * from table_name 这种格式的sql是绝对不允许的

2 刚开始,没看明白这个sql是要干嘛的,为什么要从这个表里查询数据呢?select *,date(order_creation_date) create_date from orders where (1 = 1),作为嵌套表。

3 在查询过程中,为什么会占用磁盘空间

中间产生了临时表,内存中放不下这么多数据,把数据拷贝到磁盘中,一般在 /tmp 下面 产生类似 #sql_***.MYD,#sql_***.MYI 这样的文件,其实就是一个myisam表。

这样拷贝的过程浪费时间,影响性能。

咨询同事,只是想查询出order_id的最大值,最小值。 看了一下orders表结构,orders的order_id是自增主键,那就简单了, 直接改写如下

select max(order_id),min(order_id) from orders

order_id 是自增主键,上面已经建了索引,而且是有序的,因此对于max min这种复合函数求最大最少值非常的快。

bitsCN.com

文档

糟糕的sql语句_MySQL

糟糕的sql语句_MySQL:bitsCN.com 糟糕的sql语句 同事传过来一个sql,说此sql运行期间大量占用服务器磁盘空间,大约将近10个G的空间,效率超慢 SELECT MIN(order_id), MAX(order_id) FROM (select *,date(order_creation_date) create_dat
推荐度:
标签: 空间 服务器 sql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top