最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

数据库排它操作(2)

来源:动视网 责编:小采 时间:2020-11-09 14:18:17
文档

数据库排它操作(2)

数据库排它操作(2):续: 排它操作不仅仅 FOR UPDATE 就可以,它还需要一个更新标志。 举个例子: 要 更新数据表TABLE表,表中字段ID为主键。然后A进行了如下操作 SELECT ID FROM TABLE WHERE * FOR UPDATE UPDATE TABLE SET * WHERE ID=*; A先锁
推荐度:
导读数据库排它操作(2):续: 排它操作不仅仅 FOR UPDATE 就可以,它还需要一个更新标志。 举个例子: 要 更新数据表TABLE表,表中字段ID为主键。然后A进行了如下操作 SELECT ID FROM TABLE WHERE * FOR UPDATE UPDATE TABLE SET * WHERE ID=*; A先锁


续: 排它操作不仅仅 FOR UPDATE 就可以,它还需要一个更新标志。 举个例子: 要 更新数据表TABLE表,表中字段ID为主键。然后A进行了如下操作 SELECT ID FROM TABLE WHERE * FOR UPDATE UPDATE TABLE SET * WHERE ID=*; A先锁了符合条件的数据,然后进行了更

续:

排它操作不仅仅 FOR UPDATE 就可以,它还需要一个更新标志。

举个例子:

要 更新数据表TABLE表,表中字段ID为主键。然后A进行了如下操作

SELECT ID FROM TABLE WHERE * FOR UPDATE

UPDATE TABLE SET * WHERE ID=*;
A先锁了符合条件的数据,然后进行了更新操作,之后是COMMIT之类的。

问题来了:

TIME1时刻,A了解到数据库TABLE表ID=1的列不符合状况,他在TIME2时刻准备执行上面的操作进行修改; 但是B也查到了这个状况,却在TIME1.5的时刻完成了TABLE的更改;这时候A修改的就是B改过后的数据。

解决:

需要一个参照标志,假设为UPD字段。

A要修改表中ID=1的数据,需要先进行查询ID=1数据对于的UPD字段的值;

SELECT UPD FROM TABLE WHERE ID=1

假设查找的UPD值为 vals=2014/11/14 1:04;

SELECT ID FROM TABLE WHERE ID=1 AND UPD=vals FOR UPDATE 

之后进行更新操作就没有问题了。

文档

数据库排它操作(2)

数据库排它操作(2):续: 排它操作不仅仅 FOR UPDATE 就可以,它还需要一个更新标志。 举个例子: 要 更新数据表TABLE表,表中字段ID为主键。然后A进行了如下操作 SELECT ID FROM TABLE WHERE * FOR UPDATE UPDATE TABLE SET * WHERE ID=*; A先锁
推荐度:
标签: 操作 数据 数据库
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top