当前位置:  数据库>oracle
本页文章导读:
    ▪数据的安全性与备份技术      本文内容 Data Guard 结构 RAC 结构 RMAN + 归档的方式 数据导出方式(EXP/IMP、EXPDP/IMPDP) 本文主要描述 Oracle 数据库保障数据安全的备份技术。像通常所说的冷备份、热备份、导出.........
    ▪oracle中utl_file包读写文件操作学习      在oracle中utl_file包提供了一些操作文本文件的函数和过程,学习了一下他的基本操作 1.创建directory,并给用户授权 --创建directory create or replace directory TESTFILE as '/home/oracle/zxx/test'; --给用户.........
    ▪简单演示 Oracle 数据库并发导致行级锁      本文内容 软件环境 简单演示 Oracle 数据库并发导致行级锁 本文简单演示并发导致的行级锁。并发是两个以上的用户对同样的数据进行修改(包括插入、删除和修改)。锁的产生是因.........

[1]数据的安全性与备份技术
    来源:    发布时间: 2013-10-29

本文内容

  • Data Guard 结构
  • RAC 结构
  • RMAN + 归档的方式
  • 数据导出方式(EXP/IMP、EXPDP/IMPDP)

本文主要描述 Oracle 数据库保障数据安全的备份技术。像通常所说的冷备份、热备份、导出/导入这些只是备份方式而已,它们不是重点,任何人都能想到,关键是用什么技术来做到这些。

 

Data Guard 结构

        如果用户对数据的安全性要求非常高,并且对系统的当机(内地叫“当机”,台湾叫“宕机”)可以考虑 Data Guard 结构,当主数据库出现故障时,维护人员可以用最短的时间启用备用数据库,保证业务的正常进行。

图 1 Data Guard 结构

 

RAC 结构

        RAC 结构和 Data Guard 结构属于不同级别的安全设计,Data Guard 能够保证数据不丢失或尽可能少丢失,它是数据库级别的一个冗余结构。而 RAC 则是实例级别的一个冗余结构,它能够保证数据库在一个实例出现故障后,用户操作可以无缝地由另一个实例接管,现在很多对业务连续性要求很高的系统都采用 RAC + Data Guard 的结构。

图 2 RAC 结构

 

RMAN + 归档的方式

        RMAN + 归档的备份方式,相对 RAC + Data Guard 的结构,其优势在于成本低,并且能够保证数据的完整,当数据库损坏时,如果我们有完整的备份集和归档日志,就可以将数据库恢复到最后出现故障时的时间点。缺点是需要较长的当机时间。

 

数据导出方式(EXP/IMP、EXPDP/IMPDP)

这种方式是一种数据传递,或数据迁移,或数据保存,它不能保证数据的安全。

本文链接


    
[2]oracle中utl_file包读写文件操作学习
    来源:    发布时间: 2013-10-29

在oracle中utl_file包提供了一些操作文本文件的函数和过程,学习了一下他的基本操作

1.创建directory,并给用户授权

--创建directory
create or replace directory TESTFILE as '/home/oracle/zxx/test';
--给用户授权
grant read, write on directory TESTFILE to zxx;

详细介绍

http://download.oracle.com/docs/cd/B19306_01/appdev.102/b14258/u_file.htm

2.写入操作

---测试写入
DECLARE
  filehandle  utl_file.file_type; --句柄
  begin
  filehandle := utl_file.fopen('TESTFILE','hello.txt','w'); --打开文件
  utl_file.put_line(filehandle,'Hello Oracle!');--写入一行记录
  utl_file.put_line(filehandle,'Hello World!');
  utl_file.put_line(filehandle,'你好,胖子!');
  utl_file.fclose(filehandle);--关闭句柄
  end;
  /

备注:

fopen有一个参数max_linesize,下面是原文解释

Maximum number of characters for each line, including the newline character, for this file (minimum value 1, maximum value 32767). If unspecified, Oracle supplies a default value of 1024.

3.读取操作

--测试读取
set serveroutput on;
DECLARE
  filehandle  utl_file.file_type;
  filebuffer varchar2(500);
  begin
  filehandle := utl_file.fopen('TESTFILE','hello.txt','R');
  IF utl_file.is_open(filehandle) THEN
    dbms_output.put_line('file is open!');
  END IF;
  loop
  begin
  utl_file.get_line(filehandle,filebuffer);
  dbms_output.put_line(filebuffer);
  EXCEPTION
   WHEN no_data_found THEN
    exit ;
   WHEN OTHERS  THEN
    dbms_output.put_line('EXCEPTION1:'||SUBSTR(SQLERRM, 1, 100)) ; 
  end;
  end loop;
  utl_file.fclose(filehandle);
    IF utl_file.is_open(filehandle)  THEN
      dbms_output.put_line('file is open!');
    else
    dbms_output.put_line('file is close!');
  END IF;
  utl_file.fcopy('TESTFILE', 'hello.txt', 'TESTFILE', 'hello.dat');--复制
  utl_file.fcopy('TESTFILE', 'hello.txt', 'TESTFILE', 'hello2.dat');
  utl_file.fcopy('TESTFILE', 'hello.txt', 'TESTFILE', 'hello.xls');

  utl_file.frename('TESTFILE','hello.xls','TESTFILE','frenamehello.xls',TRUE);--重命名
  utl_file.fremove('TESTFILE', 'hello2.dat');--删除文件
  EXCEPTION
     WHEN OTHERS  THEN
    dbms_output.put_line('EXCEPTION2:'||SUBSTR(SQLERRM, 1, 100)) ; 
  end;
  /

4.判断文件是否存在(读,重命名,复制,删除都要判断文件是否存在)

--判断文件是否存在
DECLARE
ex    BOOLEAN;--文件是否存在

flen NUMBER;--文件长度? 这个地方不知道怎么理 (原文 file_length The length of the file in bytes. NULL if file does not exist.)
bsize NUMBER;--文件大小
BEGIN
utl_file.fgetattr('TESTFILE', 'hello.txt', ex, flen, bsize);
IF ex THEN
    dbms_output.put_line('File Exists');
ELSE
    dbms_output.put_line('File Does Not Exist');
END IF;
dbms_output.put_line('File Length: ' || TO_CHAR(flen));
dbms_output.put_line('Block Size: ' || TO_CHAR(bsize));
END fgetattr;
/

 

转载自:http://blog.csdn.net/Rookie_CEO/article/details/6372179

本文链接


    
[3]简单演示 Oracle 数据库并发导致行级锁
    来源:    发布时间: 2013-10-29

本文内容

  • 软件环境
  • 简单演示 Oracle 数据库并发导致行级锁

本文简单演示并发导致的行级锁。并发是两个以上的用户对同样的数据进行修改(包括插入、删除和修改)。锁的产生是因为并发。没有并发,就没有锁。并发的产生是因为系统需要,系统需要是因为用户需要。

软件环境

  • Windows 2003 Server
  • Oracle 11g Release 1 (11.1)

简单演示 Oracle 数据库并发导致行级锁

        首先,打开一个会话 session 1,执行如下操作:

SQL> select distinct sid from V$mystat;   SID ---------- 118   SQL> create table t (x int primary key);   表已创建。   SQL> insert into t values(1);   已创建 1 行。   SQL> update t set x=10 where x=1;   已更新 1 行。   SQL>

        先查看本次会话的 SID,然后创建一个表 t,只有一个名为 x 的字段,且该字段为主键,插入一条数据,并更新该数据。

        接下来,打开另一个会话 session 2:

SQL> select distinct sid from V$mystat;   SID ---------- 137   SQL> update t set x=10 where x=1;

        此时,该会话被“卡”在这里不动。只是光标一直在闪……因为,session 2 被 session 1 阻塞。

        现在,查看锁定视图 V$LOCK。

SQL> select sid,type,id1,id2,lmode,request,block 2 from v$lock where sid in (118,137) 3 order by sid;   SID TYPE ID1 ID2 LMODE REQUEST BLOCK ---------- ----- ---------- ---------- ---------- ---------- ---------- 118 TM 128105 0 3 0 0 118 AE 99 0 4 0 0 118 TX 262174 34335 6 0 1 137 TM 128105 0 3 0 0 137 AE 99 0 4 0 0 137 TX 262174 34335 0 6 0   已选择6行。   SQL>

        说明:“TYPE”列表示锁的类型;“LMODE”列表示锁的模式;“ID1”和“ID2”列是锁的相关信息。“REQUEST”列是正在什么锁。

        SID=118 是第一个会话,SID=137 是第二个会话。第三行,第一个会话 BLOCK=1 表示这个会话正在阻塞其他会话,LMODE=6 表示锁的模式,即行级排他锁。第六行,第二个会话 REQUEST=6 表示当前会话正在等待一个 LMODE=6 的锁。注意,第三行和第六行的 ID1 和 ID2 列完全相同。因为它们指向统一资源,只不过一个是资源的拥有者(SID=118),一个是资源的等待者(SID=137)。

        通过这个视图,很容易发现所在——故障定位(trouble shooting)。会话 2 之所以被“卡”住,是因为会话 1 还没提交,而在这张表上,又恰好有要求列值唯一性约束。

        通过 SID 号,查看视图 V$SESSION 就可以确定用户信息。

SQL> select machine from v$session where sid in (118,137);   MACHINE ---------------------------------------------------------------- NUODE\LN NUODE\LN   SQL>

        因为,两个会话是同一台机器,所以名字一样。

本文链接


    
最新技术文章:
▪current online redo log缺失后的恢复
▪ORA-600 2662错误解决实例
▪ORA-00600 2662错误解决方法
▪Oracle Hidden Parameter:_allow_resetlogs_corruption
▪Oracle诊断事件列表
▪Oracle 隐含参数 _disable_logging 详解
▪ORA-00600 [2662]错误解决过程
▪Oracle里常见的执行计划
▪Oracle里另外一些典型的执行计划
▪Oracle服务器自动备份
▪Oracle固定SQL的执行计划(一)---SQL Profile
▪Oracle固定SQL的执行计划(二)---SPM iis7站长之家
▪同一环境下新建Standby RAC库
▪Oracle快速克隆安装
▪Oracle单实例启动多个实例
▪Oracle的PLSQL别名中文出现乱码解决方法
▪ORA-00379: no free buffers available in buffer pool DEFAULT ...
▪RMAN-06023: no backup or copy of datafile 16 found to restor...
▪RMAN还原数据库报错问题解决案例
▪OEL6.8_X86平台部署Oracle 10gR2检测失败问题
▪Oracle 性能优化建议
▪Oracle SQL语句优化心得
▪Oracle慢SQL监控脚本实现
▪Oracle dblink 查询 tns:无法解析指定的连接标识...
▪Red Hat Enterprise Linux 6使用udev配置Oracle ASM总结...
▪Linux6.6及以上版本配置Oracle ASM共享储存-UDEV
▪Oracle 12C 开启数据库归档模式
▪Solairs系统中配置Oracle 12c 开机启动
▪重建DBMS_STATS解决ORA-31626 ORA-21633以及ORA-04063 ORA...
▪Oracle ASMM 与AMM之间相互切换
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,