MyBatis与MyBatis-Plus的区别?
MyBatis和MyBatis-Plus都是Java语言中非常常用的ORM框架,二者有以下区别:
- 实现方式不同
MyBatis是基于XML或注解方式进行数据库操作的持久化框架,它提供了简单的CRUD操作及动态SQL生成等功能。而MyBatis-Plus是在MyBatis框架上的封装,通过对于增强简化后的API更加方便地进行开发,并且在性能、效率和易用性上都有一定的优化。
- 功能支持不同
MyBatis-Plus相比于MyBatis提供了很多额外的功能,例如像条件构造器、代码生成器、分页插件、性能分析拦截器等实用的组件,使得开发者可以轻松快速完成业务逻辑的开发。而MyBatis相对较为原始,需要手写大量的SQL以完成各种功能的实现。
- 编程风格有所差异
MyBatis的编程风格更加传统,需要定义mapper.xml文件并根据传入的参数使用相应的SQL查询语句,需要实现 Mybatis 提供的各种方法;而MyBatis-Plus具有许多针对CRUD进行的简化方法,通过继承BaseMapper以及使用Lambda表达式,可以让我们像SpringDataJPA类似地使用接口编程方式进行数据库操作。
下面通过代码示例来演示一下MyBatis和MyBatis-Plus的区别:
- MyBatis的实现
首先在Mybatis中需要配置sql mapper映射文件,如下所示:
<!-- userMapper.xml --> <mapper namespace="com.demo.dao.UserMapper"> <select id="getUserById" parameterType="java.lang.Integer" resultType="com.demo.entity.User"> select * from t_user where id=#{id} </select> </mapper>
然后通过Mybatis的SqlSession执行相关方法实现数据查询:
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(configuration); SqlSession sqlSession = sessionFactory.openSession(); User user = sqlSession.selectOne("com.demo.dao.UserMapper.getUserById", 1); sqlSession.close();
- MyBatis-Plus的实现
在MyBatis-Plus中则要比上述方式简单得多,并且提供了更加方便的CRUD操作。例如我们可以定义一个接口继承BaseMapper接口并调用其中提供的方法来操作数据库,如下所示:
public interface UserMapper extends BaseMapper<User> { }
以下是从数据库中根据ID查询数据时,可以在Service层直接调用BaseMapper中提供的selectById()方法:
@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public User getUserById(Long id) { return baseMapper.selectById(id); } }
如果大家觉得有用的话,可以关注我下面的微信公众号,极客李华,我会在里面更新更多行业资讯,企业面试内容,编程资源,如何写出可以让大厂面试官眼前一亮的简历,让大家更好学习编程,我的抖音,B站也叫极客李华。