由于近期工作涉及数据库相关的操作较多,就根据自己的实战经历整理了一些数据库开发的规范用法,利用6个“避免”来概括。 1、避免在数据库中做运算有句话叫做“别让脚趾头想事情,那是脑瓜子的职责”,用在数据库开发中,说的就是避免让数据库做她不擅长的事情。MySQL并不擅长数学运算和逻辑判断,所以尽量不在数据库做运算,复杂运算可以移到程序端CPU。 2、避免对索引列做运算有次,有位同事让我看一条SQL,说是在前台查询很快,但是把SQL取出来,在数据库中执行的时候,跑10分钟都不出结果。 SELECT acinv_07.id_item , 在acinv_07表上的列fiscal_year和列fiscal_period是有索引的。但是,如果对索引列进行运算,就会导致原本可以走索引的走不了索引。于是,动手改写成如下SQL: SELECT id_item , 再执行,4s钟左右就可以跑出结果了。 3、避免count(*)在分页查询的时候,有的人总是习惯用select count(*)获得总的记录条数,实际上这不是一个高效的做法,因为,之前获得数据的时候已经查询过一次了,select count(*)相当于同一个语句查询了两次,对数据库的开销自然就大了,我们应当使用数据库自带的API,或者系统变量来完成这个工作。 4、避免使用NULL字段大家在数据库表字段设计的时候,应该尽量都加上NOT NULL DEFAULT ''。 数据初始化: (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 *
6、避免在数据库里存图片图片确实是可以存储到数据库里的,例如通过二进制流将图片存到数据库中。 但是,强烈不建议把图片存储到数据库中!!!!首先对数据库的读/写的速度永远都赶不上文件系统处理的速度,其次数据库备份变的巨大,越来越耗时间,最后对文件的访问需要穿越你的应用层和数据库层。 图片是数据库最大的杀手。一般来说数据库都是存储一个URL,然后再通过URL来调用图片。 图片,文件,二进制数这三样东西慎重存储到数据库中。 |
|