• 开发DBA(APPLICATION DBA)的重要性



    开发DBA是干什么的?

    1. 审核开发人员写的SQL,并且纠正存在性能问题的SQL ---非常重要

    2. 编写复杂业务逻辑SQL,因为复杂业务逻辑SQL开发人员写出的SQL基本上都是有性能问题的,与其让开发人员写,不如DBA自己写。---非常重要

    3. 参与DB 设计,尽早纠正不合理的DB 设计,ORACLE的性能是设计出来的,而不是调出来滴 ---这块非常重要

    4. 对ORACLE进行基本的维护。

    5. 与应用架构师配合,并且纠正应用架构师所犯错误,其实开发DBA 也带有应用架构师的角色

    6. 对整个数据库进行高效的设计与规划,这个工作不能交给运维DBA, 因为运维不了解业务。

    无法想象,没有开发DBA的公司,设计出来的系统性能不知道有多烂。

    举个小例子

    最近遇到个SQL 跑的很慢,第一次12秒出结果(从磁盘读入内存),第二次2秒出结果(数据都在buffer cache里面),SQL代码如下

    SELECT COUNT(0) FROM P LEFT JOIN R ON P.ID = R.ID;
    


    P 有200W 数据 R 有 100W 数据。这个SQL 第一次跑12秒,肯定无法接受。 那么大家看看这个SQL如何优化?

    其实这个SQL写得有问题, 这里是外连接,并且求COUNT(*) 还有,JOIN字段是ID,ID 一般都是主键,那么这个SQL完全可以改写 为

    SELECT COUNT(0) FROM P;
    

    改写之后 COUNT(*) 直接读取 P表主键,0.1秒--1秒出结果,当然了,请注意,如果R表ID不是主键,并且R表ID 有重复值,COUNT(*) 会变大 ,不能这么改写

    最初的SQL写得确实有问题,但是我们不能怪开发,因为别人毕竟对SQL理解不是那么专业,所以必须要有开发DBA把关。

    大家可以想象一下,要是没开发DBA,当P表以及R表数据量增长到千万级/亿级,那得多慢啊。

    仅以这个小例子,说明开发DBA的重要性,最近做了很多优化,基本上线上所有SQL都控制在1秒内返回结果。

     


     

  • 相关阅读:
    CSS3的常用属性(一)
    Shiro授权认证原理和流程
    mysql存储引擎
    mysql索引的注意事项
    CSS的常用属性(三)
    CSS的常用属性(二)
    CSS的常用属性(一)
    常用文档站点
    Spring和SpringMVC父子容器关系初窥
    内部类学习资料分享
  • 原文地址:https://www.cnblogs.com/hehe520/p/6330540.html
Copyright © 2020-2023  润新知