• Oracle——序列、索引、同义词


    一、常见的数据库对象

    二、序列

    序列: 可供多个用户用来产生唯一数值的数据库对象

    • 自动提供唯一的数值
    • 共享对象
    • 主要用于提供主键值
    • 将序列值装入内存可以提高访问效率

    ①、创建序列

    CREATE SEQUENCE sequence
           [INCREMENT BY n]  --每次增长的数值
           [START WITH n]    --从哪个值开始
           [{MAXVALUE n | NOMAXVALUE}]
           [{MINVALUE n | NOMINVALUE}]
           [{CYCLE | NOCYCLE}]     --是否需要循环
           [{CACHE n | NOCACHE}];  --是否缓存登录
    CREATE SEQUENCE dept_deptid_seq
    INCREMENT BY 1 
    START
    WITH 1
    MAXVALUE
    9999
    NOCACHE
    NOCYCLE
    INSERT INTO departments(department_id, department_name, location_id)
    VALUES (dept_deptid_seq.NEXTVAL, 'Support', 2500);

    ②、NEXTVAL 和 CURRVAL 伪列

    • NEXTVAL 返回序列中下一个有效的值,任何用户都可以引用
    • CURRVAL 中存放序列的当前值

    CURRVAL  应在 NEXTVAL之后指定 ,否则会报CURRVAL 尚未在此会话中定义的错误。

    ③、数据字典USER_SEQUENCES

    SELECT    sequence_name, min_value, max_value, 
        increment_by, last_number
    FROM    user_sequences;
    • 查询数据字典视图 USER_SEQUENCES 获取序列定义信息
    • 如果指定NOCACHE 选项,则列LAST_NUMBER 显示序列中下一个有效的值

    ④、使用序列

    1、将序列值装入内存可提高访问效率
    2、序列在下列情况下出现裂缝:

    • 回滚
    • 系统异常
    • 多个表同时使用同一序列

    3、如果不将序列的值装入内存(NOCACHE), 可使用表 USER_SEQUENCES 查看序列当前的有效值

    ⑤、修改序列

    ALTER SEQUENCE dept_deptid_seq
                   INCREMENT BY 20
                   MAXVALUE 999999
                   NOCACHE
                   NOCYCLE;

    ⑥、修改序列的注意事项

    • 必须是序列的拥有者或对序列有 ALTER 权限
    • 只有将来的序列值会被改变
    • 改变序列的初始值只能通过删除序列之后重建序列的方法实现

    ⑦、删除序列

    • 使用 DROP SEQUENCE 语句删除序列
    • 删除之后,序列不能再次被引用
    DROP SEQUENCE dept_deptid_seq;
    Sequence dropped.

    三、索引

    • 一种独立于表的模式对象, 可以存储在与表不同的磁盘或表空间中
    • 索引被删除或损坏, 不会对表产生影响, 其影响的只是查询的速度
    • 索引一旦建立, Oracle 管理系统会对其进行自动维护, 而且由 Oracle 管理系统决定何时使用索引。用户不用在查询语句中指定使用哪个索引
    • 在删除一个表时,所有基于该表的索引会自动被删除
    • 通过指针加速 Oracle 服务器的查询速度
    • 通过快速定位数据的方法,减少磁盘 I/O

    ①、创建索引

    • 自动创建: 在定义 PRIMARY KEY 或 UNIQUE 约束后系统自动在相应的列上创建唯一性索引
    • 手动创建: 用户可以在其它列上创建非唯一的索引,以加速查询

    在一个或多个列上创建索引

    CREATE INDEX index
    ON table (column[, column]...);

    在表 EMPLOYEES的列 LAST_NAME 上创建索引

    CREATE INDEX emp_last_name_idx ON employees(last_name);
    
    Index created.

    ②、查询索引

    可以使用数据字典视图 USER_INDEXES 和 USER_IND_COLUMNS 查看索引的信息

    SELECT    ic.index_name, ic.column_name,
        ic.column_position col_pos,ix.uniqueness
    FROM    user_indexes ix, user_ind_columns ic
    WHERE    ic.index_name = ix.index_name
    AND    ic.table_name = 'EMPLOYEES';

    四、同义词-synonym

    CREATE SYNONYM e FOR employees;
    select * from e;
    • 为视图DEPT_SUM_VU 创建同义词
    CREATE SYNONYM  d_sum
    FOR  dept_sum_vu;
    Synonym Created.
    • 删除同义词
    DROP SYNONYM d_sum;
    Synonym dropped.
  • 相关阅读:
    openstack 介绍
    python实现图片批量剪裁的程序
    iOS开发多线程篇—GCD介绍
    block代码块介绍
    ios中的界面跳转方式
    NSNotificationCenter消息机制的介绍
    ios的手势操作之UIGestureRecognizer浅析
    collectionViewFlow的界面编写
    UITableView的简单应用介绍
    滚动视图创建
  • 原文地址:https://www.cnblogs.com/realshijing/p/8474416.html
Copyright © 2020-2023  润新知