oracle 查字符长度,ORACLE如何查询字符串的真正长度

b25181607548cdedfcb8481b6673aad0.png

oracle 9i中闪回查询操作实例进行闪回查询必须设置自动回滚段管理,在init.ora设置参数undo_management=auto,参数undo_retention=n,决定了能往前闪回的最大时间,值越大就需要越多undo空间。例:oracle 9i的flashback query操作。(1)创建闪回查询用户sql> create user flashtest identified by flashtest;

sql> grant connect, resource to flashtest;

sql> grant execute on dbms_flashback to flashtest;

sql> connect flashtest/flashtest;(2)创建测试表,插入测试记录sql> create table test(id number(3));

sql> insert into test values (1);

sql> insert into test values(2);

sql> commit;

sql> create table rec_date(date_scn);

通过以上的操作,我们插入了两条记录,并删除了其中一条记录。在以下的操作中,我们将通过flashback query找到删除的记录(4)闪回查询sql> declare

restore_scn date;

begin

select date_scn into restore_scn from rec_date;

dbms_flashback.enable_at_time (restore_scn);

end;

sql> select * from test;

id

1

2可以看出,虽然删除记录并提交,但是通过闪回操作,仍能查询到删除前的两条记录。需要注意 oracle每5分钟记录一次scn,并将scn和对应时间的映射进行纪录。如果原来插入的记录到做闪回操作的时间在5分钟之内,用基于时间的闪回查询可能得不到记录,因为基于时间点的查询实际上是转化为最近的一次scn,然后从这个scn开始进行恢复。因此,如果需要精确的查询可以采用基于scn的闪回查询,可精确闪回到需要恢复的时间。可以通过dbms_flashback.get_system_change_number语句获取scn。

◆◆

评论读取中....

请登录后再发表评论!

◆◆

修改失败,请稍后尝试

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值