mybatis plus 怎么使用注解的方式執(zhí)行原生 sql
Mybatis Plus 是 Mybatis 的增強工具,支持使用注解的方式執(zhí)行原生 SQL。以下是使用注解執(zhí)行原生 SQL 的示例代碼:
添加注解
在需要執(zhí)行原生 SQL 的方法上添加 @Select 注解,并在注解中寫入 SQL 語句,例如:
@Select("SELECT * FROM user WHERE name = #{name}")User selectUserByName(String name);
使用 @Param 注解傳遞參數(shù)
如果 SQL 語句中需要傳遞參數(shù),則需要使用 @Param 注解,例如:
@Select("SELECT * FROM user WHERE name = #{name} AND age = #{age}")
User selectUserByNameAndAge(@Param("name") String name, @Param("age") Integer age);
返回結果集
如果返回結果集,則需要指定返回值類型,并且可以使用 @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();
以上是使用注解執(zhí)行原生 SQL 的基本示例,需要注意的是,使用注解執(zhí)行原生 SQL 時,需要在 Mybatis Plus 的配置文件中開啟注解支持,例如:
"com.example.mapper")public class MybatisPlusConfig { ?
?public ConfigurationCustomizer configurationCustomizer() { ? ?return configuration -> configuration.setUseGeneratedShortKey(true);
?} ?
?public MybatisPlusInterceptor mybatisPlusInterceptor() {
? ?MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
? ?interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); ? ?return interceptor;
?} ?
?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 容器中,在該配置文件中配置了使用注解的方式執(zhí)行原生 SQL