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

2024-01-17 19:36

本文主要是介绍mybtis动态SQL注解 脚本动态SQL\方法中构建SQL\SQL语句构造器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mybtis动态SQL注解

    • 动态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();}}

这篇关于mybtis动态SQL注解 脚本动态SQL\方法中构建SQL\SQL语句构造器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/616988

相关文章

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示