MyBatis中动态SQL

01为什么使用sql语句的动态拼接
目前学习的内容sql语句都是直接写死的,但是在实际的开发过程中很多的sql语句都是根据不同的业务情况进行不同的改变的
02 解决的方案
sql语句的动态拼接
03学习的标签
if where when set trim foreach bind include sql
接口代码1

public interface FlowerMapper {//按照条件查询List<Flower>  selectMore(String  name,String  production);//按照条件查询List<Flower>  selectMore2(String  name,String  production);List<Flower>  selectMore3(String  name);//按照条件查询List<Flower>  selectMore4(String  name,String  production);//修改操作int update(Flower  flower);//修改操作int update2(Flower  flower);
}

XML文件1

<mapper namespace="com.bjsxt.mapper.FlowerMapper"><!--if标签if(test){..}if(test){..}--><select id="selectMore" resultType="flower">SELECT  *  from   flower  where  1=1<!--OGNL表达式--><if test="param1!=null and param1!=''">and  name=#{param1}</if><if test="param2!=null and param2!=''">and  production=#{param2}</if></select><!--Where标签的作用:会自动的增加where关键字,并且会把多余的第一个and去掉--><select id="selectMore2" resultType="flower">SELECT  *  from   flower<!--OGNL表达式--><where><if test="param1!=null and param1!=''">name=#{param1}</if><if test="param2!=null and param2!=''">and  production=#{param2}</if></where></select><select id="selectMore3" resultType="flower">SELECT  *  from  flower<where><if test="param1!=null and param1!=''">name=#{param1}</if></where></select><!--if(){..}else if(){..}else if(){..}else {}--><select id="selectMore4" resultType="flower">SELECT  *  from  flower<where><choose><when test="param1!=null and param1!=''">name=#{param1}</when><when test="param2!=null and param2!=''">and  production=#{param2}</when><otherwise>1=1</otherwise></choose></where></select><!--Set 会自动增加set关键字,并且去除最后一个逗号--><update id="update">UPDATE   flower<set><if test="name!=null and  name!=''">name=#{name},</if><if test="production!=null and production!=''">production=#{production},</if></set>where id=#{id}</update><!--trim:prefix:添加前缀prefixOverrides:去除前缀suffix:添加后缀suffixOverrides:去除后缀--><update id="update2">UPDATE   flower<trim prefix="set" suffixOverrides=","><if test="name!=null and  name!=''">name=#{name},</if><if test="production!=null and production!=''">production=#{production}</if></trim>where id=#{id}</update></mapper>

测试代码1

// 动态SQL语句
public static void main(String[] args) throws IOException {//[1]解析myBatis.xml文件InputStream inputStream = Resources.getResourceAsStream("mybatis.xml");//[2]获得sqlsession工厂SqlSessionFactory  factory=new SqlSessionFactoryBuilder().build(inputStream);//[3]获得session对象SqlSession sqlSession = factory.openSession(true);//[4]执行方法FlowerMapper mapper = sqlSession.getMapper(FlowerMapper.class);//List<Flower> list = mapper.selectMore4("玫瑰花","");Flower  f=new Flower();f.setId(9);mapper.update(f);//[5]关闭资源sqlSession.close();
}

接口2

public interface FlowerMapper2 {List<Flower> selectMore(List<Integer> li);List<Flower> selectMore2(String name, String production);List<Flower> selectMore3();}

XML2

<mapper namespace="com.bjsxt.mapper.FlowerMapper2"><!--foreach   select * from flower where id in (1,2,3)--><select id="selectMore" resultType="flower">select * from flower where id in<foreach collection="list" open="(" separator="," close=")" item="it">#{it}</foreach></select><!--bind   模糊查询--><select id="selectMore2" resultType="flower">select * from flower<where><if test="param1 != null and param1 != ''"><bind name="pa" value=" '%' + param1 + '%' "></bind>name like #{pa}    <!--占位(推荐)--></if><if test="param2 != null and param2 != ''">and production like '%${param2}%'     <!--拼接--></if></where></select><select id="selectMore3" resultType="flower">select <include refid="sq1"></include> from flower</select><!--定义(公共的)sql代码片段--><sql id="sq1">id,name,price</sql><sql id="sq2">id,name,price,production</sql></mapper>

测试3

        FlowerMapper2 mapper = sqlSession.getMapper(FlowerMapper2.class);List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);//List<Flower> li = mapper.selectMore(list);List<Flower> li = mapper.selectMore2("花", "");System.out.println(li);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325096.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ssl1643-最小乘车费用【dp练习】

最小乘车费用 题目 假设某条街上每一公里就有一个公共汽车站&#xff0c;并且乘车费用如下表&#xff1a;      而任意一辆汽车从不行驶超过10公里。某人想行驶n公里&#xff0c;假设他可以任意次换车&#xff0c;请你帮他找到一种乘车方案&#xff0c;使得总费用最小 …

JavaFX UI控件教程(十)之Scroll Bar

翻译自 Scroll Bar 本章介绍如何使用滚动条控件创建可滚动窗格。 本ScrollBar类可以在应用程序中创建滚动窗格和意见。图9-1显示了滚动条的三个区域&#xff1a;拇指&#xff0c;右侧和左侧按钮&#xff08;或向下和向上按钮&#xff09;以及轨道。 图9-1滚动条的元素 创建…

《走遍中国》珍藏版(十三)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");一游衡山&a…

a+=b不一定等于a=a+b

说明不会改变本身变量的数据类型与&#xff0c;–运算符一样

Jexus部署.Net Core项目

Jexus Jexus 即 Jexus Web Server&#xff0c;简称JWS&#xff0c;是Linux平台上 的一款ASP.NET WEB服务器。它是 Linux、Unix、FreeBSD 等非Windows系统架设 ASP.NET WEB 服务器的核心程序。 将HTTP自宿主应用程序&#xff08;如Asp.net Core应用程序、Node.js应用程序等&…

MyBatis中增删改操作

Mapper层代码 <!-- 增加操作 public int insert (Flower fl) --> <insert id"insert"> insert into flower values(default,#{name},#{price},#{production}) </insert> <!--修改操作 public int update(…

JavaFX UI控件教程(十一)之Scroll Pane

翻译自 Scroll Pane 在本章中&#xff0c;您将学习如何在JavaFX应用程序中构建滚动窗格。 滚动窗格提供UI元素的可滚动视图。此控件使用户可以通过平移视口或使用滚动条来滚动内容。具有默认设置和添加的图像的滚动窗格如图10-1所示。 图10-1滚动窗格 创建滚动窗格 示例10…

洛谷【P2758】-编辑距离

题目描述 设A和B是两个字符串。我们要用最少的字符操作次数&#xff0c;将字符串A转换为字符串B。这里所说的字符操作共有三种&#xff1a; 1、删除一个字符&#xff1b; 2、插入一个字符&#xff1b; 3、将一个字符改为另一个字符&#xff1b; &#xff01;皆为小写字母&…

交换两个数字的三种方式

package com.wdl.day01;public class HelloJava {public static void main(String[] args) {int num11;int num22;//方式一&#xff1a;定义临时变量 // int tempnum1; // num1num2; // num2temp;//方式二&#xff1a;好处&#xff1a;不用定义临时变量//…

Docker Machine 简介

Docker Machine 是什么&#xff1f; Docker Machine 是 Docker 官方提供的一个工具&#xff0c;它可以帮助我们在远程的机器上安装 Docker&#xff0c;或者在虚拟机 host 上直接安装虚拟机并在虚拟机中安装 Docker。我们还可以通过 docker-machine 命令来管理这些虚拟机和 Doc…

C#基础知识详解之【字段与属性】

讲理论知识之前&#xff0c;先看一段代码&#xff1a;public class Emp {//字段private int age;//属性public int Age{get { return age; }set { age value; }} }大家可以看到上面实例代码中&#xff0c;声明了一个名为age的字段&#xff0c;还有一个名为Age的属性&#xff0…

JavaFX UI控件教程(十二)之List View

翻译自 List View 在本章中&#xff0c;您将学习如何在JavaFX应用程序中创建列表。 该ListView级代表项目的滚动列表。图11-1显示了酒店预订系统中可用住宿类型的列表。 图11-1简单列表视图 您可以通过使用该setItems方法定义其项目来填充列表。您还可以通过应用setCellFact…

MyBatis中多表查询(业务代码方式)

业务代码的方式 (实现的方式&#xff0c;书写业务逻辑的java代码实现) ------查询学生所在班级的信息 &#xff08;一对一查询&#xff09; 1、先把所有学生查询出来&#xff08;clazzno&#xff09; select* from student 2、拿着clazzno去clazz表中查询班级的信息 select * f…

ssl1010-方格取数

这道题曾经是提高组的第四题&#xff0c;但是毕竟书上有&#xff0c;所以emmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm&#xff0c;QAQ。 Description   设有N*N的方格图(N<10,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0。如下图所示&#xff08;见样例&#xf…

《走遍中国》珍藏版(十四)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");不管你是漫…

.net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结(二)

依据Partition和Consumer的Rebalance策略&#xff0c;找到Kafka.Client Rebalance代码块&#xff0c;还原本地环境&#xff0c;跟踪调试&#xff0c;发现自定义Consumer Group 的Consumer并没有分配到PartionID,如下图、 frameborder"0" scrolling"no" sty…

JavaFX UI控件教程(十三)之Table View

翻译自 Table View 在本章中&#xff0c;您将学习如何使用JavaFX应用程序中的表执行基本操作&#xff0c;例如添加表&#xff0c;使用数据填充表以及编辑表行。 JavaFX SDK API中的几个类旨在以表格形式表示数据。用于创建JavaFX应用程序表中的最重要的类是TableView&#x…

【洛谷P1108】低价购买【dp练习】

题目 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则。要想被认为是伟大的投资者&#xff0c;你必须遵循以下的问题建议:“低价购买&#xff1b;再低价购买”。每次你购买一支股票,你必须用低于你上次购买它的价格购买它。买的次数越多越好!你的目标是在遵循以上建议…

MyBatis中多表查询(N+1方式)

N1查询方式 [1]什么是N1的查询方式 如果没有N1的方式我们想要实现多表的查询&#xff0c;自己书写查询的业务逻辑代码&#xff08;java&#xff09; mybatis希望通过自己标签配置的方式来解决这个问题 [2]执行的操作 查询学生所在班级的信息&#xff08;一对一&#xff09; 查询…