xml地图|网站地图|网站标签 [设为首页] [加入收藏]
当前位置: www8029com > 澳门新葡8522最新网站 > 正文

百万级数据库SQL优化大总结,关于iOS数据库大数

时间:2019-11-01 15:41来源:澳门新葡8522最新网站

网上关于SQL优化的教程很多,但是比较杂乱。近日有空整理了一下,写出来跟大家分享一下,其中有错误和不足的地方,还请大家纠正补充。

前言:

对于目前的iOS应用,大的数据量操作是一个不可避免的问题,本文仅对sqlite数据库大数据量操作进行优化策略:

这篇文章我花费了大量的时间查找资料、修改、排版,希望大家阅读之后,感觉好的话推荐给更多的人,让更多的人看到、纠正及补充。

优化规则:

1.对查询进行优化, 要尽量避免全表扫描, 首先应考虑在where及order by涉

及的列上建立索引。

2.应尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃

使用索引而进行全表扫描,如:

1select id from t where num is null

最好不要给数据库留NULL,尽可能的使用NOT NULL填充数据库.备注、描述、评论之类的可以设置为NULL,其他的,最好不要使用NULL。

不要以为NULL不需要空间,比如:char(100)型,在字段建立时,空间就固定

了, 不管是否插入值(NULL也包含在内),都是占用100个字符的空间的,如

果是varchar这样的变长字段,null不占用空间。

可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:1select id from t where num=0

3.应尽量避免在where子句中使用!=或<>操作符,否则将引擎放弃使用索

引而进行全表扫描。

4.应尽量避免在where子句中使用or来连接条件,如果一个字段有索引,一

个字段没有索引,将导致引擎放弃使用索引而进行全表扫描,如:

1select id from t where num=10 or Name='admin'

可以这样查询:

1select id from t where num=10 union all select id from t

where Name='admin'

5.in和not in也要慎用,否则会导致全表扫描,如:1select id from t where num in (1,2,3)对于连续的数值,能用between就不要用in了:

1select id from t where num between 1 and 3很多时候用exists代替in是一个好的选择:

1select num from a where num in (select num from b)

用下面的语句替换:

1select num from a where exists (select 1 from b where num

=a.num)

6.下面的查询也将导致全表扫描:

1s elect id from t where name like‘

编辑:澳门新葡8522最新网站 本文来源:百万级数据库SQL优化大总结,关于iOS数据库大数

关键词: www8029com