• 语音交友APP源码中MySQL数据库开发的6个“避免”


    由于在语音交友APP源码中需要进行MySQL数据库的开发,而MySQL数据库开发又会涉及到许多操作,所以要尽量避免在语音交友APP源码开发中出现相关的错误,以下就是应该避免的问题。

    1、避免在数据库中做运算

    有句话叫做“别让脚趾头想事情,那是脑瓜子的职责”,用在数据库开发中,说的就是避免让语音交友APP源码的数据库做她不擅长的事情。MySQL并不擅长数学运算和逻辑判断,所以尽量不在语音交友APP源码数据库做运算,复杂运算可以移到程序端CPU。

    2、避免对索引列做运算
    有次,有位同事让我看一条SQL,说是在前台查询很快,但是把SQL取出来,在数据库中执行的时候,跑10分钟都不出结果。
    看了一下SQL,最后定位到一个视图中的一个子查询上面。该子查询的SQL文本如下:

    SELECT  acinv_07.id_item ,
            SUM(acinv_07.dec_endqty) dec_endqty
    FROM    acinv_07
    WHERE   acinv_07.fiscal_year * 100 + acinv_07.fiscal_period 
            = ( SELECT DISTINCT
                       ctlm1101.fiscal_year * 100 + ctlm1101.fiscal_period
                       FROM ctlm1101 WHERE flag_curr = 'Y'
                       AND id_oprcode = 'acinv'
                       AND acinv_07.id_wh = ctlm1101.id_table)
    GROUP BY acinv_07.id_item
    
    

    在acinv_07表上的列fiscal_year和列fiscal_period是有索引的。但是,如果对索引列进行运算,就会导致原本可以走索引的走不了索引。于是,动手改写成如下SQL:

    SELECT    id_item ,
                        SUM(dec_qty) dec_qty
              FROM      dpurreq_03
              GROUP BY  id_item
            ) a ,
            ( SELECT    a.id_item ,
                        SUM(a.dec_endqty) dec_endqty
              FROM      acinv_07 a ,
                        ( SELECT DISTINCT
                                    ctlm1101.fiscal_year ,
                                    ctlm1101.fiscal_period ,
                                    id_table
                          FROM      ctlm1101
                          WHERE     flag_curr = 'Y'
                                    AND id_oprcode = 'acinv'
                        ) b
              WHERE     a.fiscal_year = b.fiscal_year
                        AND a.fiscal_period = b.fiscal_period
                        AND a.id_wh = b.id_table
              GROUP BY  a.id_item
    
    

    再执行,4s钟左右就可以跑出结果了。
    总的来说,在语音交友APP源码中写SQL时,不到万不得已,不要对索引列进行计算。

    3、避免count(*)
    在分页查询的时候,有的人总是习惯用select count()获得总的记录条数,实际上这不是一个高效的做法,因为,之前获得数据的时候已经查询过一次了,select count()相当于同一个语句查询了两次,对语音交友APP源码的数据库开销自然就大了,我们应当使用语音交友APP源码数据库自带的API,或者系统变量来完成这个工作。

    4、避免使用NULL字段
    大家在语音交友APP源码数据库表字段设计的时候,应该尽量都加上NOT NULL DEFAULT ‘’。
    使用NULL字段会产生很多不好的影响,例如:很难进行查询优化、NULL列加索引,需要额外空间、含NULL复合索引无效……
    看下面的案例:

    数据初始化:
    create table table1 (
        `id` INT (11) NOT NULL,
        `name` varchar(20) NOT NULL
    )
    create table table2 (
        `id` INT (11) NOT NULL,
        `name`  varchar(20)
    )
    insert into table1 values (4,"zhaoyun"),(2,"zhangfei"),(3,"liubei")
    insert into table2 values (1,"zhaoyun"),(2, null)
    
    

    (1) NOT IN子查询在有NULL值的情况下返回永远为空结果,查询容易出错

    select name from table1 where name not in (select name from table2 where id!=1)
    
    

    在这里插入图片描述
    (2) 列值允许为空,索引不存储null值,结果集中不会包含这些记录。

    select * from table2 where name != 'zhaoyun'
    
    

    在这里插入图片描述

    select * from table2 where name != 'zhaoyun1'
    
    

    在这里插入图片描述
    (3) 使用concat拼接时,首先要对各个字段进行非null判断,否则只要任何一个字段为空都会造成拼接的结果为null

    select concat("1", null) from dual;
    
    

    在这里插入图片描述
    (4) 当计算count时候null column不会计入统计

    select count(name) from table2;
    
    

    在这里插入图片描述
    **5、避免select ***

    使用select可能会返回不使用的列的数据。它在MySQL数据库服务器和语音交友APP源码之间产生不必要的I/O磁盘和网络流量。
    如果明确指定列,则结果集更可预测并且更易于管理。想象一下,当您使用select
    并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。
    使用select *可能会将敏感信息暴露给未经授权的语音交友APP源码用户。

    6、避免在数据库里存图片

    语音交友APP源码中的图片确实是可以存储到数据库里的,例如通过二进制流将图片存到数据库中。

    但是,强烈不建议把图片存储到语音交友APP源码数据库中!!!!首先对数据库的读/写的速度永远都赶不上文件系统处理的速度,其次数据库备份变的巨大,越来越耗时间,最后对语音交友APP源码文件的访问需要穿越你的应用层和数据库层。

    语音交友APP源码中的图片是数据库最大的杀手。一般来说数据库都是存储一个URL,然后再通过URL来调用图片。图片,文件,二进制数这三样东西慎重存储到数据库中。以上就是“语音交友APP源码中MySQL数据库开发的6个“避免””的全部内容,希望对大家有帮助。
    本文转载自网络,转载仅为分享干货知识,如有侵权欢迎联系云豹科技进行删除处理
    原文链接:https://segmentfault.com/a/1190000037694188

  • 相关阅读:
    Nginx在linux环境下(centos7)的安装、负载均衡设置
    ocr识别开源软件tesseract试用记录
    Nginx在windows环境下的安装、负载均衡设置
    一个测试程序迭代的故事05
    一个测试程序迭代的故事04
    一个测试程序迭代的故事03
    一个测试程序迭代的故事02
    一个测试程序迭代的故事01
    Delphi5和Delphi7属性编辑器内存泄漏问题的解决
    使用Calibre自带工具批量转换电子书格式
  • 原文地址:https://www.cnblogs.com/yunbao/p/15176638.html
Copyright © 2020-2023  润新知