mybatis中insert语句动态sql篇「建议收藏」

mybatis中insert语句动态sql篇「建议收藏」在mybatis中如何把insert语句改成动态入参;原SQL语句如下:<!–插入user方法一–><insertid="addUser"parameterType="user">insertintosmbms_user(userCode,userName,userPassword,gender,addres

大家好,又见面了,我是你们的朋友全栈君。

在mybatis中如何把insert语句改成动态入参;
原SQL语句如下:

<!-- 插入user方法一 -->
  <insert id="addUser" parameterType="user">
   insert into smbms_user(userCode,userName,userPassword,gender,address,phone) 
    values(#{userCode},#{userName},#{userPassword},#{gender},#{address},#{phone})
  </insert>

对于入参传入的是一个user对象,对象包含了userCode,userName,userPassword,gender,address,phone这些属性,
一般我们插入对象,插入什么属性就需要在sql语句中写上对应的字段名,然后在values中写上对应的字段名的值。如果插入场景很多,比如有此插入只需两个字段,有些插入只需三个字段,那我们就需要写多个方法,多条对应的sql语句。mybatis支持动态sql,对于增、删、查、改都支持。下面我们来修改上面的示例语句。
首先对于示例代码:

<!-- 插入user方法一 -->
  <insert id="addUser" parameterType="user">
   insert into smbms_user(userCode,userName,userPassword,gender,address,phone) 
    values(#{userCode},#{userName},#{userPassword},#{gender},#{address},#{phone})
  </insert>

我们在测试类里运行看一下console打印出来的sql语句,
我们传入所有对象的属性

//测试方法
@Test
 public void test0() {
  int count=0;
  SqlSession sqlSession=null;
   try{
   sqlSession=MyBatisUtil.createSqlSession(); 
   //调用Mapper文件来对数据进行操作,
   User user=new User();
   user.setUserCode("测试Code1");
   user.setUserName("测试用户1");
   user.setGender(21);
   user.setAddress("测试地址");
   user.setPhone("测试号码");
   user.setUserPassword("1111111");
   count=sqlSession.insert("cn.smbms.dao.user.UserMapper.addUser", user);
   logger.debug("UserMapperTest count:"+count); 
   }catch(Exception e){
    e.printStackTrace();
   }finally{
    MyBatisUtil.closeSqlSession(sqlSession);
   }
   
 }

控制台输入的语句

[DEBUG] 2018-11-29 22:39:56,685 cn.smbms.dao.user.UserMapper.addUser - ==>  Preparing: insert into smbms_user(userCode,userName,userPassword,gender,address,phone) values(?,?,?,?,?,?) 
[DEBUG] 2018-11-29 22:39:56,716 cn.smbms.dao.user.UserMapper.addUser - ==> Parameters: 测试Code1(String), 测试用户1(String), 1111111(String), 21(Integer), 测试地址(String), 测试号码(String)

可以看出把我们写的sql语句完整输出出来的,
接下来我们给入参对象注释掉两个属性

User user=new User();
   user.setUserCode("测试Code1");
   user.setUserName("测试用户1");
   user.setGender(21);
   user.setAddress("测试地址");
   //user.setPhone("测试号码");
   //user.setUserPassword("1111111");

测试类运行后看console

[DEBUG] 2018-11-29 22:44:31,866 cn.smbms.dao.user.UserMapper.addUser - ==>  Preparing: insert into smbms_user(userCode,userName,userPassword,gender,address,phone) values(?,?,?,?,?,?) 
[DEBUG] 2018-11-29 22:44:31,896 cn.smbms.dao.user.UserMapper.addUser - ==> Parameters: 测试Code1(String), 测试用户1(String), null, 21(Integer), 测试地址(String), null

可以看出sql语句依然完整打印出来了,只是我们未入参的属性注入的值为null

现在更改示例sql的写法,如下

<!-- 动态sql插入方法二   start -->
  <!-- 对应的插入字段的名字 -->
  <sql id="key">
   <trim suffixOverrides=",">
    <if test="userCode!=null and userCode!=''">
     userCode,
    </if>
    <if test="userName!=null and userName!=''">
     userName,
    </if>
    <if test="userPassword!=null and userPassword!=''">
     userPassword,
    </if>
    <if test="gender!=null and gender!=''">
     gender,
    </if>
    <if test="address!=null and address!=''">
     address,
    </if>
    <if test="phone!=null and phone!=''">
     phone,
    </if>
   </trim>
  </sql>
  
  <!-- 对应的插入字段的值 -->
  <sql id="values">
   <trim suffixOverrides=",">
    <if test="userCode!=null and userCode!=''">
     #{userCode},
    </if>
    <if test="userName!=null and userName!=''">
     #{userName},
    </if>
    <if test="userPassword!=null and userPassword!=''">
     #{userPassword},
    </if>
    <if test="gender!=null and gender!=''">
     #{gender},
    </if>
    <if test="address!=null and address!=''">
     #{address},
    </if>
    <if test="phone!=null and phone!=''">
     #{phone},
    </if>
   </trim>
  </sql>
  <insert id="addUser2" parameterType="user">
   insert into smbms_user(<include refid="key"/>) 
    values(<include refid="values"/>)
  </insert>
    <!-- 动态sql插入方法二  end-->

然后入参如下 ,我们只赋值了两个属性:

User user=new User();
   user.setUserCode("测试Code1");
   user.setUserName("测试用户1");
   //user.setGender(21);
   //user.setAddress("测试地址");
   //user.setPhone("测试号码");
   //user.setUserPassword("1111111");

测试类运行后console显示的sql语句为:

[DEBUG] 2018-11-29 22:49:50,726 cn.smbms.dao.user.UserMapper.addUser2 - ==>  Preparing: insert into smbms_user( userCode, userName ) values( ?, ? ) 
[DEBUG] 2018-11-29 22:49:50,756 cn.smbms.dao.user.UserMapper.addUser2 - ==> Parameters: 测试Code1(String), 测试用户1(String)

可以发现mybatis执行sql语句会动态根据我们的入参来执行sql语句,如此,我们无论插入多少字段,只需在xml中写一条sql语句 在映射接口中写一个方法就可以了,mybatis会动态的为我们生成sql语句进行执行

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152500.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python控制运算的优先顺序(python控制电脑桌面软件)

    Python控制odrive紧接着上一篇文章,来分享一下我的应用过程。先说结论,python编程odrive其实只要写上你之前在odrivetool下的调试命令就行了目前我还只是一个菜鸡,对很多技术都不熟悉或者只知道表面。我也是边做变成长,有哪些不到位的地方可以友善交流。最初的疑惑python也是我最近才开始学习的语言,它可以是一门交互式的语言,如果你知道这一点,那么就知道odrivetool其实就是这样子,你输入命令行然后执行。所以,如果你想控制odrive,只要在python代码中写上诸如o

    2022年4月17日
    60
  • ORA-01722: invalid number

    ORA-01722: invalid number

    2021年11月15日
    52
  • java深拷贝的实现方式_接口可以创建对象吗

    java深拷贝的实现方式_接口可以创建对象吗Cloneable接口与Serializable接口都是定义接口而没有任何的方法。Cloneable可以实现对象的克隆复制,Serializable主要是对象序列化的接口定义。很多时候我们涉及到对象的复制,我们不可能都去使用setter去实现,这样编写代码的效率太低。JDK提供的Cloneable接口正是为了解决对象复制的问题而存在。Cloneable结合Serializable接口可以实现JVM对象的深度复制。

    2022年10月14日
    4
  • tcp粘包分析_解决tcp粘包问题

    tcp粘包分析_解决tcp粘包问题原文源自:https://blog.csdn.net/zhangxinrun/article/details/6721495一.两个简单概念长连接与短连接:1.长连接   Client方与Server方先建立通讯连接,连接建立后不断开,然后再进行报文发送和接收。2.短连接   Client方与Server每进行一次报文收发交易时才进行通讯连接,交易完毕后立即断开连接。此种…

    2022年8月11日
    5
  • 【离散数学】单射、满射和双射的定义、区别

    【离散数学】单射、满射和双射的定义、区别满射:对任意b,存在a满足f(a)=b~即:值域y是满的,每个y都有x对应,不存在某个y没有x对应的情况~单射:(one-to-onefunction)一对一函数,x不同则y不同~即:没有一个x对应两个y,也没有一个y有对应两个x~双射:既是满射,也是单射~即:每个y都有x对应,而且都是一一对应~…

    2022年6月10日
    222
  • asp.net 微信分享到朋友圈,分享给朋友接口

    asp.net 微信分享到朋友圈,分享给朋友接口微信分享到朋友圈,分享给朋友说明:转载:http://www.cnblogs.com/ysyn/archive/2015/07/23/4665897.html、引言:  工作中开发微信网站,简称微网站。由于微网站的分享内容是系统自动选取的当前网址,客户需要改变分享的内容,即点击屏幕右上角的分享按钮,选择发送给朋友和发送到朋友圈,其中的内容和图片需要自定义。于

    2022年5月27日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号