SELECT...FOR UPDATE 语句的语法如下:
SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];
其中:
OF 子句用于指定即将更新的列,即锁定行上的特定列。
WAIT 子句指定等待其他用户释放锁的秒数,防止无限期的等待。
“使用FOR UPDATE WAIT”子句的优点如下: <!--IWMS_AD_BEGIN-->
<script src="../../system/system60.js" type="text/javascript"></script>
|
<!--IWMS_AD_END-->
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子句在牵连到多个表时,具有较大作用,如不使用of指定锁定的表的列,则所有表的相关行均被锁定,若在of中指定了需修改的列,则只有与这些列相关的表的行才会被锁定。
分享到:
相关推荐
本文主要探讨了Oracle游标中的多表UPDATE行锁及其解决方案。 Oracle的锁定机制主要包括共享封锁、独占封锁和共享更新封锁。共享更新封锁是一种行级封锁,它允许用户在获取锁定的数据行上进行读取和更新,但阻止其他...
SELECT * FROM stu_account t WHERE t.count_id=2 FOR UPDATE; ``` #### 五、约束操作 约束是确保数据完整性和正确性的关键机制。 **1. 添加外键约束** **语法:** ```sql ALTER TABLE <table_name> ADD ...
- **语法**: `SELECT * FROM 表名 WHERE 条件 FOR UPDATE;` - **示例**: `SELECT * FROM stu_account tw WHERE tw.count_id = 2 FOR UPDATE;` - **解释**: 对`stu_account`表中`count_id`为2的记录施加行级锁,...
SELECT * FROM stu_account tw WHERE tw.count_id=2 FOR UPDATE; ``` - **说明**:此命令用于获取`stu_account`表中`count_id`为2的记录的行锁。当执行此命令时,其他用户或会话将无法修改该行直到当前会话释放锁...
删除HKDY_LOCAL_MACHINE/SOFTWARE/ODBC/ODBCINST.INI中除Microsoft ODBC for Oracle注册表键以外的所有含有Oracle的键。 删除环境变量中的PATHT CLASSPATH中包含Oracle的值。 删除“开始”/“程序”中所有...
Oracle SQL支持标准SQL语法,如SELECT、INSERT、UPDATE、DELETE,以及更高级的子查询、联接、分组和聚合函数等。掌握SQL语句的编写和优化对于数据查询和处理至关重要。 3. **PL/SQL编程**:PL/SQL是Oracle特有的...
- SQL语言:掌握SQL的基本语法,包括SELECT、INSERT、UPDATE、DELETE语句的使用。 2. **数据库体系结构** - 实例与数据库:理解实例和数据库的关系,以及SGA(System Global Area)和PGA(Program Global Area)...
只有行锁将用于SELECT FOR UPDATE, 但在更新时将获取表锁。 值范围: ALWAYS | DEFAULT | INTENT 默认值: ALWAYS shared_servers 说明 : 指定在启动例程后, 要为共享服务器环境创建的服务器进程的数量。 值范围: ...
设置为 `INTENT` 时,对于 `SELECT FOR UPDATE` 查询使用行锁,但在更新时获取表锁。 - **值范围**:`ALWAYS`、`DEFAULT` 或 `INTENT` - **默认值**:`ALWAYS` #### shared_servers 参数 - **说明**:该参数指定了...
- **10g for Linux安装**: 适用于Linux平台的Oracle 10g安装指南。 - **登录OEM**: 使用Oracle Enterprise Manager进行数据库管理。 - **修改OEM端口**: 调整OEM服务使用的端口号。 - **重建企业管理器**: 当OEM...
要想启动或关闭ORACLE系统必须首先切换到ORACLE用户,如下 su - oracle a、启动ORACLE系统 oracle>sqlplus SQL>connect internal SQL>startup SQL>quit b、关闭ORACLE系统 oracle>sqlplus SQL>connect internal ...
从标签“sql语句”我们可以推断,接下来的内容将围绕SQL的各种命令展开,如查询(SELECT)、数据定义(CREATE)、数据操纵(INSERT、UPDATE、DELETE)以及事务处理等。 部分内容提到了一些具体的SQL函数和存储过程...
- 创建触发器:`CREATE TRIGGER trigger_name BEFORE/AFTER {INSERT|UPDATE|DELETE} ON table_name FOR EACH ROW ...`。 - 触发时机:BEFORE/AFTER。 4. **事务处理** - 事务的基本概念:一组SQL操作,要么全部...
3.3.8 update忘加where条件误操作恢复(模拟oracle闪回功能) 99 3.3.9 delete忘加where条件误操作恢复(模拟oracle闪回功能) 108 第4章 同步复制报错故障处理 112 4.1 最常见的3种故障 112 4.1.1 在master上...