oracle知识杂记

  • 索引类型

1、B-树索引

分区索引、压缩索引、函数索引等都属于B-树索引

2、位图索引

3、索引组织表

  • 索引管理

1、普通单列索引
                   对where条件、group by,order by的列创建索引

语法:create index IDX_aa on tblName(columnName)

2、位图索引:
                   适用于大量重复值的列

语法:create bitmap index IDX_aa on tblName(columnName)

3、唯一索引:
                    创建主键和Unique constraint(唯一约束)时会自动创建唯一索引

语法:CREATE UNIQUE INDEX IDX_UNIQUEColumn ON table (column);

4、组合索引

多列组成的索引,引导列放在前面

5、分区索引

分区索引分为分区内局部索引和分区全局索引

6、函数索引
                    oracle支持对函数表达式(算数表达式、PL/SQL函数、程序包函数、SQL函数、用户自定义函数)创建索引

语法:CREATE INDEX index ON table (FUNCTION(column));

7、反向键索引

          create unique index IDX_sale on sales(id) global reverse;

8、压缩索引

          create index sales_fact_c1 on sales_fact(product, year, week) compress 2;

9、is null 或is not null

当列值与null进行比较时,不会使用单列索引,需要通过虚拟列创建多列索引

          create index IDX_n10 on t1(n1, 0)

10、索引组织表

在索引组织表中,表本身被组织成索引,所有的列值存储在索引树里面,使用主键进行数据行访问将只会包含索引访问,索引组织表适用于以下情况

1、数据行长度较短的表

2、大多使用主键列进行访问的表

  • oracle进入命令界面
       sqlplus /nolog
connect /as sysdba
  • oracle删除用户下的所有对象和数据文件

1、删除rrtong用户及其下面的所有对象

          drop user userName cascade;
          drop user rrtong 必须是这个用户下面没有任何对象才能使用
          drop user rrtong cascade 删除这个用户以及这个用户下的所有对象了

2、删除数据文件
                  方法一:

                drop tablespace tbs_name including contents and datafiles;

方法二:

                 cd /usr/oracle/app/oradata/orcl/
mv /usr/oracle/app/oradata/orcl/rrtong.dbf /home/backup/rrtong.dbf
  • oracle数据库导入/导出

方法一:使用toad界面导入/导出操作
                             1、先执行第5点删除用户和数据库实例
                             2、创建要导入的数据库用户和对应的表空间
                             3、参考以下链接,进行操作
                                   参考:http://blog.csdn.net/zouqingfang/article/details/36196431
                                   说明:含有虚拟列的表无法成功导出
              方法二:直接命令方式导入/导出操作
                              1、expdb导出
    
                              2、impdb导入

  • oracle定时备份

impdp edu_adm/pujinet DIRECTORY="DMP_DIR"  DUMPFILE="edu140611.dmp" SCHEMAS= "edu_adm"  logfile="import_20140612.log"  ;

  • 压缩表

1、NOCOMPRESS
                  表或分区不压缩,当没有具体指定压缩子句时这是默认行为
            2、COMPRESS
                  这个选项被认为适合于数据仓库系统,只在直接路径插入过程中在表或分区上启用压缩。
            3、COMPRESS FOR DIRECT_LOAD OPERATIONS
                  这个选项与COMPRESS关键字有同样的影响。
            4、COMPRESS FOR ALL OPERATIONS
                  这些选项被认为适合于OLTP系统,如名字暗示的那样,这些选项为所有操作启用了压缩,包括普通的DML语句。
                  这个选项需要COMPATIBLE初始化参数设置为11.1.0或更高。

  • 数据库链路配置

方法一:

在A服务器上操作

          vi /usr/oracle/app/oracle/product/11.2.0/dbhome_1/network/admin/tnsnames.ora
#添加以下内容
DBLINKB =
(DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = B服务器ip地址)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = orcl)
    )
)

然后再使用pl/sql创建数据库链路,输入数据库链路名称,输入对方数据库用户名和密码,再输入DBLINK(对应上面设置)

方法二: 同时也可以通过以下方式进行操作

         create database link link名称  connect to 对方数据库用户名 identified by 对方数据库用户密码 using '对方数据库ip:端口/实例名'
  • oracle查询失效的索引,并进行重建
      --查询失效的索引记录
select index_name ,status from user_indexes where Status = 'UNUSABLE' ;
--重建失效的索引
alter index PK_NOTICEKEY rebuild;
上一篇:C语言随笔_return答疑


下一篇:从谷歌官网下载android 6.0源码、编译并刷入nexus 6p手机