java开发之简单的数据库优化,sql优化

做开发快4年从刚开始功能模块开发到后期的代码优化,数据库优化、重构等,慢慢的在需求开发阶段就养成了一些开发习惯,接下来就说下我自己的一些见解和习惯。目前想到的就这些简单明了的优化,持续更新吧

 

1、在项目中经常会遇见一个繁琐的sql,多表关联尽量不要超过3个表

2、SELECT子句中不要使用“ * ”

在绝大多数情况下,使用星号是一种糟糕的编程习惯。数据库在解析的过程中, 会将“ * ” 依次转换成所有的列名, 这个工作是通过查询数据字典完成 的, 这意味着将耗费更多的时间。它会进行全表扫描,不能有效利用索引,增大了数据库服务器的负担,以及它与应用程序客户端之间的网络IO开销。

3、项目中减少访问数据库的次数

因为频繁的对数据库操作将影响其他正常用户的访问。对数据库的访问会牵涉到磁盘IO的操作,经过一段时间分析发现网站性能差主要是在数据的读写。并且每次读数据库的更新操作会写日志,减少不必要的磁盘写入。

总之能有效批量获取的数据不要一个一个获取,能查一次的不要查多次,减少额外的数据库访问。

4、用 WHERE 子句替换 HAVING 子句

避免使用 HAVING 子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤。这 个处理需要排序,总计等操作。如果能通过 WHERE 子句限制记录的数目,那就能减少这 方面的开销。

5、减少对表的查询

在含有子查询的 SQL 语句中,要特别注意减少对表的查询.例子:SELECT TAB_NAME FROM TABLES WHERE (TAB_NAME,DB_VER) = (SELECT TAB_NAME,DB_VER FROM TAB_COLUMNS WHERE VERSION=604)

6、通过内部函数提高 SQL 效率

7、使用表的别名

当在 SQL 语句中连接多个表时,使用表的别名并把别名前缀于每个 Column 上。这样 一来,就可以减少解析的时间并减少那些由 Column 歧义引起的语法错误。

8、用有效索引提高sql的执行效率

如果有 order by 的场景,请注意利用索引的有序性;建组合索引的时候,区分度最高的在最左边;

9、还有一些:选择最有效的表名顺序、WHERE子句中的连接顺序、sql语句大写等,最新版本的数据库渐渐不用考虑这些了,但这个习惯我还一直保持着。

 

 

不积跬步,无以至千里;不积小流,无以成江海。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值