php - 数据库如何判断一条数据是否被修改?

查看:111
本文介绍了php - 数据库如何判断一条数据是否被修改?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

A ,B同时在一页面上访问一组数据, A针对其中一条数据做了修改. B的页面没有刷新,所以B看见的信息是在A修改之前的,这时候B也要修改这条数据. 我如何做才能提醒B,这条数据已经被修改过.

看到一个办法,修改数据之前根据这条数据最后修改的时间先将这条数据查出来(select * from xxx where updatetime = xxx and id= xxx),如果查不到说明修改过,查到了说明没有修改.

我想问问有没有更好的办法?

解决方案

我记得hibernate中乐观锁用的是版本号字段实现的,每次更新成功后时候版本号字段的值加1
在更新前,先检查数据库中的版本号和页面中保存的版本号是否相同,如果版本号变大,提示用户在编辑期间已有其他用户修改了数据。

当然也可以用悲观锁,进入页面的时候使用的select ... for update锁定记录,这时候其他用户就不能同时编辑锁定的记录了。

这篇关于php - 数据库如何判断一条数据是否被修改?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆