#比如:计算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.