Oracle中锁的产生和解锁
Oracle锁处理、解锁方法
Oracle锁处理、解锁⽅法1、查询锁情况select sid,serial#,event,BLOCKING_SESSION from v$session where event like '%TX%';2、根据SID查询具体信息(可忽略)select sid,serial#,username,machine,blocking_session from v$session where sid=<SID>;3、杀掉会话#根据1和2中查到的SID和SERIAL# 定位会话,并杀掉ALTER SYSTEM DISCONNECT SESSION '<SID>,<SERIAL>' IMMEDIATE;或ALTER SYSTEM KILL SESSION '<SID>,<SERIAL>';附件:#查询阻塞脚本col waiting_session for a20col lock_type for a15col mode_requested for a10col mode_held for a10col lock_id1 for a10col lock_id2 for a10set linesize 120set pagesize 999with dba_locks_cust as(SELECT inst_id||'_'||sid session_id,DECODE (TYPE,'MR', 'Media Recovery','RT', 'Redo Thread','UN', 'User Name','TX', 'Transaction','TM', 'DML','UL', 'PL/SQL User Lock','DX', 'Distributed Xaction','CF', 'Control File','IS', 'Instance State','FS', 'File Set','IR', 'Instance Recovery','ST', 'Disk Space Transaction','TS', 'Temp Segment','IV', 'Library Cache Invalidation','LS', 'Log Start or Switch','RW', 'Row Wait','SQ', 'Sequence Number','TE', 'Extend Table','TT', 'Temp Table',TYPE)lock_type,DECODE (lmode,0, 'None', /* Mon Lock equivalent */1, 'Null', /* N */2, 'Row-S (SS)', /* L */3, 'Row-X (SX)', /* R */4, 'Share', /* S */5, 'S/Row-X (SSX)', /* C */6, 'Exclusive', /* X */TO_CHAR (lmode))mode_held,DECODE (request,0, 'None', /* Mon Lock equivalent */1, 'Null', /* N */2, 'Row-S (SS)', /* L */3, 'Row-X (SX)', /* R */4, 'Share', /* S */5, 'S/Row-X (SSX)', /* C */6, 'Exclusive', /* X */TO_CHAR (request))mode_requested,TO_CHAR (id1) lock_id1,TO_CHAR (id2) lock_id2,ctime last_convert,DECODE (block,0, 'Not Blocking', /* Not blocking any other processes */1, 'Blocking', /* This lock blocks other processes */2, 'Global', /* This lock is global, so we can't tell */TO_CHAR (block))blocking_othersFROM gv$lock),lock_temp as(select * from dba_locks_cust),lock_holder as(select w.session_id waiting_session,h.session_id holding_session,w.lock_type,h.mode_held,w.mode_requested,w.lock_id1,w.lock_id2from lock_temp w, lock_temp hwhere h.blocking_others in ('Blocking','Global')and h.mode_held != 'None'and h.mode_held != 'Null'and w.mode_requested != 'None'and w.lock_type = h.lock_typeand w.lock_id1 = h.lock_id1and w.lock_id2 = h.lock_id2),lock_holders as(select waiting_session,holding_session,lock_type,mode_held,mode_requested,lock_id1,lock_id2from lock_holderunion allselect holding_session, null, 'None', null, null, null, nullfrom lock_holderminusselect waiting_session, null, 'None', null, null, null, nullfrom lock_holder)select lpad(' ',3*(level-1)) || waiting_session waiting_session,lock_type,mode_requested,mode_held,lock_id1,lock_id2from lock_holdersconnect by prior waiting_session = holding_sessionstart with holding_session is null;总结以上所述是⼩编给⼤家介绍的Oracle锁处理、解锁⽅法,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。
oracle加锁方式,oracle中加锁与解锁
oracle加锁⽅式,oracle中加锁与解锁oracle中的数据在并发操作时,为了防⽌错误的发⽣可以进⾏记录或者数据库表的加锁操作。
当锁操作完成时可以进⾏解锁操作。
数据库中加锁有两种⽅式,独占模式和共享模式。
1.独占模式,不允许其他会话以任何⽅式共享锁定资源,当进⾏数据库数据修改时可以使⽤这种模式。
2.共享模式,允许在数据访问时,并发共同访问,但是当修改数据时上升为独占模式。
锁分为⾏级锁和表级锁,⾏级锁是锁定某些⾏记录,表级锁是锁定整张表。
1.⾏级锁。
insert update delete (隐式加⾏锁) select...for update(显⽰加⾏锁,共享模式) select * from emp where deptno=30 for update select * from A where id=2 for update skip locked update emp set ename='Joke' where empno=7499;在释放锁之前其他⽤户只能对进⾏数据查询,不能对数据进⾏insert、delete和update。
假如有其他⽤户要锁定同⼀资源:可以使⽤wait ⼦句对锁的等待时间控制如:在另⼀⽤户中:select * from emp where deptno=30 for update wait 2 (等待2秒如2秒钟还未释放资源,系统将会给出提⽰信息。
2.表级锁。
共享模式(in share mode) 共享更新模式(in share update mode) 排他锁模式锁定表的通⽤语法: lock table 表名 in ;1) 共享模式 不允许其他⽤户插⼊,更新和删除⾏,多个⽤户可以同时在同⼀表上设置共享锁,这样设置锁的多个⽤户都只能执⾏查询 lock table emp in share mode;2)共享更新模式(in share update mode) 允许多个⽤户同时锁定表的不同⾏, 允许其他⽤户进⾏DML(insert update delete select)操作 , 除了已锁定的⾏ 如: lock table emp in share update mode; select * from emp where deptno=30 for update //锁定的⾏其他⽤户不能delete ,update 部门30的雇员信息 其他⽤户可以查看锁定的⾏: select * from emp where deptno=303)排他锁模式(限制性强) 不允许其他⽤户插⼊,更新和删除⾏, 允许查看数据,但只有⼀个⽤户可以在表中放置排他锁 lock table emp in exclusive mode;解锁:(1)锁表查询的代码有以下的形式: select count(*) from v$locked_object; select * from v$locked_object;(2)查看哪个表被锁 select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id; (3)查看是哪个session引起的 select ername,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_id = b.sid order by b.logon_time;(4)杀掉对应进程 执⾏命令:alter system kill session'1025,41'; 其中1025为sid,41为serial#.。
Oracle用户被锁的原因及解决办法
Oracle⽤户被锁的原因及解决办法在登陆时被告知test⽤户被锁1、⽤dba⾓⾊的⽤户登陆,进⾏解锁,先设置具体时间格式,以便查看具体时间SQL> alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';Session altered.2、查看具体的被锁时间SQL> select username,lock_date from dba_users where username='TEST';USERNAME LOCK_DATETEST 2009-03-10 08:51:033、解锁SQL> alter user test account unlock;User altered.4、查看是那个ip造成的test⽤户被锁查看$ORACLE_HOME/network/admin/log/listener.log⽇志10-MAR-2009 08:51:03 * (CONNECT_DATA=(SID=lhoms)(SERVER=DEDICATED)(CID=(PROGRAM=Oracle)(HOST=omstestdb)(USER=oraoms))) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.69.1.11)(PORT=49434)) * establish * lhoms * 0 10-MAR-2009 08:51:03 * (CONNECT_DATA=(SID=lhoms)(SERVER=DEDICATED)(CID=(PROGRAM=oracle)(HOST=omstestdb)(USER=oraoms))) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.69.1.11)(PORT=49435)) * establish * lhoms * 0这样可知是上⾯10.69.1.11的ip尝试多次失败登陆造成的被锁注:⼀般数据库默认是10次尝试失败后锁住⽤户1、查看FAILED_LOGIN_ATTEMPTS的值select * from dba_profiles2、修改为30次alter profile default limit FAILED_LOGIN_ATTEMPTS 30;3、修改为⽆限次(为安全起见,不建议使⽤)alter profile default limit FAILED_LOGIN_ATTEMPTS unlimited;以上所述是⼩编给⼤家介绍的Oracle⽤户被锁的原因及解决办法,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。
oracle锁原理
Oracle锁原理详解1. 概述在Oracle数据库中,锁是用于控制并发访问的一种机制。
当多个用户同时访问数据库时,为了保证数据的一致性和完整性,Oracle会对数据进行加锁,以防止其他用户对数据的修改。
本文将详细介绍Oracle锁的基本原理。
2. 锁的类型Oracle中的锁可以分为两种类型:共享锁(Shared Lock)和排他锁(Exclusive Lock)。
•共享锁:多个事务可以同时获取共享锁,并且可以并发读取数据,但不能修改数据。
共享锁用于保证数据的一致性,即多个事务可以同时读取相同的数据,但不能同时修改数据。
•排他锁:只有一个事务可以获取排他锁,并且其他事务不能同时获取共享锁或排他锁。
排他锁用于保证数据的完整性,即一个事务在修改数据时,其他事务不能同时读取或修改数据。
3. 锁的级别Oracle中的锁可以分为多个级别,包括表级锁、行级锁和字段级锁。
•表级锁:锁定整个表,阻止其他事务对表的修改。
表级锁对于大型表来说,可能会导致性能问题,因为它会阻塞其他事务的访问。
•行级锁:锁定表中的一行数据,其他事务可以并发读取其他行的数据。
行级锁可以更细粒度地控制并发访问,但可能会导致死锁问题。
•字段级锁:锁定表中的一个或多个字段,其他事务可以并发读取或修改其他字段的数据。
字段级锁可以进一步细化锁的粒度,但也可能导致死锁问题。
4. 锁的控制Oracle中的锁由数据库管理系统(DBMS)自动控制,用户无需手动操作。
当一个事务对数据进行修改时,DBMS会自动为该数据加上相应的锁,并在事务提交或回滚后释放锁。
锁的控制是通过锁定机制和并发控制机制实现的。
•锁定机制:当一个事务对数据进行修改时,DBMS会自动为该数据加上相应的锁。
锁定机制可以保证在并发访问时,每个事务都能正确地读取和修改数据。
•并发控制机制:当多个事务同时访问数据库时,DBMS会根据事务的隔离级别来控制并发访问。
并发控制机制可以避免脏读、不可重复读和幻读等问题。
oracle锁表原因和如何解锁分享
oracle锁表原因和如何解锁分享最近项⽬项⽬开始忙起来了,就不哔哔了,直接给你们看东西好了。
查锁表select a.OS_USER_NAME, c.owner, c.object_name, b.sid, b.serial#, logon_timefrom v$locked_object a, v$session b, dba_objects cwhere a.session_id = b.sidand a.object_id = c.object_idorder by b.logon_time;解锁ALTER SYSTEM KILL SESSION '129,77';查什么系统导致上的锁select spid, osuser, s.programfrom v$session s,v$process pwhere s.paddr=p.addr and s.sid=129查看什么语句导致锁表的select l.session_id sid,s.serial#,l.locked_mode,l.oracle_username,er#,l.os_user_name,s.machine,s.terminal,a.sql_text,a.actionfrom v$sqlarea a, v$session s, v$locked_object lwhere l.session_id = s.sidand s.prev_sql_addr = a.addressorder by sid, s.serial#;查看有⼏个表被锁select count(*) from v$locked_object;查表SPID129是通过查锁表查出来的SIDselect spid, oSUSEr, s.programfrom v$session s,v$process pwhere s.paddr=p.addr and s.sid=129当Kill不能解锁时,Ctrl+R CMD 输⼊下⾯这句,结束线程。
oracle 字段加密解密方法
(原创实用版3篇)编制人员:_______________审核人员:_______________审批人员:_______________编制单位:_______________编制时间:____年___月___日序言下面是本店铺为大家精心编写的3篇《oracle 字段加密解密方法》,供大家借鉴与参考。
下载后,可根据实际需要进行调整和使用,希望能够帮助到大家,谢射!(3篇)《oracle 字段加密解密方法》篇1Oracle 提供了 DBMS_CRYPTO 包来进行字段加密和解密操作。
在使用此包前,需要先创建一个密钥,可以使用 DES、AES 等算法进行加密。
以下是使用 AES 算法进行加密的步骤:1.创建一个密钥:```CREATE OR REPLACE SYSTEM GENERATED ALWAYS AS NEEDED CREDENTIALS DES_KEY;```2.使用密钥进行加密:```SELECT DBMS_CRYPTO.ENCRYPT(平原文本,DES_KEY) FROM 表名;```3.解密加密后的字段:```SELECT DBMS_CRYPTO.DECRYPT(加密后的字段,DES_KEY) FROM 表名;```其中,平原文本是需要加密的字符串,DES_KEY 是加密密钥。
在解密时,需要使用相同的密钥进行解密。
需要注意的是,加密和解密操作都需要使用 sys 用户进行操作,因为该用户拥有足够的权限来使用 DBMS_CRYPTO 包。
《oracle 字段加密解密方法》篇2Oracle 提供了 DBMS_CRYPTO 包来支持字段加密和解密操作。
在使用此包之前,需要先创建一个密钥,可以使用 DBMS_CRYPTO.GENERATE_KEY 函数生成一个随机密钥,也可以使用 DBMS_CRYPTO.HASH_KEY 函数将一个字符串作为输入生成密钥。
对于加密操作,可以使用 DBMS_CRYPTO.ENCRYPT 函数,将明文字符串和密钥作为输入,返回加密后的密文字符串。
Oracle包被锁定的原因分析及解决方案
Oracle包被锁定的原因分析及解决方案在数据库的开发过程中,经常碰到包、存储过程、函数无法编译或编译时会导致PL/SQL 无法响应的问题。
碰到这种问题,基本上都要重启数据库解决,严重浪费开发时间。
本文将就产生这种现象的原因和解决方案做基本的介绍。
问题分析从事数据库开发的都知道锁的概念,如:执行Update Table xxx Where xxx 的时候就会产生锁。
这种常见的锁在Oracle 里面被称为DML锁。
在Oracle中还有一种DDL锁,主要用来保证存储过程、表结构、视图、包等数据库对象的完整性,这种锁的信息可以在DBA_DDL_LOCKS中查到。
注意:V$LOCKED_OBJECT记录的是DML锁信息,DDL锁的信息不在里面。
对应DDL锁的是DDL语句,DDL语句全称数据定义语句(Data Define Language)。
用于定义数据的结构或Schema,如:CREATE、ALTER、DROP、TRUNCATE、COMMENT、RENAME。
当我们在执行某个存储过程、或者编译它的时候Oracle会自动给这个对象加上DDL锁,同时也会对这个存储过程所引用的对象加锁。
了解了以上知识以后,我们可以得出结论:编译包长时间无响应说明产生了死锁。
我们可以轻易的让这种死锁发生,举例:1、打开一个PL/SQL,开始调试某个函数(假设为:FUN_CORE_SERVICECALL),并保持在调试状态2、打开一个SQL Window,输入Select *Fromdba_ddl_locks aWhere ='FUN_CORE_SERVICECALL'会发现一行记录:3、打开一个新的PL/SQL,重新编译这个函数。
我们会发现此时已经无法响应了4、回到第一个PL/SQL ,重新执行Select *Fromdba_ddl_locks aWhere ='FUN_CORE_SERVICECALL'我们将会看到如下记录:5、上述的情况表明发生了锁等待的情况。
Oracle常见死锁发生的原因以及解决方法
Oracle常见死锁发生的原因以及解决方法死锁是指在并发程序中,两个或多个进程因为争夺系统资源而陷入无限等待的状态,从而无法继续执行下去。
在Oracle数据库中,死锁是一个非常常见的问题,它会导致系统性能下降,甚至造成系统崩溃。
本文将详细介绍Oracle常见死锁发生的原因以及解决方法。
一、死锁发生的原因1.竞争资源:当多个进程同时请求相同的资源时,可能会导致死锁的发生。
例如,如果两个进程同时请求一个表的写锁,那么它们就会陷入死锁状态。
2.锁的顺序:当多个进程按照不同的顺序请求锁时,可能会导致死锁的发生。
例如,如果进程A先请求资源X,再请求资源Y,而进程B先请求资源Y,再请求资源X,那么它们就会陷入死锁状态。
3.锁的持有时间:当一个进程持有一个锁,并且在等待其他资源时继续保持该锁,可能会导致死锁的发生。
例如,如果进程A持有资源X的锁,并且在等待资源Y时继续保持该锁,而进程B持有资源Y的锁,并且在等待资源X时继续保持该锁,那么它们就会陷入死锁状态。
二、死锁的解决方法1. 死锁检测和解除:Oracle数据库提供了死锁检测和解除的机制。
当一个进程请求一个资源时,数据库会检查是否存在死锁。
如果存在死锁,数据库会选择一个进程进行回滚,解除死锁状态,并且通知其他进程重新尝试获取资源。
2.超时设置:为了避免死锁的发生,可以设置超时时间。
当一个进程请求一个资源时,如果在指定的超时时间内无法获取资源,那么就放弃该请求,并且释放已经持有的资源。
这样可以防止死锁的发生,但是会增加系统的开销。
3.锁的顺序:为了避免死锁的发生,可以规定所有进程按照相同的顺序请求锁。
例如,可以规定所有进程按照资源的名称进行排序,然后按照顺序请求锁。
这样可以避免死锁的发生,但是可能会影响系统的性能。
4.锁的粒度:为了避免死锁的发生,可以尽量减小锁的粒度。
例如,可以将一个大的锁分解成多个小的锁,这样可以减少锁的冲突,降低死锁的概率。
但是需要注意的是,锁的粒度过小可能会导致系统的性能下降。
oracle锁与死锁概念,阻塞产生的原因以及解决方案
oracle锁与死锁概念,阻塞产⽣的原因以及解决⽅案锁是⼀种机制,⼀直存在;死锁是⼀种错误,尽量避免。
⾸先,要理解锁和死锁的概念:1、锁:定义:简单的说,锁是数据库为了保证数据的⼀致性⽽存在的⼀种机制,其他数据库⼀样有,只不过实现机制上可能⼤相径庭。
那么,锁的种类有哪些?锁的种类有很多,根据保护的对象不同,Oracle数据库锁可以分为以下⼏⼤类:DML锁(data locks,数据锁),⽤于保护数据的完整性;DDL锁(dictionary locks,字典锁),⽤于保护数据库对象的结构,如表、索引等的结构定义;内部锁和闩(internal locks and latches),保护数据库的内部结构。
在实际项⽬中遇到的最多的是DML锁,也可进⼀步说是⾏级锁。
这些⾏级锁在程序并发访问的时候会造成程序很慢,或者直接访问不了的情况—这种现象称为阻塞。
那么,产⽣阻塞的原因是什么呢?定义:当⼀个会话保持另⼀个会话正在请求的资源锁定时,就会发⽣阻塞。
被阻塞的会话将⼀直挂起,直到持有锁的会话放弃锁定的资源为⽌。
四个常见的DML语句会产⽣阻塞:1)INSERT 2)U PDATE 3)DELETE 4)SELECT…FOR UPDATE2、死锁:定义:当两个⽤户同时希望持有对⽅的资源时就会发⽣死锁。
即当两个⽤户互相等待对⽅释放资源时,oracle认定产⽣了死锁,在这种情况下,将以牺牲⼀个⽤户为代价,另⼀个⽤户继续执⾏,牺牲的事物将回滚。
例⼦: 1:⽤户1对A表进⾏Update,没有提交。
2:⽤户2对B表进⾏Update,没有提交。
此时双反不存在资源共享的问题。
3:如果⽤户2此时对A表作update,则会发⽣阻塞,需要等到⽤户⼀的事物结束。
4:如果此时⽤户1⼜对B表作update,则产⽣死锁。
此时Oracle会选择其中⼀个⽤户进⾏会滚,使另⼀个⽤户继续执⾏操作。
起因: Oracle的死锁问题实际上很少见,如果发⽣,基本上都是不正确的程序设计造成的,经过调整后,基本上都会避免死锁的发⽣。
oracle解锁数据的方法
oracle解锁数据的方法
在Oracle数据库中,解锁数据的方法取决于锁定的类型和锁定的来源。
下面是一些常见的解锁数据的方法:
1. 手动提交或回滚事务:如果数据被锁定是因为当前事务没有完成,则可以手动提交或回滚事务,以释放锁定的数据。
可以使用以下命令提交事务:
```
COMMIT;
```
或者使用以下命令回滚事务:
```
ROLLBACK;
```
2. 等待其他事务完成:如果数据被其他事务锁定,则可以等待其他事务完成并释放锁定的数据。
3. 杀死会话进程:如果无法等待其他事务完成或无法识别锁定的来源,可以使用以下命令杀死锁定会话进程:
```
ALTER SYSTEM KILL SESSION 'sid, serial#';
```
其中'sid'和'serial#'是锁定会话的标识符,在V$SESSION视图中可以找到。
4. 重启数据库实例:如果数据长时间被锁定或无法解锁,可以考虑重启整个数据库实例来释放锁定的数据。
但是,这种解锁方法应该在其他方法失败后才使用,并且需要小心处理,避免数据丢失或影响其他正在进行的操作。
需要注意的是,解锁数据可能会引起数据一致性问题,必须谨慎使用。
在进行任何解锁操作之前,建议先备份数据以防止意外情况发生。
oracle锁表查询和解锁方法
oracle锁表查询和解锁方法一、锁表查询1.使用“行锁”的“for update”子句“for update”子句可以显式地锁定表中的行,以防止其他用户在数据没有更新之前更改或删除它们。
您可以在SELECT语句后使用“for update”子句来锁定表中的特定行:SELECT empno, enameFROM employeesWHERE deptno = 10FORUPDATE;如果您希望锁定整个表,请加上“OF”关键字:SELECT empno, enameFROM employeesWHERE deptno = 10FOR UPDATE OF empno;当在“of”后面指定列名时,它表示你想要锁定此列中的所有行。
这意味着其他会话只能读取此表,但不能修改任何满足WHERE子句的行。
要确保SQL语句完全执行,您必须提交事务。
2.使用“表锁”的“lock table”您可以使用“lock table”语句来锁定表。
lock table用于管理和表中的数据不受任何其他用户影响的场合。
它有三种锁定模式:共享(shared)、排他(exclusive)和混合(mixed)。
lock table table_name in exclusive mode;通常,你将锁定表以防止其他用户以任何方式更改。
共享模式锁定表并允许其他用户从表中选择数据,而排他模式锁定除了选择以外的所有指令。
为了防止其他会话使用SELECT语句,可以使用混合模式。
混合模式允许其他进程只进行SELECT操作。
要确保锁定表,您可以提交事务或回滚事务:请注意,如果您锁定任何表,您必须确保提交或回滚事务,否则其他会话将无法进行任何操作。
二、解锁表。
oracle数据库加解密方法
oracle数据库加解密方法在Oracle数据库中,可以使用dbms_crypto包进行加解密。
该包提供了多种加密算法和函数,包括DES、3DES(2-key和3-key)、AES、MD5、MD4、SHA-1和SHA-2哈希算法以及MAC(消息认证码)。
以下是在Oracle数据库中使用dbms_crypto包进行加解密的一般步骤:1. 连接到Oracle数据库,并使用sysdba权限登录。
2. 授予普通用户执行dbms_crypto包的权限。
可以使用以下命令:```sqlGRANT EXECUTE ON _CRYPTO TO USER;```3. 创建加密函数。
可以使用以下语法创建一个加密函数:```sqlCREATE OR REPLACE FUNCTION ENCRYPT_FUNCTION(V_STR VARCHAR2, V_KEY VARCHAR2) RETURN RAW ISL_ENC RAW;BEGINL_ENC := DBMS_(V_STR, DBMS__AES256 + DBMS__CBC, V_KEY);RETURN L_ENC;END;```上述函数使用了AES-256算法进行加密,并使用CBC模式和提供的密钥进行加密。
您可以根据需要选择不同的加密算法和参数。
4. 在普通用户中创建同义词。
使用以下命令为加密函数创建一个同义词:```sqlCREATE SYNONYM ENCRYPT_FUNCTION FOR _FUNCTION;```5. 现在普通用户可以使用加密函数来加密和解密数据。
例如,以下是一个示例查询,演示如何使用加密函数对字符串进行加密:```sqlSELECT ENCRYPT_FUNCTION('Hello World', 'MySecretKey') FROM DUAL;```上述查询将返回加密后的字符串。
您可以使用相同的函数和密钥来解密数据。
oracle 解除账户锁定规则
标题:Oracle 解除账户锁定规则一、背景介绍Oracle数据库作为一种重要的关系型数据库管理系统,广泛应用于各行各业的信息管理和数据存储中。
在使用Oracle数据库的过程中,经常会碰到账户被锁定的情况,这给数据库管理人员带来了一定的困扰。
为了解决这一问题,Oracle提供了一定的解除账户锁定规则。
二、账户锁定的原因1. 输入错误超过一定次数2. 管理员手动锁定账户3. 其他未知原因导致的账户锁定三、账户锁定的解除规则1. 通过重置密码解除锁定当账户因为密码输入错误次数过多被锁定时,可以通过重置密码解除锁定。
具体操作步骤如下:(1)使用管理员账户登入Oracle数据库;(2)执行ALTER USER username ACCOUNT UNLOCK语句,将被锁定的账户解锁;(3)执行ALTER USER username IDENTIFIED BY new_password语句,重置该账户的密码。
2. 等待一定时间自动解锁当账户被锁定时,可以选择等待一定时间让系统自动解锁账户。
Oracle默认的自动解锁时间为30分钟,当超过这个时间后,系统会自动解锁账户。
3. 通过SYS用户解锁在特殊情况下,可以使用SYS用户来解锁被锁定的账户。
操作步骤如下:(1)使用SYS用户登入Oracle数据库;(2)执行ALTER USER username ACCOUNT UNLOCK语句,将被锁定的账户解锁。
四、账户锁定规则的设置和管理1. 设置账户锁定策略为了保障数据库的安全性,可以设置账户锁定策略,限制密码错误次数并设置账户锁定时间。
可以通过以下SQL语句设置账户锁定策略:ALTER PROFILE profile_name LIMIT F本人LED_LOGIN_ATTEMPTS n;ALTER PROFILE profile_name LIMIT PASSWORD_LOCK_TIME t;2. 监控账户锁定情况数据库管理员应当定期查看和监控数据库中账户的锁定情况,及时发现并处理异常情况,保障数据库的正常运行。
Oracle 默认用户名密码及解锁
很久没有使用sqlplus创建表空间和用户了,需要的时候竟然忘记了密码,试了好多次都没连接上,进而用户也被锁定,在网上找了一些资料,问题解决了,希望对和我一样情况的朋友们有所帮助。
1.安装时选择的自动安装,忘了用户名和密码导致现在试了几个默认的用户名密码後(表格中附带默认用户名及密码),都提示无效的用户名、密码,这时候要找到一组用户名、密码提示被锁,才能进行下一步安装ORACLE时,若没有为下列用户重设密码,则其默认密码如下:用户名/密码登录身份说明sys/change_on_installSYSDBA或SYSOPER不能以NORMAL登录,可作为默认的系统管理员system/managerSYSDBA或NORMAL不能以SYSOPER登录,可作为默认的系统管理员sysman/oem_tempsysman 为oms的用户名scott/tigerNORMAL普通用户aqadm /aqadmSYSDBA或NORMAL高级队列管理员Dbsnmp/dbsnmpSYSDBA或NORMAL复制管理员2,在CMD中启动SQLPLUS;用sqlplus/as sysdba登录,提示连接到:Oracle Database 10g Express Edition Release 10.2.0.1.0 - Production3. 执行ALTER USER 你被锁的用户名 ACCOUNT UNLOCK;4. 重新用SQL/PLUS登录,用你刚刚解锁的用户名、密码;重新修改密码就可以了!具体操作如下:1.运行->sqlplus /nolog2.输入conn / as sysdba 管理员账户登录3.如果用户被锁定先解锁:alter user system account unlock;4.修改密码:alter user system identified by wanglj;接下来可以用sqlplus登陆了。
oracle锁表查询和解锁方法
oracle锁表查询和解锁方法Oracle数据库提供了多种锁表查询和解锁方法,主要包括以下几种:1.查询锁表的方法:-查询数据库中的锁表信息:可以使用`V$LOCKED_OBJECT`视图来查询数据库中当前被锁定的对象和会话信息。
-查看表的锁信息:可以使用`DBA_LOCK`视图来查看指定表被锁定的信息,包括锁定的用户、锁定的模式、锁定的操作等。
-查看表上的锁信息:可以使用`DBA_OBJECTS`视图来查询指定表上的锁信息,包括锁定的用户、锁定的模式、锁定的操作等。
2.解锁表的方法:- 杀死会话:使用`ALTER SYSTEM KILL SESSION 'sid,serial#' IMMEDIATE;`语句可以立即终止指定会话。
其中,`sid`和`serial#`是要终止会话的标识符。
- 释放表锁:使用`ALTER TABLE table_name ENABLE TABLE LOCK`语句可以释放指定表的锁。
其中,`table_name`是要释放锁的表名。
- 修改会话状态:使用`UPDATE V$SESSION SET STATUS = 'KILLED' WHERE SID = sid AND SERIAL# = serial#;`语句可以将指定会话的状态修改为`KILLED`,从而间接释放表锁。
其中,`sid`和`serial#`是要释放锁的会话的标识符。
3.避免锁表的方法:-尽量使用短事务:短事务可以减少对资源的占用时间,从而降低锁表的风险。
-尽量使用较小的粒度锁:使用较小的粒度锁可以减少锁表的范围,提高并发性能。
-合理调整事务隔离级别:使用合适的事务隔离级别可以在保证数据一致性的前提下减少锁表的发生。
-分表、分区表:将大表进行分表或分区,可以减少锁表的范围,提高并发性能。
4.监控锁表情况:- 监控锁表的工具:可以使用Oracle提供的监控工具,如AWR Report、ASH Report、Enterprise Manager等,来实时监控锁表情况。
oracle数据库用户解锁语句
oracle数据库用户解锁语句Oracle数据库用户解锁是指将被锁定的用户账号恢复为可正常使用的状态。
用户账号被锁定可以是由于输入错误的密码次数超过了系统限制,或者是由于管理员手动锁定了该用户账号。
下面列举了10个解锁Oracle数据库用户的语句。
1. ALTER USER语句ALTER USER语句是最常用的解锁用户账号的方法之一。
可以使用以下语法将用户账号解锁:```ALTER USER <username> ACCOUNT UNLOCK;```其中,`<username>`是要解锁的用户账号名称。
执行这条语句后,用户账号将被解锁并可以正常使用。
2. UNLOCK USER语句UNLOCK USER语句也可以用来解锁用户账号,语法如下:```UNLOCK USER <username>;```同样,`<username>`是要解锁的用户账号名称。
执行这条语句后,用户账号将被解锁。
3. 使用ADMIN命令解锁用户账号在Oracle数据库中,可以使用ADMIN命令解锁用户账号。
具体步骤如下:a. 使用sysdba权限登录到数据库:```sqlplus / as sysdba```b. 执行ADMIN命令解锁用户账号:```ADMIN UNLOCK USER <username>;```4. 使用ALTER SYSTEM命令解锁用户账号另一种解锁用户账号的方法是使用ALTER SYSTEM命令。
具体步骤如下:a. 使用sysdba权限登录到数据库:```sqlplus / as sysdba```b. 执行ALTER SYSTEM命令解锁用户账号:```ALTER SYSTEM UNLOCK USER '<username>';```5. 使用DBMS_LOCK.SLEEP函数解锁用户账号DBMS_LOCK.SLEEP函数可以用来解锁用户账号,具体步骤如下:a. 使用sysdba权限登录到数据库:```sqlplus / as sysdba```b. 执行DBMS_LOCK.SLEEP函数解锁用户账号:```BEGINDBMS_LOCK.SLEEP(1);EXECUTE IMMEDIATE 'ALTER USER <username> ACCOUNTUNLOCK';END;/```6. 使用DBMS_SYS_SQL解锁用户账号DBMS_SYS_SQL包中的EXECUTE_AND_FETCH函数可以用来执行动态SQL语句,从而解锁用户账号。
oracle锁表查询和解锁方法
oracle锁表查询和解锁方法## Oracle 锁表查询和解锁方法Oracle数据库是当今最流行的关系型数据库系统,其中有一种十分重要的特性就是它可以锁定数据库表,防止别人修改该表的内容,又被称为并发控制。
下面我们分别来看看Oracle中查询和解锁表的方法:### 一、Oracle中查询锁表方法1. 使用系统内置函数查询锁表- 以DBA权限登录,使用“select * from v$lock;”查询锁表状态;- 使用“SELECT l.sid, l.type, l.mode, l.id1,ername, s.osuser, s.machine FROM v$lock l,v$session s WHERE l.sid=s.sid;”查询出锁表具体信息,以便确定锁表的具体情况和引起表锁定的原因。
2. 使用dba_dml_locks视图查看锁表- 以DBA账号登录,使用“select * fromdba_dml_locks;”命令查看锁表的状态;- 使用“select * f rom dba_dml_locks where name='表名' and mode_held='锁定模式';”命令查看表名称以及表上锁定的模式。
### 二、Oracle中解锁表方法1. 强制执行表解锁:- 使用“ALTER SYSTEM KILL SESSION'sid,serial#' IMMEDIATE;”命令强制杀死会话占用表的会话,以释放表上的锁定;- 使用“select * from v$lock;”命令查询是否成功释放表的锁定。
2. 将表上锁定的模式转换- 使用Oracle的“alter system 的 kill session 命令”可以将表上的锁定模式转换,将表上的某个类型的锁定模式被另外一种更安全的锁定模式替换; - 使用“Select * from v$lock;” 命令查询是否转换成功。
Oracle锁定和解锁用户的命令
Oracle锁定和解锁⽤户的命令
转:/art/200910/158576.htm
在DBA的⽇常⼯作中,经常遇到为Oracle⽤户解锁的操作;这篇⽂章给出在命令⾏下进⾏Oracle⽤户解锁的操作⽅法,通过⼏条简单的解锁语句就能完成此项⼯作。
下⾯是具体的过程:
默认的scott⽤户是被锁定的,先解锁就能登陆上了。
使⽤下⾯的语句解锁scott:
alter user scott account unlock;
解锁之后可能会要求你该密码:
alter user scott identified by tiger;
再登陆:
sqlplus scott/tiger
就能登陆了
Oracle锁定和解锁⽤户的命令
SQL> conn /as sysdba
已连接。
//scott ⽤户在没有设定tieger默认密码时,登陆不上
锁定⽤户的⽅法:
SQL> alter user test account lock;
⽤户已更改。
-------test⽤户登陆数据库,失败了。
C:\>sqlplus test/test
ERROR:
ORA-28000: the account is locked
Oracle⽤户解锁的⽅法:
SQL> conn /as sysdba
SQL> alter user test account unlock;
⽤户已更改。
这样就完成了Oracle的⽤户解锁操作。
Oracle表中一行记录被锁(行锁,表锁,死锁)
Oracle表中⼀⾏记录被锁(⾏锁,表锁,死锁)表现形式:可以向表⾥⾯save新数据,但是⽆法跟新某⼀条数据,update的时候就⼀直在等待。
Oracle锁表查询和解锁⽅法数据库操作语句的分类DDL:数据库模式定义语⾔,关键字:createDML:数据操纵语⾔,关键字:Insert、delete、updateDCL:数据库控制语⾔,关键字:grant、removeDQL:数据库查询语⾔,关键字:selectoracle表在什么情况下会被锁住DML锁⼜可以分为,⾏锁、表锁、死锁⾏锁:当事务执⾏数据库插⼊、更新、删除操作时,该事务⾃动获得操作表中操作⾏的排它锁。
表级锁:当事务获得⾏锁后,此事务也将⾃动获得该⾏的表锁(共享锁),以防⽌其它事务进⾏DDL语句影响记录⾏的更新。
事务也可以在进⾏过程中获得共享锁或排它锁,只有当事务显⽰使⽤LOCK TABLE语句显⽰的定义⼀个排它锁时,事务才会获得表上的排它锁,也可使⽤LOCK TABLE显⽰的定义⼀个表级的共享锁(LOCK TABLE具体⽤法请参考相关⽂档)。
死锁:当两个事务需要⼀组有冲突的锁,⽽不能将事务继续下去的话,就出现死锁。
如事务1在表A⾏记录#3中有⼀排它锁,并等待事务2在表A中记录#4中排它锁的释放,⽽事务2在表A记录⾏#4中有⼀排它锁,并等待事务1在表A中记录#3中排它锁的释放,事务1与事务2彼此等待,因此就造成了死锁。
死锁⼀般是因拙劣的事务设计⽽产⽣。
死锁只能使⽤SQL下:alter system kill session “sid,serial#”;或者使⽤相关操作系统kill进程的命令,如UNIX下kill -9 sid,或者使⽤其它⼯具杀掉死锁进程。
DDL锁⼜可以分为:排它DDL锁、共享DDL锁、分析锁排它DDL锁:创建、修改、删除⼀个数据库对象的DDL语句获得操作对象的排它锁。
如使⽤alter table语句时,为了维护数据的完成性、⼀致性、合法性,该事务获得⼀排它DDL锁。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Oracle中锁的产品和解锁文档修改记录版本号日期说明编写者审核者V1.0 20110822 初稿周伟明1Oracle锁的介绍在多进程或者多线程业务系统中,多个Oracle用户可以同时登录到一个Oracle数据库,对数据库中的数据进行操作难免会出现同时访问同一数据(表或者表中某一条记录)的情况,如果不对这种情况进行规范操作,数据的一致性和完整性就得不到保证,从而会出现意想不到的结果,所以必须有一种机制对并发访问进行控制和调度,避免造成数据更新不正确。
Oracle锁就是这样一种机制,它是控制并发操作最常用的方法。
Oracle使用锁来防止进程相互之间发生的破坏性影响,当一个进程企图阻止另外一个进程对某条数据操作时,该进程就对这个数据进行锁,别的进程对这个数据操作之前,必须获得这个数据的解锁。
Oracle锁功能是Oracle DBMS自动完成的,不需要用户干预,但Oracle也提供了加锁的命令,供用户使用。
1.1 Oracle锁机制Oracle自动使用不同锁类型来控制数据的并发操作,以防止用户之间的破坏性干扰。
Oracle为一个事务自动锁一个资源,以防止其他事务对同一个资源的排他锁。
当某种条件出现或者事务不再需要该资源时,锁自动解除。
Oracle自动获取不同类型的锁取决于锁的资源及其所执行的操作。
其中包括数据锁(DML)、字典锁(DDL)、内部锁、人工锁定、分布锁和并行缓冲管理锁。
1.1.1数据锁(DML)模式数据锁保证表中数据在多个用户并发操作数据时保证数据的完整性,并防止相冲突的DML和DDL操作的破坏性干扰。
DML操作可在两个级别获取数据锁:行级锁(TX)和表级锁(TM)。
表级锁有以下几种方式●空Null,即无锁。
●行共享表锁(RS)行共享表锁(有时也叫SS),表明事务保持已锁表行的表锁,并试图修改数据。
这种锁是在执行以下命令的时自动获取:Select …From 表名… for update for …;Lock Table 表名 in Row Share Mode;当一个事务在一个表持有行共享锁的时候,允许其他事务并行查询、插入、修改或者删除及再进行行锁,但禁止其他事务以排他方式进行操作该表。
Lock Table 表名 in Exclusive Mode;●行排他表锁(RX)行排他表锁(有时也叫SX)表示该事务对该资源有独占权利,通常是在修改记录时发生这种锁。
该锁在执行以下命令的时候自动获取:Insert Into 表名…;Update 表名…;Delete From 表名…;Lock Table 表名 In Row Exclusive Mode;当一个事务在一个表上持有行排他锁时,允许其他事务并行查询、插入、删除、修改或者锁同一个表的其他行,但禁止其他事务使用下列命令进行并发锁:Lock Table 表名 In Share Mode;Lock Table 表名 In Share Row Exclusive Mode;Lock Table 表名 In Exclusive Mode;●共享表锁(S)拥有共享表锁的事务允许其他事务查询该表,或用Select … For Update锁住指定的行,和取得他们自己的Share Table锁(Lock Table In Share Mode),但其他事务不能修改该表。
实现共享表锁使用如下命令:Lock Table 表名 In Share Table;但是禁止其他事务使用下列命令进行并发锁:Lock Table 表名 In Share Exclusive Mode;Lock Table 表名 In Row Exclusive Mode;Lock Table 表名 In Exclusive Mode;●共享行排他表锁(SRX)这种锁比共享锁具有更多限制,它只允许其他事务做查询,或用Select … For Update 锁指定的行,但不允许修改表。
实现共享行排他表锁使用如下命令:Lock Table 表名 In Share Row Exclusive Mode;一旦表使用了这种锁,下列锁均不可使用:Lock Table 表名 In Share Mode;Lock Table 表名 In Share Row Exclusive Mode;Lock Table 表名 In Exclusive Mode;●排他表锁(X)排他表锁是最严格的方式,一个表只允许一个排他表锁存在,Exclusive允许持有锁的事务对该表读取操作,其他事务只可以查询操作,插入、删除、修改等操作均不允许,也不允许取得任何形式的锁。
实现排他表锁使用如下命令:Lock Table 表名 In Exclusive Mode;1.1.2字典锁(DDL)模式DDL锁保证模式对象(如表)的定义,DDL操作将影响对象;一个DDL命令隐式地提交一个事务,当DDL事务需要时,由Oracle 自动获取字典锁,用户不能显式地请求DDL锁。
1.1.3内部锁模式内部用户保证Oracle内部结构,而这些内部结构是不能访问的,所以用户无需对他们深入了解。
1.1.4死锁死锁是多用户系统可能发生的一种现象,通常这种情况比较少,但是一般出现就比较致命。
当两个或者多个进程相互等待对方释放资源而没有一个进程可以继续的时候,就造成了死锁,具体如下:实例1:事务T1:Update fundreal aSet a.current_balane = a.current_balane + v_current_balaneWhere a.fund_account = ‘100000’;Update fundserialcounter aSet a.serial_counter_value = a.serial_counter_value + 1;Where a.serial_counter_no = 1;事务T2:Update fundserialcounter aSet a.serial_counter_value = a.serial_counter_value + 1;Where a.serial_counter_no = 1;Update fundreal aSet a.current_balane = a.current_balane + v_current_balaneWhere a.fund_account = ‘100000’;当T1事务在修改fundreal表记录的时候,T2事务在修改fundserialcounter表,而当T1事务在修改fundserialcounter表的时候,T2事务还没有释放,这时T2事务需要处理fundreal表,T1事务还没有释放,这样相互等待就出现了死锁。
实例2:事务T1:for cur_loop in (select a.* from fundreal a where a.fund_account >= ‘10000’) loopUpdate fundreal aSet a.current_balane = a.current_balane + v_current_balane Where a.fund_account = cur_loop.fund_accountAnd a.money_type = ‘0’;Update fundserialcounter aSet a.serial_counter_value = a.serial_counter_value + 1;Where a.serial_counter_no = 1And a.branch_no = cur_loop.branch_no;end loop;事务T2:Update fundreal aSet a.current_balane = a.current_balane + v_current_balaneWhere a.fund_account = ‘100001’And a.money_type = ‘0’;Update fundserialcounter aSet a.serial_counter_value = a.serial_counter_value + 1;Where a.serial_counter_no = 1And a.branch_no = 1;当T1事务在修改fundreal表修改账号10000的时候并且修改了表fundserialcounter 的branch_no字段为1的数据,T2事务在修改fundreal表修改账号100001的时候,而当T1事务在修改fundreal表账号100001的时候,T2事务还没有释放fundreal,这时T2事务需要处理fundserialcounter表,T1事务还没有释放fundserialcounter,这样相互等待就出现了死锁。
1.1.4.1死锁原理当PMON(程序监控)后台进程检查到死锁之后,就会自动回滚导致死锁的命令,会产生如下错误:ORA-00060: deadlock detected while waiting for resource.并通知PMON首先检查到的哪一个进程发生了死锁(这是不能预测的),接收到死锁信息的进程必须决定释放回滚所做的其他修改,这样将使得另外一个进程继续下去,或者采取其他措施,如要求数据库管理员找到导致死锁的另外一个进程并进行杀死。
例如:Alter System Kill Session ‘Sid,Serial#’;2Oracle锁的查询2.1 涉及系统对象2.1.1V$LOCK查看当前系统中所有锁定的情况,主要字段内容如下1.TYPE :类型说明AD ASM Disk AU LockAF Advisor FrameworkAG Analytic Workspace GenerationAK GES Deadlock TestAO MultiWriter Object AccessAS Service OperationsAT Alter TablespaceAW Analytic WorkspaceBR Backup/RestoreCF Controlfile TransactionCI Cross-Instance Call InvocationCL Label Security cacheCM ASM Instance EnqueueCT Block Change TrackingCU CursorDB DbsDriverDD ASM Local Disk GroupDF Datafile Online in RAC技术文档DG ASM Disk Group ModificationDI GES InternalDL Direct Loader Index CreationDM Database Mount/OpenDN Diskgroup number generatorDP LDAP ParameterDQ ASM RBAL doorbellDR Distributed RecoveryDS Database SuspendDT Default Temporary TablespaceDV Diana VersioningDX Distributed TransactionE Library Cache Lock 2FA ASM File Access LockFB Format BlockFC Disk Group Chunk MountFD Flashback DatabaseFG ACD Relocation Gate EnqueueFL Flashback database logFM File MappingFR Disk Group RecoveryFS File Set / Dictionary CheckFT Disk Group Redo GenerationFU DBFUSG Library Cache Pin 2HD ASM Disk HeaderHP Queue PageHQ Hash QueueHV Direct Loader High Water MarkHW Segment High Water MarkIA InternalID NIDIL Label SecurityIM Kti blr lockIR Instance RecoveryIS Instance StateIT In-Mem Temp Table Meta CreationIV Library Cache InvalidationIZ INSTANCE LOCKJD Job Queue DateJI Materialized ViewJQ Job QueueJS Job SchedulerKK Kick Instance to Switch LogsKM SchedulerKP Kupp Process StartupKT Scheduler PlanL Library Cache Lock 1MD Materialized View Log DDLMH AQ Notification Mail HostML AQ Notification Mail PortMN LogMinerMR Media RecoveryMS Materialized View Refresh LogMW MWIN Schedule技术文档N Library Cache Pin 1OC Outline CacheOL Outline NameOQ OLAPI HistoriesPD Property LockPE ParameterPF Password FilePG Global ParameterPH AQ Notification ProxyPI Remote PX Process Spawn StatusPL Transportable TablespacePM ASM PST SignallingPR Process StartupPS PX Process ReservationPT ASM Partnership and Status TablePV KSV slave startupPW Buffer Cache PreWarmQ Row CacheRB ASM Rollback RecoveryRF Data Guard BrokerRM GES Resource RemasteringRN Redo Log Nab ComputationRO Multiple Object ReuseRP Resilver / RepairRS Reclaimable SpaceRT Redo ThreadSB LogicalStandbySC System Change NumberSF AQ Notification SenderSH Active Session History FlushingSI Streams Table InstantiationSK Shrink SegmentSM SMON SerializationSQ Sequence CacheSR Synchronized ReplicationSS Sort SegmentST Space TransactionSU SaveUndo SegmentSV Sequence OrderingSW Suspend WritesTA Instance UndoTB SQL Tuning Base Existence CacheTC Tablespace CheckpointTD KTF map table enqueueTE KTF broadcastTF Temporary FileTL Log LockTM DMLTO Temp ObjectTQ Queue table enqueueTS Temporary SegmentTT TablespaceTW Cross-Instance TransactionTX TransactionUL User-defined技术文档UN User NameUS Undo SegmentWA AQ Notification WatermarkWF AWR FlushWL Being Written Redo LogWP AWR PurgeWS LogWriter StandbyXH AQ Notification No-ProxyXR Quiesce / Force LoggingXY Internal Test2.LMODE :类型说明1 NULL2 RS(Row Share)3 RX(Row Exclusive)4 S(Share Table)5 SRX(Share Row Exclusive)6 X(Exclusive)3.REQUEST :类型说明0 Success1 Timeout(The lock could not be obtainedwithin the specified number of seconds)2 Deadlock(In this case, an arbitrary sessionwill be rolled back)3 Parameter Error4 The session does not own the lockspecified by the lock ID or the lock handle.5 Invalid lock handle. The handle was notfound on the lock table.4.ID1:TX状态下,等待锁的对象ID,TM状态下,回滚号码的十进制。