写点什么

mybatis plus 怎么使用注解的方式执行原生 sql

作者:俊俊哥
  • 2023-03-14
    湖南
  • 本文字数:1062 字

    阅读完需:约 3 分钟

Mybatis Plus 是 Mybatis 的增强工具,支持使用注解的方式执行原生 SQL。以下是使用注解执行原生 SQL 的示例代码:

  1. 添加注解

在需要执行原生 SQL 的方法上添加 @Select 注解,并在注解中写入 SQL 语句,例如:

@Select("SELECT * FROM user WHERE name = #{name}")User selectUserByName(String name);
复制代码
  1. 使用 @Param 注解传递参数

如果 SQL 语句中需要传递参数,则需要使用 @Param 注解,例如:

@Select("SELECT * FROM user WHERE name = #{name} AND age = #{age}")User selectUserByNameAndAge(@Param("name") String name, @Param("age") Integer age);
复制代码
  1. 返回结果集

如果返回结果集,则需要指定返回值类型,并且可以使用 @Results 注解来指定结果集的映射关系,例如:

@Select("SELECT * FROM user")@Results({    @Result(property = "id", column = "user_id"),    @Result(property = "name", column = "user_name"),    @Result(property = "age", column = "user_age")})List<User> selectAllUsers();
复制代码

以上是使用注解执行原生 SQL 的基本示例,需要注意的是,使用注解执行原生 SQL 时,需要在 Mybatis Plus 的配置文件中开启注解支持,例如:

@Configuration@MapperScan("com.example.mapper")public class MybatisPlusConfig {
@Bean public ConfigurationCustomizer configurationCustomizer() { return configuration -> configuration.setUseGeneratedShortKey(true); }
@Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; }
@Bean public SqlSessionFactory sqlSessionFactory(DataSource dataSource, MybatisPlusInterceptor interceptor) throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); sqlSessionFactory.setPlugins(interceptor); sqlSessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mapper/**/*.xml")); sqlSessionFactory.setTypeAliasesPackage("com.example.model"); return sqlSessionFactory.getObject(); }}
复制代码

在以上代码中,通过 @Configuration 注解将 Mybatis Plus 的配置文件注入到 Spring 容器中,在该配置文件中配置了使用注解的方式执行原生 SQL 的相关配置。

发布于: 刚刚阅读数: 5
用户头像

俊俊哥

关注

架构是平衡的艺术 2013-06-01 加入

还未添加个人简介

评论

发布
暂无评论
mybatis plus怎么使用注解的方式执行原生sql_mybatis_俊俊哥_InfoQ写作社区