Mybatis如何通过不同条件插入不同数据?

发布于 2022-09-06 00:18:14 字数 58 浏览 11 评论 0

在插入一个数据时,有1,2代表两种状态,需要根据其中一个字段的大小来插入1或是2。xml中需要怎么写!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

番薯 2022-09-13 00:18:14

可以在业务层完成状态的设置,数据层不建议加入复杂的业务。
真的需要的,可以通过if标签来做,参考如下:

  <insert id="insertSelective" parameterType="com.wk.aqi.model.Tcomment" >
    insert into tcomment
    <trim prefix="(" suffix=")" suffixOverrides="," >
      sid,
      <if test="ip != null" >
        ip,
      </if>
      <if test="content != null" >
        content,
      </if>
    </trim>
    <trim prefix="values (" suffix=")" suffixOverrides="," >
      #{sid,jdbcType=INTEGER},
      <if test="ip != null" >
        #{ip,jdbcType=VARCHAR},
      </if>
    </trim>
  </insert>
指尖凝香 2022-09-13 00:18:14

可以使用动态SQL来实现

姐不稀罕 2022-09-13 00:18:14

hi 您好!
是这样的,通过你的问题,我认为可能会有两种情况,一种是你本身"需要根据的其中的一条数据大小来插入的"。如果本身的其中一条数据是你要插入的表中的字段,Mybatis是可以解决的,eg:<if test="字段==1或者2"> </if>即可。另外一种情况就是不是你表中的字段,这种情况下,就刚刚有人回答的那样,即可解决。

潇烟暮雨 2022-09-13 00:18:14

使用动态SQl

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文