Mybatis 新增修改一条SQL

如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE;如果不会导致唯一值列重复的问题,则插入新行。例如,如果列a被定义为UNIQUE,并且包含值1,则以下 两个语句具有相同的效果:

<insert id="updateByProviderLotterytype" parameterType=" 参数">
INSERT INTO sc_provider_lotterytype (

relate_code,

buss_id,

buss_lotterytype,

lottery_typecode,

status,deal_by,

deal_time,

last_update_by

,last_update_time)   

 

VALUES (

#{relateCode},

#{bussId},

#{bussLotterytype},

#{lotteryTypecode},

#{status},#{dealBy},

#{dealTime},

#{lastUpdateBy},

#{lastUpdateTime})

 

ON DUPLICATE KEY UPDATE

buss_id = #{bussId},

buss_lotterytype = #{bussLotterytype},

lottery_typecode = #{lotteryTypecode},

status = #{status},
deal_by = #{dealBy},

deal_time = #{dealTime},

last_update_by = #{lastUpdateBy},

last_update_time = #{lastUpdateTime}
</insert>

 

很明显,以上 relate_code 字段就是主键,应为update时没有这个字段

转载于:https://www.cnblogs.com/Hoon/p/4257117.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值