MyBatis中动态SQL注解@SelectProvider、@InsertProvider、@UpdateProvider、@DeleteProvider简介说明
下文笔者讲述Mybatis中动态sql注解@SelectProvider、@InsertProvider、@UpdateProvider、@DeleteProvider简介说明,如下所示
@SelectProvider、@InsertProvider、@UpdateProvider、@DeleteProvider注解功能说明
MyBatis 3.x 版本及以后版本提供 以下动态sql的高级注解 @SelectProvider: 用于构建动态查询SQL @InsertProvider: 用于构建动态新增SQL @UpdateProvider: 用于构建动态更新SQL @DeleteProvider: 用于构建动态删除SQL例:动态构建查询sql
/** * 动态获取用户信息 * */ @SelectProvider(type = UserSqlBuilder.class, method = "buildGetUserByIdSql") public UserInfo getUserById(@Param("userId") int userId); UserSqlBuilder工具类的代码如下: public class UserSqlBuilder { public String buildGetUserByIdSql(@Param("userId") int userId) { return new SQL() { { SELECT("*"); FROM("tb_user"); WHERE("user_id = #{userId}"); } }.toString(); } }例2:使用MyBatis的动态SQL注解,实现用户信息的查询、新增、修改、删除操作。
1、创建数据表 在MySQL数据库中创建用户信息表tb_user 并添加数据 -- 判断数据表是否存在,存在则删除 DROP TABLE IF EXISTS tb_user; -- 创建“用户信息”数据表 CREATE TABLE IF NOT EXISTS tb_user ( user_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '用户编号', user_name VARCHAR(50) NOT NULL COMMENT '用户名称', blog_url VARCHAR(50) NOT NULL COMMENT '博客地址', blog_remark VARCHAR(50) COMMENT '博客备注' ) COMMENT = '用户信息表'; -- 添加数据 INSERT INTO tb_user(user_name,blog_url,blog_remark) VALUES('java265','https://www.java265.com','您好 这是世界上最优秀的java网站'); //2创建项目 创建一个maven项目 添加pom.xml配置信息 在pom.xml配置文件中添加MyBatis、 MySQL的JDBC数据库驱动。 <!-- MyBatis与SpringBoot整合依赖 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.3</version> </dependency> <!-- MySQL的JDBC数据库驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.20</version> </dependency> (3)配置相关信息 将默认的application.properties文件的后缀修改为“.yml”,即配置文件名称为:application.yml,并配置以下信息: spring: #DataSource数据源 datasource: url: jdbc:mysql://localhost:3306/db_admin?useSSL=false& username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver #MyBatis配置 mybatis: type-aliases-package: com.java265.entity #别名定义 configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #指定 MyBatis 所用日志的具体实现,未指定时将自动查找 map-underscore-to-camel-case: true #开启自动驼峰命名规则(camel case)映射 lazy-loading-enabled: true #开启延时加载开关 aggressive-lazy-loading: false #将积极加载改为消极加载(即按需加载),默认值就是false lazy-load-trigger-methods: "" #阻挡不相干的操作触发,实现懒加载 cache-enabled: true #打开全局缓存开关(二级环境),默认值就是true //创建实体类(Entity层) 在com.java265.entity包中 创建UserInfo类(用户信息实体类)。 package com.java265.entity; /** * 用户信息实体类 * **/ public class UserInfo { private int userId; //用户编号 private String userName; //用户名称 private String blogUrl; //博客地址 private String blogRemark; //博客备注 //省略getter与setter方法... } //数据库映射层(Mapper层) //在com.java265.mapper包中 //创建UserMapper接口(用户信息Mapper动态代理接口)。 package com.java265.mapper; import com.java265.entity.UserInfo; import org.apache.ibatis.annotations.*; import org.apache.ibatis.jdbc.SQL; import org.springframework.stereotype.Repository; /** * 用户信息Mapper动态代理接口 * **/ @Mapper @Repository public interface UserMapper { /** * 根据用户ID,获取用户信息 */ @SelectProvider(type = UserSqlBuilder.class, method = "buildGetUserByIdSql") public UserInfo getUserById(@Param("userId") int userId); /** * 新增用户,并获取自增主键 */ @InsertProvider(type = UserSqlBuilder.class, method = "buildInsertUserSql") @Options(useGeneratedKeys = true, keyColumn = "user_id", keyProperty = "userId") public int insertUser(UserInfo user); /** * 修改用户 */ @UpdateProvider(type = UserSqlBuilder.class, method = "buildUpdateUserSql") public int updateUser(UserInfo user); /** * 删除用户 */ @DeleteProvider(type = UserSqlBuilder.class, method = "buildDeleteUserSql") public int deleteUser(@Param("userId") int userId); //建议将SQL Builder以映射器接口内部类的形式进行定义 public class UserSqlBuilder { public String buildGetUserByIdSql(@Param("userId") int userId) { return new SQL() { { SELECT("*"); FROM("tb_user"); WHERE("user_id = #{userId}"); } }.toString(); } public String buildInsertUserSql(UserInfo user) { return new SQL() { { INSERT_INTO("tb_user"); VALUES("user_name", "#{userName}"); VALUES("blog_url", "#{blogUrl}"); VALUES("blog_remark", "#{blogRemark}"); } }.toString(); } public String buildUpdateUserSql(UserInfo user) { return new SQL() { { UPDATE("tb_user"); SET("user_name = #{userName} ,blog_url=#{blogUrl} ,blog_remark=#{blogRemark}"); WHERE("user_id = #{userId}"); } }.toString(); } public String buildDeleteUserSql(@Param("userId") int userId) { return new SQL() { { DELETE_FROM("tb_user"); WHERE("user_id = #{userId}"); } }.toString(); } } } //测试 @Autowired private UserMapper userMapper; /** * 根据用户ID,获取用户信息 * */ @Test public void getUserById() { //获取用户编号为1的用户信息 UserInfo userInfo = userMapper.getUserById(1); //打印结果 System.out.println("用户编号:" + userInfo.getUserId()); System.out.println("用户姓名:" + userInfo.getUserName()); System.out.println("地址:" + userInfo.getBlogUrl()); System.out.println("备注:" + userInfo.getBlogRemark()); }
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。