登录
首页 >  数据库 >  MySQL

数据库DAO方法命名最佳实践

来源:SegmentFault

时间:2023-02-24 21:13:12 193浏览 收藏

积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《数据库DAO方法命名最佳实践》,就带大家讲解一下MySQL、Oracle、mybatis知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

一般我们在写数据库查询的时候会有很多的查询数据的方法
比如:

  • 查询数据操作(查询分类列表、城市信息、新闻列表)
  • 修改操作(修改昵称、修改订单的状态)
  • 删除操作(删除)
  • 添加操作(下一个订单、添加一个商品)
  • 统计操作(统计有多少个订单)

其实一看就是我们通常的使用最多的crud操作,但是随着业务的迭代,我们的数据库的操作会越来越多,就会产生一个问题:看一个DAO方法的直接反应是不知道这个方法具体什么数据库操作。这样新人加入后,对于项目的理解难度就会加大。本质上就是通过比较好的命名规范来解决这个问题。

好了废话不多说,那通过怎么样的命令规则才能解决这个问题呢?根据笔者的工作经验大致罗列出了一些通用的命名方案,希望可以对大家做一个参考。

  • 查询的数据一般我们会分为两种情况,一种是查询出所有的数据,比如是元数据(新闻分类信息、城市信息)对于这类的命名我一般会用listXXX()这样的命名方式,这样一眼就可以看出这个DAO方法是查询这个表的所有数据;另一种是查询分页数据,比如新闻列表这里的信息我一般会用findXXX(Criteria c),findById(Long id)这样的命名方式。
  • 修改数据我们一般以updateBy(Record record ,Criteria c),updateById(Long id)开头命名
  • 删除以deleteById(Long id),deleteBy(Criteria c)开头命名
  • 添加一般以insert(Record record)开头命名
  • 统计一般用countBy(Criteria c)开头命名

通过上面的命名规则,再结合业务的调用的参数,基本上很清楚了解到每个方法具体是操作数据的,用过Criteria也可以把条件的逻辑封装到sql语句的处理上,形成一个通用的解决方法。解释一下Record是要操作的数据对象,Criteria是条件对象

下面附一套我常用的mybatis的Mapper的命名方案

public interface UserRepository {
    long countBy(UserCombo combo);
    int deleteBy(UserCombo combo);
    int deleteById(Long id);
    int insert(User record);
    int insertSelective(User record);
    List listAll();
    List findBy(UserCombo combo);
    User findById(Long id);
    int updateSelectiveBy(@Param("record") User record, @Param("combo") UserCombo combo);
    int updateBy(@Param("record") User record, @Param("combo") UserCombo combo);
    int updateSelectiveBy(User record);
    int updateBy(User record);
}

好啦,总的来说是一套基于约定的套路来减少团队的沟通的成本。按照这样的DAO方法代码命名规范,这样再也不怕代码写多了,不知道哪些方法的功能是干什么的了。见名知意方便开发,提升沟通效率。

本篇关于《数据库DAO方法命名最佳实践》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表