欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

oracle知识杂记

程序员文章站 2022-07-13 08:13:39
...
  • 索引类型

             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;