使用MyBatis Plus后如何设计Dao层 Service层?

发布于 2022-09-11 22:37:44 字数 645 浏览 20 评论 0

之前一直用MyBatis,Dao层写各种SQL语句,Service层写业务,其中会调用到Dao层。

转MyBatis Plus后,我对此产生了困惑。因为Dao层的方法可能会被不止一个Service层的方法调用,但是使用MyBatisPlus的话可以在业务层方法中直接传入QueryWrapper来使用,这样如果业务层别的方法也需要使用此方法的话只能重新写一遍吗?

例如:根据年龄查询用户,使用MyBatis Plus只需要在业务层调用userMapper.selectOne(new QueryWrapper<User>().eq("user_age", age)); 而业务层的其他方法也可能需要根据年龄查询用户,这时我只能再写一遍userMapper.selectOne(new QueryWrapper<User>().eq("user_age", age)); 语句吗?

我想一个好的设计应该是将其封装为Dao层的方法,但是封装为Dao层跟直接写SQL语句差别也不是很大,那这样的话我的MyBatisPlus不是失去意义了吗?

或者说是我应该为每一个需要使用的SQL语句在Service层定义一个方法吗?

还是说我原本的分层模式就有问题?

感谢解答。来自一个菜鸟的疑惑。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

梦里泪两行 2022-09-18 22:37:44

分层是没有问题的,我觉得是需要单独定义一个service方法的,否则在做单元测试的时候就没法mock了。或者要在数据库操作之前增加缓存之类的通用层也是不方便的。

回梦 2022-09-18 22:37:44

为什么不把Mybatis-plus的IService与ServiceImpl当做是Dao的基类呢,当Dao层
然后自己另外写一个Service层,组织业务逻辑

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文