mysql查询优化

本文探讨了如何优化SQL查询以提高数据库性能。建议避免在WHERE子句中使用函数,如避免`F1/2=100`,而应写为`F1=100*2`。使用`EXISTS`代替`IN`语句可提高效率。推荐减少对数据库的访问次数,限制结果集大小,并避免数据类型不兼容。合理利用索引和简化查询结构也是关键。此外,避免在不必要时使用通配符,如`SELECT * FROM T1`,应按需选择列。
摘要由CSDN通过智能技术生成

#比如:计算id大于5的城市 
#a语句 
select count(*) from world.city where id > 5;
#b语句
select (select count(*) from world.city) – count(*) from world.city where id <= 5; 
 
#a语句当行数超过11行的时候需要扫描的行数比b语句要多, 
#b语句扫描了6行,此种情况下,b语句比a语句更有效率。
#当没有where语句的时候直接select count(*) from world.city这样会更快,因为mysql总是知道表的行数。避免使用不兼容的数据类型
例如float和int、char和varchar、binary和varbinary是不兼容的。
        数据类型的不兼容可能使优化器无法执行一些本来可以进行的优化操作。
         在程序中,保证在实现功能的基础上,尽量减少对数据库的访问次数;通过搜索参数,尽量减少对表的访问行数,最小化结果集,从而减轻网络负担;能够分开的操作尽量分开处理,提高每次的响应速度;在数据窗口使用SQL时,尽量把使用的索引放在选择的首列;
        算法的结构尽量简单;在查询时,不要过多地使用通配符如 SELECT * FROM T1语句,要用到几列就选择几列如:SELECT COL1,COL2 FROM T1;
        在可能的情况下尽量限制尽量结果集行数如:SELECT TOP 300 COL1,COL2,COL3 FROM T1,因为某些情况下用户是不需要那么多的数据的。
        不要在应用中使用数据库游标,游标是非常有用的工具,但比使用常规的、面向集的SQL语句需要更大的开销;按照特定顺序提取数据的查找。
#数据不兼容会拉低效率
INSERT INTO cnt(id)VALUES(11.1)#尽量避免在WHERE子句中对字段进行函数或表达式操作,这将导致引擎放弃使用索引而进行全表扫描。
#如: 
SELECT * FROM T1 WHERE F1/2=100 
#应改为: 
SELECT * FROM T1 WHERE F1=100*2

#因为这会使系统无法使用索引,而只能直接搜索表中的数据。
#例如: 
SELECT id FROM employee WHERE id != “B%” 
#优化器将无法通过索引来确定将要命中的行数,因此需要搜索该表的所有行。
#在in语句中能用exists语句代替的就用exists.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值