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

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

阅读 13.3k
4 个回答

可以在业务层完成状态的设置,数据层不建议加入复杂的业务。
真的需要的,可以通过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>

可以使用动态SQL来实现

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题