如何设计高效合理的MySQL查询语句_MySQL

作者&投稿:骆砍 (若有异议请与网页底部的电邮联系)
~
MySQL查询语句大家都在用,但是应该如何设计高效合理的MySQL查询语句呢?下面就教您MySQL查询语句的合理设计方法,分享给大家学习学习。

1.合理使用索引
索引是数据库中重要的数据结构,它的根本目的就是为了提高查询效率。现在大多数的数据库产品都采用IBM最先提出的ISAM索引结构。索引的使用要恰到好处,其使用原则如下:

●在经常进行连接,但是没有指定为外键的列上建立索引,而不经常连接的字段则由优化器自动生成索引。

●在频繁进行排序或分组(即进行group by或order by操作)的列上建立索引。

●在条件表达式中经常用到的不同值较多的列上建立检索,在不同值少的列上不要建立索引。比如在雇员表的“性别”列上只有“男”与“女”两个不同值,因此就无必要建立索引。如果建立索引不但不会提高查询效率,反而会严重降低更新速度。

●如果待排序的列有多个,可以在这些列上建立复合索引(compound index)。

●使用系统工具。如Informix数据库有一个tbcheck工具,可以在可疑的索引上进行检查。在一些数据库服务器上,索引可能失效或者因为频繁操作而使得读取效率降低,如果一个使用索引的查询不明不白地慢下来,可以试着用tbcheck工具检查索引的完整性,必要时进行修复。另外,当数据库表更新大量数据后,删除并重建索引可以提高查询速度。

2.避免或简化排序

应当简化或避免对大型表进行重复的排序。当能够利用索引自动以适当的次序产生输出时,优化器就避免了排序的步骤。以下是一些影响因素:

●索引中不包括一个或几个待排序的列;

●group by或order by子句中列的次序与索引的次序不一样;

●排序的列来自不同的表。

为了避免不必要的排序,就要正确地增建索引,合理地合并数据库表(尽管有时可能影响表的规范化,但相对于效率的提高是值得的)。如果排序不可避免,那么应当试图简化它,如缩小排序的列的范围等。

3.消除对大型表行数据的顺序存取

在嵌套查询中,对表的顺序存取对查询效率可能产生致命的影响。比如采用顺序存取策略,一个嵌套3层的查询,如果每层都查询1000行,那么这个查询就要查询10亿行数据。避免这种情况的主要方法就是对连接的列进行索引。例如,两个表:学生表(学号、姓名、年龄??)和选课表(学号、课程号、成绩)。如果两个表要做连接,就要在“学号”这个连接字段上建立索引。

还可以使用并集来避免顺序存取。尽管在所有的检查列上都有索引,但某些形式的where子句强迫优化器使用顺序存取。下面的查询将强迫对orders表执行顺序操作:

SELECT * FROM orders WHERE (customer_num=104 AND order_num>1001) OR order_num=1008


虽然在customer_num和order_num上建有索引,但是在上面的语句中优化器还是使用顺序存取路径扫描整个表。因为这个语句要检索的是分离的行的集合,所以应该改为如下语句:

SELECT * FROM orders WHERE customer_num=104 AND order_num>1001
UNION
SELECT * FROM orders WHERE order_num=1008


这样就能利用索引路径处理查询。

4.避免相关子查询

一个列的标签同时在主查询和where子句中的查询中出现,那么很可能当主查询中的列值改变之后,子查询必须重新查询一次。查询嵌套层次越多,效率越低,因此应当尽量避免子查询。如果子查询不可避免,那么要在子查询中过滤掉尽可能多的行。

5.避免困难的正规表达式

MATCHES和LIKE关键字支持通配符匹配,技术上叫正规表达式。但这种匹配特别耗费时间。例如:

SELECT * FROM customer WHERE zipcode LIKE “98_ _ _”


即使在zipcode字段上建立了索引,在这种情况下也还是采用顺序扫描的方式。如果把语句改为SELECT * FROM customer WHERE zipcode >“98000”,在执行查询时就会利用索引来查询,显然会大大提高速度。

另外,还要避免非开始的子串。例如语句:SELECT * FROM customer WHERE zipcode[2,3]>“80”,在where子句中采用了非开始子串,因而这个语句也不会使用索引。

6.使用临时表加速查询

把表的一个子集进行排序并创建临时表,有时能加速查询。它有助于避免多重排序操作,而且在其他方面还能简化优化器的工作。例如:

SELECT cust.name,rcVBles.balance,??other columns
FROM cust,rcvbles
WHERE cust.customer_id = rcvlbes.customer_id
AND rcvblls.balance>0
AND cust.postcode>“98000”
ORDER BY cust.name


如果这个查询要被执行多次而不止一次,可以把所有未付款的客户找出来放在一个临时文件中,并按客户的名字进行排序:

SELECT cust.name,rcvbles.balance,??other columns
FROM cust,rcvbles
WHERE cust.customer_id = rcvlbes.customer_id
AND rcvblls.balance>0
ORDER BY cust.name
INTO TEMP cust_with_balance


然后以下面的方式在临时表中查询:

SELECT * FROM cust_with_balance
WHERE postcode>“98000”


临时表中的行要比主表中的行少,而且物理顺序就是所要求的顺序,减少了磁盘I/O,所以查询工作量可以得到大幅减少。

注意:临时表创建后不会反映主表的修改。在主表中数据频繁修改的情况下,注意不要丢失数据。

7.用排序来取代非顺序存取

非顺序磁盘存取是最慢的操作,表现在磁盘存取臂的来回移动。SQL语句隐藏了这一情况,使得我们在写应用程序时很容易写出要求存取大量非顺序页的查询。有些时候,用数据库的排序能力来替代非顺序的存取能改进查询。





合理的设计有何重要性 举例说明不合理的设计带来的后果
通常意义上合理的设计就是所谓综合平衡了美观与功能,这是最基本的,要是没有平衡好带来的后果就是特别好看但是用起来很不方便或者造价异常高,或是很好用,但是非常难看,无法吸引眼球和人们的注意。当下所谓的合理设计就是要以人为本,从人使用、人性尺度和人心理暗示的角度去考虑。这个范畴非常广泛,简...

S给M分配小任务有何意义?
在实施小任务时,S需要注意任务的合理性,确保不给M带来过度的压力,同时,有效的沟通和协调至关重要,以确保双方对任务的理解一致。S可以通过多种方式下达任务,如口头指示、书面清单或利用远程控制技术,每种方式都有其优缺点,需要根据具体情况灵活选择。总的来说,S给M下达小任务在网恋中既是管理的...

怎样设计合理,明晰的教学目标
如果学生学习经过学习后反馈良好,基本达到了目标的要求,说明目标的设计符合学生的学情,是有效的。如果实施的结果与预先的设计相去甚远,那我们要回归到最初的目标,反思什么地方设计得还不合理,下一步应该如何去改进。通过设计——实施——反馈——反思——再设计不断地循环操练,教师的目标设计的能力...

S& M关系中,命令清单有何作用?
这份清单内容广泛,可能涵盖M的着装规定,如特定的服装或道具要求;行为规范,比如在特定情境下的行为表现;以及互动的界限,例如何时可以接受痛苦或何时需要停止。它的设计灵活性极高,S可以根据自身的喜好和对M承受能力的考量,量身定制这份清单,使之适应双方独特的喜好和需求。正确理解和执行命令清单对于...

小学语文常用的高效教学方法
3、巧妙设计疑问,激发学生好奇 心理学认为,只有学生感兴趣的东西才会激发他们的好奇心。常言道:"兴趣是最好的老师,是入门的向导。"语文老师在课堂上所提的问题的好坏直接影响学生学的效果。因此,老师所提的问题要与学生的兴趣紧密相连,投其所好,巧妙设计疑问,让他们的好奇心成为语文课堂上事倍功半的催化剂。我...

微‎生物实‎验室设计‎方案应该怎么做更合理?
在设计微生物实验室时,需要合理规划各个科室,一般包括准备室、微生物培养室、器械消毒及清洗室、纯水室、检测室、菌种室和储藏室等。为了确保安全,各个科室之间应设为独立区域,并设置隔离门。在重要的实验室中,还应设立缓冲区,以便进入实验室的人员可以在缓冲区进行二次清洁并更换衣物。实验室(包括...

10个UI设计的小技巧让你的作品更合理!
如果是为老年人或是手部受限的人群进行设计,我们就不需要太多的横向滑动。如果是在为通过键盘来与应用程序进行沟通的编程人员或是作家进行设计,那么我们需要支持所有常见的快捷键方式,以最大限度地减少鼠标使用时间。3. 设定预期 许多网站或是应用都会出现这样的情况:单击按钮就进入付款界面、删除网站或是一些不是很好...

请帮我设计一个初中生的作息时间表和合理的学习方法
合理的学习方法是要根据你个人的条件而定的,不是大家都认为好的就是好的,是要适合你的才是好的,你没介绍你的情况怎么给你设计。 已赞过 已踩过< 你对这个回答的评价是? 评论 收起 四方砚 2009-05-30 · TA获得超过1974个赞 知道答主 回答量:377 采纳率:0% 帮助的人:193万 我也去答题访...

如何合理的制定计划
2、结合实际,确定目标。   订计划时,不要脱离学习的实际,目标不能定得太高或过低,要依据:(1)知识、能力的实际;(2)“缺欠”的实际;(3)时间的实际;(4)教学进度的实际,确定目标,以通过自己的努力能达到为宜。 3、长计划,短安排。   要在时间上确定学习的远期目标、中期目标和近期目标...

有哪些好的合理化建议
3.合理的安排你的睡眠 不仅是在春节期间,就是在平时,充足的睡眠对于我们也是相当重要的,成年人每天最好睡7.5小时以上,16岁以下少年儿童则最好保持在9.5小时左右。 4.合理安排你的外出活动 春节期间走亲访友的当然属于常事,但是这里面也是有讲究的。初一一般是去亲戚们的长辈家,同龄或朋友家里;初二,要去拜...

察哈尔右翼中旗13654615517: 如何设计高效合理的MySQL查询语句 -
空薛妇乐: 举例来说,如果数据的量积累到一定的程度,比如一个银行的账户数据库表信息积累到上百万甚至上千万条记录,全表扫描一次往往需要数十分钟,甚至数小时.如果采用比全表扫描更好的查询策略,往往可以使查询时间降为几分钟,由此可见...

察哈尔右翼中旗13654615517: 如何提高mysql查询语句的书写能力 -
空薛妇乐: 举例来说,如果数据的量积累到一定的程度,比如一个银行的账户数据库表信息积累到上百万甚至上千万条记录,全表扫描一次往往需要数十分钟,甚至数小时.如果采用比全表扫描更好的查询策略,往往可以使查询时间降为几分钟,由此可见...

察哈尔右翼中旗13654615517: 请高手对现有mysql数据库设计一个高效率的查询 -
空薛妇乐: 查询日期的嘛,可以直接在sql语句中使用时间段啊.比如查询今年的 就“createDate >='2010-01-01' and createDate查询月份也可以这么做,比如查询1月份的:“createDate >='2010-01-01 and createDate 获取数量的话,可以用count 也可以直接用查询语句获得的符合条件的结果数.如果不清楚的话可以在线聊.

察哈尔右翼中旗13654615517: mysql 查询语句该怎么写 -
空薛妇乐: $sql = "SELECT * FROM `us12r` WHERE `sq23m` LIKE '%{$id}%'";$result = mysql_query($sql,$link); if (!$result) { exit("SQL语句执行失败!"); } 这是一个完整带执行的PHP操作MYSQL源代码.

察哈尔右翼中旗13654615517: mysql查询语句怎么写? -
空薛妇乐: 1 select* fromtablewherecourse_id = 'CS-101'groupbyid havingid notin(selectid fromtablewherecourse_id != 'CS-190'groupbyid)

察哈尔右翼中旗13654615517: 求帮写个mysql查询语句 -
空薛妇乐: SELECT a.id,a.username,COUNT(b.id) as sumUserID FROM users AS a ,n AS b where a.id=b.userid GROUP BY a.id order by sumUserID DESC 结果: a.id a.username sumUserID 1 a 2 2 b 1 3 c 1 4 d 1 可以取结果集中第一条记录,也可以用limit在sql语句中限制只显示第一个结果,但因为不同的数据库的limit有不同写法,隧未列出limit写法.

察哈尔右翼中旗13654615517: 优化SQL 查询:如何写出高性能SQL语句 -
空薛妇乐: 1、深入理解数据库的工作原理和数据存储的方式,不同的数据库的工作原理是不同的,mysql oracle db2等等都是不同的,更不要说一些nosql数据库和newsql数据库了. 2、理解sql语句检索数据的方式. 3、理解索引,知道怎样的字段建立怎...

察哈尔右翼中旗13654615517: 查询sql语句怎么写 -
空薛妇乐: MYSQL语句:select money from wage where employess_id='条件' and time between '起始日期' and '结束日期' 含义:查询用户ID在某个时间段的工资情况

察哈尔右翼中旗13654615517: 高效的MySql分页语句 -
空薛妇乐: select * from tbl_user where 主键 is not null limit 80,10------------------------------------------------------------ select * from tbl_user where 主键 符合什么条件 limit 80,10----------------------------------------------------------- select * from tbl_user where 索引列条件 limit 80,...

察哈尔右翼中旗13654615517: mysql常用查询语句 新手求帮助 -
空薛妇乐: select 商品名称 from 商品表 left join 商家表 on 商品表.商家id=商家表.id where 商家表.名称='xxxxxxxxxxxxxxxxxxxxxxxx';

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网