阿里巴巴开发手册数据库方面的优化

简介: 其他    1.对于后台输出到前台的变量必须要加$!{var}    2.Math.random()这个方法的返回值是double类型,注意取值范围是0=<

其他
    1.对于后台输出到前台的变量必须要加$!{var}
    2.Math.random()这个方法的返回值是double类型,注意取值范围是0=< <1,注意除0异常,
    要想获得整型数,不要*10,只需要调用Random的nextInt(),nextLong()方法,
    3.不要在视图中加任何的逻辑,视图的任务就是展示,
    4.任何数据结构的构造或初始化都要指定其大小,避免数据无限增长吃光内存
    
数据库规约
    1.表达与否概念的字段必须用is_xxx,如删除与否is_deleted
    2.数据库名,表名,字段名都不允许出现大写,因为MySQL在linux默认下区分大小写
    3.decimal对于小数的存储用,禁止使用float和double,float和double存在精度损失的问题,很可能在值计算时得不到正确的结果
    如果数据范围超出了decimal的范围的话,建议就把整数和小数分开存
    4.如果存取的字符串长度确定了,那么就用char定字符串的长
    5.varchar是可变字符串,那么当其字符串超出5000就用text,独立出一张表避免影响其它字段的索引效率
    6.表的命名最好是业务名称_表的作用
    7.字段允许适当冗余,但是对于冗余的字段有要求:1.不是频繁修改,2.不是varchar超长字段
    8.合适的字符长度,可以提高检索速度。
    

SQL语句
    1.禁止使用count(常量)或者count(列名),因为它们避免不了NULL值
    用count(*)来计算条数
    2.count(distinct col)计算该列没有NULL值的不重复的数量
    3.注意count(col)当这一列全为NULL时,返回0,而sum(col)返回的值是NULL
    4.当代码中写查询分页时,count为0应直接返回,避免执行后边的代码
    5.对于数据的修改,删除操作时应该先select,避免出现错误
    6.在表查询时,应该禁止*,能用字段就用字段
    7.select * from user where id in
    <foreach collection="ids" item="item" open="("separator="," close=")">#{item}</foreach>
    sql.xml 配置参数使用:#{}, #param# 不要使用${} 此种方式容易出现 SQL 注入,
    select * from userorder by #{name} desc  /*有问题sql*/
    select * from userorder by ${name} desc
    8.iBATIS 自带的 queryForList(String statementName,int start,int size)不推 荐使用。 
    正例:Map<String, Object> map = new HashMap<String, Object>();
            map.put("start", start);    map.put("size", size);  
    9.不要写一个大而全的更新数据,更新哪些写哪些,因为容易出错,效率低
    10.@Transactional 事务不要滥用,
    11.Query对于查询对象的封装,超过两个以上的对象禁止用Map来传输

相关文章
|
11天前
|
存储 缓存 监控
数据库优化技术:提升性能与效率的关键策略
【10月更文挑战第15天】数据库优化技术:提升性能与效率的关键策略
42 8
|
2月前
|
消息中间件 缓存 监控
优化微服务架构中的数据库访问:策略与最佳实践
在微服务架构中,数据库访问的效率直接影响到系统的性能和可扩展性。本文探讨了优化微服务架构中数据库访问的策略与最佳实践,包括数据分片、缓存策略、异步处理和服务间通信优化。通过具体的技术方案和实例分析,提供了一系列实用的建议,以帮助开发团队提升微服务系统的响应速度和稳定性。
|
1天前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
13 7
|
1天前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
9 5
|
2天前
|
Java 数据库连接 数据库
优化之路:Java连接池技术助力数据库性能飞跃
在Java应用开发中,数据库操作常成为性能瓶颈。频繁的数据库连接建立和断开增加了系统开销,导致性能下降。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接,显著减少连接开销,提升系统性能。文章详细介绍了连接池的优势、选择标准、使用方法及优化策略,帮助开发者实现数据库性能的飞跃。
14 4
|
5天前
|
存储 缓存 监控
数据库优化:提升性能与效率的关键策略
【10月更文挑战第21】数据库优化:提升性能与效率的关键策略
|
5天前
|
存储 分布式计算 监控
数据库优化:提升性能与效率的全面策略
【10月更文挑战第21】数据库优化:提升性能与效率的全面策略
|
19天前
|
SQL 监控 数据库
慢SQL对数据库写入性能的影响及优化技巧
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生显著的不利影响
|
2月前
|
存储 关系型数据库 MySQL
【阿里规约】阿里开发手册解读——数据库和ORM篇
从命名规范、建表规范、查询规范、索引规范、操作规范等角度出发,详细阐述MySQL数据库使用过程中所需要遵循的各种规范。
【阿里规约】阿里开发手册解读——数据库和ORM篇
|
9天前
|
存储 监控 关系型数据库
MySQL并发控制与管理:优化数据库性能的关键
【10月更文挑战第17天】MySQL并发控制与管理:优化数据库性能的关键
31 0