触发redo写的几个条件1.超时(timeout)
当LGWR处于空闲状态时,它依赖于rdbms ipc message等待 , 处于休眠状态,直到3秒超时时间到 。
如果LGWR发现有redo需要写出,那么LGWR将执行写出操作 , log file parallel write等待事件将会出现 。
启用10046事件,从LGWR跟踪日志中可以清楚的观察到这些事件:
2.阈值达到
只要一个进程在log buffer中分配空间,已经使用的Log buffer的数量将被计算 。如果使用的块的
数量大于或等于_log_io_size参数设置,那么将会触发LGWR写操作 。
如果此时LGWR未处于活动状态 , 那么LGWR将被通知去执行后台写操作 。
缺省的_log_io_size等于1/3 log buffer大?。?上限值为1M,此参数在X$KSPPSV中显示的0值,意为缺省值 。
也就是 , LGWR将在Min(1M,1/3 log buffer size)时触发 。注意此处的log buffer size是以log block来衡量的 。
此值通常为512 bytes.
获得Oracle的隐含参数,参考 如何获取Oracle的隐含参数
3.提交
当一个事物提交时 , 在redo stream中将记录一个提交标志 。
在这些redo被写到磁盘上之前,这个事物是不可恢复的 。所以 , 在事务返回成功标志给用户前,必须等待LGWR写完成 。进程通知LGWR写,并且以log file sync事件开始休眠,超时时间为1秒 。
Oracle的隐含参数_wait_for_sync参数可以设置为false避免redo file sync的等待,但是就将无法保证事务的恢复性 。
注意,在递归调用(recursive calls)中的提交(比如过程中的提交)不需要同步redo直到需要返回响应给用户 。因此递归调用仅需要同步返回给用户调用之前的最后一次Commit操作的RBA 。
存在一个SGA变量用以记录redo线程需要同步的log block number 。
如果多个提交在唤醒LGWR之前发生,此变量记录最高的log block number,在此之前的所有redo都将被写入磁盘 。
这有时候被称为组提交(group commit).
4.在DBWR写之前
如果DBWR将要写出的数据的高RBA超过LGWR的on-Disk RBA,DBWR将post LGWR去执行写出 。
在Oracle8i之前,此时DBWR将等待log file sync事件 。
从Oracle8i开始 , DBWR把这些Block放入一个defer队列,同时通知LGWR执行redo写出,DBWR可以继续执行无需等待的数据写出 。
Oracle数据库如何关闭?在服务中关闭:
OracleOracle_homeTNSListener对应于数据库的监听程序
OracleServiceSID对应于数据库的例程
OracleDBConsoleSID对应于Oracle Enterprise Manager(OEM)
其中,Oracle_home表示Oracle主目录,如Oracle11g_home1;SID表示Oracle系统标识符,如OracleServiceMAG01的MAG01 。
比较好的启动顺序是:OracleOracle_homeTNSListener,OracleServiceSID,OracleDBConsoleSID 。
关闭时次序相反 。
下面给出了自己写的已经排好顺序的启动和停止服务的两个批处理文件:
//启动Oracle
Start Oracle.bat
@echo off
echo 确定要启动Oracle 11g服务吗?
pause
net start OracleOraDb11g_home1TNSListener
net start OracleServiceMAG01
net start OracleDBConsolemag01
echo 启动Oracle 11g服务完成,请确认有没有错误发生 。
Pause
//关闭Oracle
Stop Oracle.bat
@echo off
echo 确定要停止Oracle 11g 服务吗?
pause
net stop OracleDBConsolemag01
net stop OracleServiceMAG01
net stop OracleOraDb11g_home1TNSListener
echo 停止Oracle 11g服务完成,请确认有没有错误发生 。
Pause
如何调用一个函数的Oracle从休眠状态 , 返回参数Oracle中函数/过程返回结果集oracle如何休眠的几种方式:
以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过.
(1) 返回游标:
returnoracle如何休眠的类型为:SYS_REFCURSOR
之后在IS里面定义变量:curr SYS_REFCURSOR;
最后在函数体中写:
open cur for
select ......;
return cur;
例:
CREATE OR REPLACE FUNCTION A_Test(
orType varchar2
)RETURN SYS_REFCURSORis
type_cur SYS_REFCURSOR;BEGIN
OPEN type_cur FOR
select col1,col2,col3 from testTable ;RETURNtype_cur;END;
(2)返回table类型的结果集:
首先定义一个行类型:
CREATE OR REPLACE TYPE "SPLIT_ARR"AS OBJECT(nowStr varchar2(18))
其次以此行类型定义一个表类型:
CREATE OR REPLACE TYPE "SPLIT_TAB" AS TABLE of split_arr;
定义函数(此函数完成字符串拆分功能):
CREATE OR REPLACE FUNCTION GetSubStr(str in varchar2, --待分割的字符串
splitchar in varchar2 --分割标志)return split_tabIS
restStr varchar2(2000) default GetSubStr.str;--剩余的字符串
thisStr varchar2(18);--取得的当前字符串
indexStr int;--临时存放分隔符在字符串中的位置
v split_tab := split_tab(); --返回结果
begin
dbms_output.put_line(restStr);while length(restStr) != 0
LOOPtop
indexStr := instr(restStr,splitchar); --从子串中取分隔符的第一个位置
if indexStr = 0 and length(restStr) != 0then--在剩余的串中找不到分隔符
begin
v.extend;
v(v.count) := split_arr(Reststr);return v;end;end if;
if indexStr = 1 then---第一个字符便为分隔符,此时去掉分隔符
begin
restStr := substr(restStr,2);gototop;end;end if;
if length(restStr) = 0 or restStr is null then
return v;end if;
v.extend;
thisStr := substr(restStr,1,indexStr - 1); --取得当前的字符串
restStr := substr(restStr,indexStr1);---取剩余的字符串
v(v.count) := split_arr(thisStr);END LOOP;return v;end;
在PL/SQL developer中可以直接调用
cursor strcur is
select nowStr from Table(GetSubStr('111,222,333,,,',','));
(3)以管道形式输出:
create type row_type as object(a varchar2(10), v varchar2(10));--定义行对象
create type table_type as table of row_type; --定义表对象
create or replace function test_fun(
a in varchar2,b in varchar2
)return table_type pipelinedis
v row_type;--定义v为行对象类型
begin
for thisrow in (select a, b from mytable where col1=a and col2 = b) loop
v := row_type(thisrow.a, thisrow.b);pipe row (v);end loop;return;end;select * from table(test_fun('123','456'));
【oracle如何休眠 oracle_sid怎么设置】oracle如何休眠的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于oracle_sid怎么设置、oracle如何休眠的信息别忘了在本站进行查找喔 。
推荐阅读
- 体育竞技游戏2016,体育竞技游戏项目
- go语言升级,go语言 cgo
- phpcms获取字节数,php获取字符
- 我对目前直播运营的看法,谈谈你对直播运营的看法
- c语言表示曲线函数 c语言 曲线
- 什么叫视频流量运营策略,什么叫泛流量视频
- 哪种安卓智能手表好,什么安卓智能手表好
- word里面怎么设置页码,Word里面怎么设置页码本页及其以后
- c语言定义数组函数 c语言函数里定义数组