oracle 定位行锁,oracle 的for update行锁语法

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)))'; ......

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值