MyBatis与MyBatis-Plus的区别?

MyBatis与MyBatis-Plus的区别?

MyBatis和MyBatis-Plus都是Java语言中非常常用的ORM框架,二者有以下区别:

  1. 实现方式不同

MyBatis是基于XML或注解方式进行数据库操作的持久化框架,它提供了简单的CRUD操作及动态SQL生成等功能。而MyBatis-Plus是在MyBatis框架上的封装,通过对于增强简化后的API更加方便地进行开发,并且在性能、效率和易用性上都有一定的优化。

  1. 功能支持不同

MyBatis-Plus相比于MyBatis提供了很多额外的功能,例如像条件构造器、代码生成器、分页插件、性能分析拦截器等实用的组件,使得开发者可以轻松快速完成业务逻辑的开发。而MyBatis相对较为原始,需要手写大量的SQL以完成各种功能的实现。

  1. 编程风格有所差异

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);
    }
}

以上就是MyBatis和MyBatis-Plus的一些主要区别。虽然它们都有自己的优缺点和适用场景,但Mybatis-Plus在开发效率及易用性上面的提升还是非常明显的。

猜你喜欢

转载自blog.csdn.net/qq_51447496/article/details/131166800