20221111 springboot 锁(mybatis)

springboot 锁(mybatis)

乐观锁

每次获取数据的时候,都不会担心数据被修改,所以每次获取数据的时候都不会进行加锁,由于数据没有进行加锁,期间该数据可以被其他线程进行读写操作。

原理

乐观锁,大多是基于数据版本 ( Version)记录机制实现。何谓数据版本?即为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表增加一个 “version” 字段来 实现(表中添加一个字段 version)。 读取出数据时,将此版本号一同读出,之后更新时,对此版本号加一。此时,将提交数据的版本数据与数据库表对应记录的当前版本信息进行比对,如果提交的数 版本号大于数据库表当前版本号,则予以更新,否则认为是过期数据。

实现

<update id="updateByPrimaryKey" parameterType="com.etc.lockdemo.entity.Admin">
    update tbl_admin
    set 
        adminuser =  #{adminuser,jdbcType=VARCHAR},
        adminpwd =  #{adminpwd,jdbcType=VARCHAR},
        adminname =  #{adminname,jdbcType=VARCHAR},
        admindate =  #{admindate,jdbcType=VARCHAR},
        adminstate =  #{adminstate,jdbcType=INTEGER},
        version = version+1
    where   adminid = #{adminid,jdbcType=INTEGER} and version=#{version,jdbcType=INTEGER}
</update>

service层在方法或者类前添加@Transaction 事务处理注解

悲观锁

悲观锁则认为拿到的数据一定会被别人修改,为了防止被人修改,当我一拿到数据,我就对它进行加锁,这样别人就无法获得我的数据,只有等我操作完成释放锁后,后面的人才能获得我的数据。悲观锁的实现直接在语句后面加for update即可.

实现

sql语句结尾添加for update ,执行查询之后需要再执行update语句

<select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
    select
    <include refid="Base_Column_List" />
    from tbl_goods
    where  goodsid = #{goodsid,jdbcType=INTEGER} for update
</select>

service层在方法或者类前添加@Transaction 事务处理注解

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值