mybtis动态SQL注解 脚本动态SQL\方法中构建SQL\SQL语句构造器

动态SQL注解

分类

  1. 脚本动态SQL:XML配置方式的动态SQL,是用<script>的方式把它照搬过来,用注解来实现。适用于xml配置转换到注解配置
  2. 方法中构建SQL:@SelectProvider 、@InsertProvider、@UpdateProvider、@DeleteProvider 这些方法的使用
  3. SQL语句构造器:实现动态 SQL 的内容

脚本动态SQL

在sql语句中加入<script></script>标签,按照之前sqlmap中的动态sql的样式书写;增删改查都一样

@Select("<script>"
			+ "select * from student "
			+ "<where>"
			+ "<if test =\" ssex != null\">"
			+ "and ssex = #{ssex}"
			+ "</if>"
			+ "<if test =\" classId != 0\"> and classid = #{classId} </if>"
			+ "</where>"
			+ "</script>")
	public List<Student> findStudentJiaoBean(Student s);

方法中构建SQL

注解@SelectProvider@InsertProvider@UpdateProvider@DeleteProvider

用法

  1. 创建SQL语句类:该类包含需要动态生成的SQL 语句;
  2. 创建Mapper接口类:该类和配置文件的接口文件一样,用来处理数据库操作;
  3. 利用@SelectProvider:将 SQL 语句类和 Mapper 接口类关联,利用@SelectProvider 的 type 属性和 method 属性;
  4. 测试验证:编写测试类,测试动态生成的SQL 语句是否准确。
//语法
@UpdateProvider(type = 内部类名.class,method = "方法名")

eg:
@UpdateProvider(type = StudentSql.class,method = "updatestuSqlFunc")
	public int updateStudentFunc(Student s);

class StudentSql{
   
		public String updatestuSqlFunc(Student s) {
   

			String sql = "update student set ";
			String sql1 = null;
			if(s.getBirthday() != null) {
   
				sql += "birthday = #{birthday},";
			}
			if(s.getClassId() != 0) {
   
				sql += "classid = #{classId},";
			}
			if(s.getSname() != null) {
   
				sql += "sname = #{sname},";
			}
			if(s.getSsex() != null) {
   
				sql += "ssex = #{ssex},";
			}
			sql1 = sql.substring(0, sql.length()-1);
			sql1 += " where sid = #{sid}";
			return sql1;
		}
	}

在接口中定义内部类,来构建需要的动态sql语句,比使用标签的方式结构更加清晰

SQL语句构造器

sql语句构造器的常用方法

属性名 说明
SELECT 开始或插入到 SELECT 子句,可以被多次调用,参数也会添加到 SELECT子句。
FROM 开始或插入到 FROM 子句,可以被多次调用,参数也会添加到 FROM 子句
WHERE 插入新的 WHERE 子句条件,可以多次被调用
OR / AND 使用 OR / AND 来分隔当前的 WHERE 子句的条件
DELETE_FROM 开始一个 delete 语句并指定需要从哪个表删除的表名。
INSERT_INTO 开始一个 insert 语句并指定需要插入数据的表名
VALUES 插入到 insert 语句中。第一个参数是要插入的列名,第二个参数则是该列的值。
UPDATE 开始一个 update 语句并指定需要更新的表名
SET 针对 update 语句,插入到 “set” 列表中
语法(都一样)@UpdateProvider(type = 内部类名.class,method = "方法名")
    
eg:
//构造方法(查询)
@UpdateProvider(type = StudentSql.class,method = "selectstuGZQ")
public List<Student> selectStudentGZQ(Student s);
	
//构造方法(新增)
@InsertProvider(type = StudentSql.class, method = "insertstuGZQ")
public int insertStudentGZQ(Student s);
	
//构造方法(修改)
@UpdateProvider(type = StudentSql.class,method = "updatestuGZQ")	
public int updateStudentGZQ(Student s);
	
//构造方法(删除)
@DeleteProvider(type = StudentSql.class,method = "deletestuGZQ")
public int deleteStudentGZQ(int sid);

class StudentSql{
   
		public String selectstuGZQ(Student s) {
   
			return new SQL() {
   
				{
   
					SELECT("sid","birthday");
					SELECT("ssex","sname");
					SELECT("classid");
					FROM("Student");
					if(s.getSsex() != null) {
   
						WHERE("ssex = #{ssex}");
					}
					if(s.getClassId() != 0) {
   
						WHERE("classid = #{classId}");
					}
				}
			}.toString(); 
		}
		
		public String insertstuGZQ(Student s) {
   
			return new SQL() {
   
				{
   
					INSERT_INTO("student");
					if(s.getSname() != null) {
   
						VALUES("sname","#{sname}");						
					}
					if(s.getBirthday() != null) {
   
						VALUES("birthday", "#{birthday}");				
					}
					if(s.getSsex() != null) {
   
						VALUES("ssex", "#{ssex}");						
					}
					if(s.getClassId() != 0) {
   
						VALUES("classid", "#{classId}");				
					}
				}
			}.toString();
		}
		
		public String updatestuGZQ(Student s) {
   
			return new SQL() {
   
				{
   
					UPDATE("student");
					if(s.getSname() != null) {
   
						SET("sname=#{sname}");
					}
					if(s.getBirthday() != null) {
   
						SET("birthday=#{birthday}");
					}
					if(s.getSsex() != null) {
   
						SET("ssex=#{ssex}");
					}
					if(s.getClassId() != 0) {
   
						SET("classid=#{classId}");
					}
					WHERE("sid = #{sid}");
				}
			}.toString();
		}
		
		public String deletestuGZQ(int sid) {
   
			return new SQL() {
   
				{
   
					DELETE_FROM("student");
					WHERE("sid = #{v}");
				}
			}.toString();
		}
	}

相关推荐

  1. MyBatis动态SQL语句

    2024-01-21 01:02:02       67 阅读
  2. MyBatis 之十:MyBatis 框架注解动态 SQL

    2024-01-21 01:02:02       41 阅读
  3. MyBatis动态SQL(Dynamic SQL)

    2024-01-21 01:02:02       55 阅读
  4. Mybatis使用注解实现复杂动态SQL

    2024-01-21 01:02:02       60 阅读
  5. MyBatis动态SQL

    2024-01-21 01:02:02       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-21 01:02:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-21 01:02:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-21 01:02:02       82 阅读
  4. Python语言-面向对象

    2024-01-21 01:02:02       91 阅读

热门阅读

  1. 算法训练营Day37(贪心6)

    2024-01-21 01:02:02       70 阅读
  2. 【力扣刷题练习】103. 二叉树的锯齿形层序遍历

    2024-01-21 01:02:02       71 阅读
  3. Webpack5入门到原理3:基本配置

    2024-01-21 01:02:02       60 阅读
  4. python期末:常见模块的使用及计算生态

    2024-01-21 01:02:02       51 阅读