oracle 的for update行锁语法

SELECT...FOR UPDATE 语句的语法如下:

SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];

其中:

OF 子句用于指定即将更新的列,即锁定行上的特定列。

WAIT 子句指定等待其他用户释放锁的秒数,防止无限期的等待。

“使用FOR UPDATE WAIT”子句的优点如下:

1防止无限期地等待被锁定的行;

2允许应用程序中对锁的等待时间进行更多的控制。

3对于交互式应用程序非常有用,因为这些用户不能等待不确定

4 若使用了skip locked,则可以越过锁定的行,不会报告由wait n 引发的‘资源忙’异常报告

示例:

create table t(a varchar2(20),b varchar2(20));

insert into t values('1','1');

insert into t values('2','2');

insert into t values('3','3');

insert into t values('4','4');

现在执行如下操作:

在plsql develope中打开两个sql窗口,

在1窗口中运行sql

select * from t where a='1' for update;

在2窗口中运行sql1

1. select * from t where a='1'; 这一点问题也没有,因为行级锁不会影响纯粹的select语句

再运行sql2

2. select * from t where a='1' for update; 则这一句sql在执行时,永远处于等待状态,除非窗口1中sql被提交或回滚。

如何才能让sql2不等待或等待指定的时间呢? 我们再运行sql3

3. select * from t where a='1' for update nowait; 则在执行此sql时,直接报资源忙的异常。

若执行 select * from t where a='1' for update wait 6; 则在等待6秒后,报 资源忙的异常。

如果我们执行sql4

4. select * from t where a='1' for update nowait skip Locked; 则执行sql时,即不等待,也不报资源忙异常。

现在我们看看执行如下操作将会发生什么呢?

在窗口1中执行:

select * from t where rownum<=3 nowait skip Locked;

在窗口2中执行:

select * from t where rownum<=6 nowait skip Locked;

select for update 也就如此了吧,insert、update、delete操作默认加行级锁,其原理和操作与select for update并无两样。

select for update of,这个of子句在牵连到多个表时,具有较大�

相关文档:

oracle 多表删除 同时删除多表中关联数据

2009-04-27 14:40

1、从数据表t1中把那些id值在数据表t2里有匹配的记录全删除掉

DELETE t1 from t1,t2 WHERE t1.id=t2.id    或DELETE from t1 USING t1,t2 WHERE t1.id=t2.id

2、从数据表t1里在数据表t2里没有匹配的记录查找出来并删除掉

DELETE t1 from t1 L ......

一、安装(略)

服务器端

1、windows:(略)

2、linux:待续...

客户端

待续...

--包括配置--

二、登陆

......

oracle cast() 函数问题

SQL> create table t1(a varchar(10));

Table created.

SQL> insert into t1 values ('12.3456');

1 row created.

SQL> select round(a) from t1;

ROUND(A)

----------

12

SQL> select round(a,3) from t1;

ROUND(A,3)

- ......

Oracle时间日期操作

sysdate+(5/24/60/60) 在系统时间基础上延迟5秒

sysdate+5/24/60 在系统时间基础上延迟5分钟

sysdate+5/24 在系统时间基础上延迟5小时

sysdate+5 在系统时间基础上延迟5天

add_months(sysdate,-5) 在系统时间基础上延迟5月

add_months(sysdate,-5*12) 在系统时间基础上延迟5年

上月末的日期:sel ......

-- Drop existing database link drop database link DL_name

-- Create database link create database link DL_name connect to username identified by userpwd using '(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=ipaddress)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=service_name)))'; ......

oracle 定位行锁,oracle 的for update行锁语法相关推荐

  1. mysql行锁索引问题_Mysql锁机制--索引失效导致行锁变表锁

    =============== Tips:在阅读本文前,最好先阅读 这篇(Mysql锁机制--行锁)文章~ 在上篇文章中,我们看到InnoDB默认的行锁可以使得操作不同行时不会产生相互影响.不会阻塞, ...

  2. Mysql里的锁(排它锁、共享锁、行锁、表锁、间隙锁、临键锁、意向锁)

    一.加锁的目的是什么? 在我们了解数据库锁之前,首先我们必须要明白加锁的目的是为了解决什么问题,如果你还不清楚的话,那么从现在起你应该知道,数据库的锁是为了解决事务的隔离性问题,为了让事务之间相互不影 ...

  3. oracle行锁 查询等待,Oracle 的for update行锁语法

    SELECT...FOR UPDATE 语句的语法如下: SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED]; 其中: ...

  4. mysql中锁原理及for update悲观锁的详解

    mysql 中有多种多样的锁,今天我们具体分享一下: 一.mysql中乐观锁和悲观锁原理及种类: ​        乐观锁并不是数据库自带的,如果需要使用乐观锁,那么需要自己去实现,一般情况下,我们会 ...

  5. 07丨行锁功过:怎么减少行锁对性能的影响

    1. 引言   行锁就是针对数据表中行记录的锁.这很好理解,比如事务 A 更新了一行,而这时候事务 B 也要更新同一行,则必须等事务 A 的操作完成后才能进行更新. 2. 从两阶段锁说起   我先给你 ...

  6. 【转】【MySQL】事务与锁(四):行锁到底锁住的是什么?记录?字段?索引?

    首先我们有三张表t1,t2,t3,它们都是只有两个字段, int类型的id和varchar类型的name:区别是t1没有索引,t2有主键索引,t3有唯一索引. 再强调一次,在实验前必须提前关闭自动提交 ...

  7. 七、行锁功过:怎么减少行锁对性能的影响?

    文章目录 前言 1 从两阶段锁说起 2 死锁和死锁检测 前言 前面介绍了 MySQL 的全局锁和表级锁,接下来我们就来讲讲 MySQL 的行锁. MySQL 的行锁是在引擎层由各个引擎自己实现的.但并 ...

  8. MySQL 行锁功过:怎么减少行锁对性能的影响

    日常读书笔记 行锁 实现 两段锁 如果同时对同一行数据操作的事务很多,mysql可能就挂了 死锁和死锁检测 什么是死锁 死锁的四个必要条件 发生死锁时的两种策略 - 直接等待,直到超时 - 发生死锁检 ...

  9. 07 行锁功过:怎么减少行锁对性能的影响? (笔记)

    继续把该讲内容总结为几个问题, 大家复习的时候可以先尝试回答这些问题检查自己的掌握程度: 1. 两阶段锁的概念是什么? 对事务使用有什么帮助? 2. 死锁的概念是什么? 举例说明出现死锁的情况. 3. ...

最新文章

  1. The project cannot be built until build path errors are resolved的解决方法
  2. esxi ntp服务器地址_NTP的工作原理以及工作模式
  3. 驱动操作硬件的根本操作
  4. 计算机视觉编程——增强现实基础
  5. java 利用dfs生成简单的随机迷宫(效率不高)
  6. 什么是 lnmp 实现原理。
  7. Product Archive相关的标准function module
  8. PyTorch系列 | 如何加快你的模型训练速度呢?
  9. 虎扑APP遭全网下架 原因未知
  10. 程序员被公司开除,隔阵子领导命令回前公司讲解代码,网友直呼:关我嘛事?
  11. office哪个版本最好用?都有哪些版本
  12. python右对齐_Python中print函数输出时的左右对齐问题
  13. 为什么要学习凸优化?
  14. qq_seconds.html,qq英语名字汇总82句
  15. 机器学习必看书籍推荐
  16. 【图像分割】基于形态学重建和过滤改进FCM算法(FRFCM)实现图像分割matlab代码
  17. 小红书批量发布帖子笔记软件怎么用
  18. SV学习(1)——数据类型
  19. [Ant自动打包]ant执行命令的详细参数和Ant自带的系统属性
  20. 第七章、Spring Boot MyBatis升级篇

热门文章

  1. JavaScript中必须掌握的10个难点(必看)
  2. django mysql开发_基于django框架web项目实战开发四 django+mysql实现增删查改功能
  3. java数组的二进制查找_Java程序在长数组上实现二进制搜索
  4. 从入门到入土:恶意代码Lab03-03.exe|分析实验|运行截图|问题回答|
  5. 从入门到入土:Nessus出击:使用nessus扫描某台靶机
  6. 谷歌再遭反垄断起诉:曾试图“扼杀”三星应用商店!
  7. 读源码搞懂为什么Redis用单线程还这么快
  8. iPhone 之后,苹果还会带来什么?
  9. 来点干货 | Android 常见内存泄漏与优化(二)
  10. 新基建下 AI 算力市场崛起,华为凭什么从中分一杯羹?