Oracle基础 12 对象 objects 同义词/序列/试图/索引
--创建同义词
create public synonym employees for hr.employees; --公共同义词
需要 create public synonym 权限
表的所有用户授予公共权限
grant select on employees to public;
create synonym t1_s for t1; --私有同义词
如果想在不同的环境中通过不同的别名引用同一个表时,要创建私有同义词。
编译同义词
alter synonym t1_s compile;
管理同义词
select table_name, synonym_name
from dba_synonyms
where owner='IKKI';
删除同义词
drop public synonym employees;
drop synonym t1_s;
--创建序列
create sequence seq1
increment by 1
start with 1
maxvalue 100 | minvalue 10 | nomaxvalue
cache | nocache
cycle | nocycle;
例如:
create sequence seq1
increment by 1
start with 10
maxvalue 999
nocache
nocycle;
查看序列
select * from user_sequences;
select seq1.nextval from dual;
select seq1.currval from dual;
使用序列
create table emp2(
id number(10),
name varchar2(20),
dept varchar2(20),
bh number(10)
);
insert into emp2(bh,id,name,dept)
values(seq1.nextval,302,'tom',2002);
--rowid
select rowid,bh,id,name
from emp2;
select * from emp2
where rowid='AAASOVAAEAAAAKOAAB';
--创建试图
create view my_employees as
select employee_id,first_name,last_name,salary
from employees
where manager_id=122
with read only; --用户只能从试图进行查询
删除试图
drop view my_employees;
物化试图
可以在物化试图上做以下事情:
在物化试图上创建索引;
在分区表上创建物化试图;
对物化试图进行分区。
刷新方式
on commit:用此方式,当一个主表的更改数据被提交时,物化试图被自动刷新以反应数据的更改。
on demand:用此方式,你必须执行诸如 DBMS_MVIEW.REFREST 这样的过程来更新物化试图。
刷新类型
complete:此刷新类型将完全重新计算基于物化试图的查询。如果物化试图原来花费12小时建立,那么重建也将花费同样的时间。显然,当主表中很少一部分行被更改、删除或插入时,不应该使用此选项。
fast:Oracle 将使用物化试图日志来记录主表的所有更改。然后使用物化试图日志来更新物化试图。物化试图日志是基于相应物化试图的表。在物化试图与联接相关的每个表都需要有自己的物化试图日志,以便捕捉表的更改。
force:如果选择此选项,Oracle 将尽量使用 fast 刷新机制,如果由于某些原因而不能使用该机制,则将使用 complete 刷新方法。此选项默认的刷新方法。
never:此刷新选项不刷新物化试图。显然,对于主表有许多更改的物化试图来说,这不是一个可行的选项。
使用 DBMS_MVIEW 程序包
创建物化试图
1、授予必要的权限
grant create materialized view to ikki;
grant query rewrite to ikki;
2、创建物化试图日志
create materialized view log
on products with sequence,rowid
(prod_id, prod_name, prod_desc, prod_subcategory,
prod_subcategory_desc, prod_category, prod_category_desc, prod_weight_class, prod_unit_of_measure, prod_pack_size, supplier_id,
prod_status, prod_list_price, prod_min_price)
including new values;
create materialized view log on sales
with sequence,rowid
(prod_id, cust_id, time_id, channel_id, promo_id,
quantity_sold, amount_sold)
including new values;
3、创建物化试图
create materialized view product_sales_mv
build immediate
refresh fast
enable query rewrite
as select p.prod_name, sum(s.amount_sold) as dollar_sales,
count(*) as cnt, count(s.amount_sold) as cnt_amt
from sales s, products p
where s.prod_id=p.prod_id
group by p.prod_name;
build immediate:立即建立物化试图,这是默认选项。另一种方法是使用 build deferred 选项,此选项将在以后某个指定时刻装载物化试图及其数据。
refresh fast:说明物化试图采用 fast 刷新方法。
enable query rewrite:表示 Oracle 优化程序将透明的重写查询以使用新创建的物化试图而不是基础的主表。
SQL> create materialized view log on ygb;
Materialized view log created.
SQL> create materialized view mv_ygb
2 refresh fast
3 as select * from ygb;
Materialized view created.
删除物化视图日志
SQL> drop materialized view log on ygb;
Materialized view log dropped.
删除物化视图
SQL> drop materialized view mv_ygb;
Materialized view dropped.
--创建索引
create index emp_tb_id on emp2(id);
删除索引
drop index emp_tb_id;
重建索引
alter index emp_tb_id rebuild;
alter index emp_tb_id rebuild online;
在进行索引的联机重建时,可以执行所有的 DML 操作,但不能执行任何 DDL 操作。
不可见索引
你可以把不可见索引作为临时索引,以便执行某些特殊操作,或者用来在索引成为正式索引前先对其进行测试。此外,有时使一个索引不可见可见替代删除索引或使其不可用。你可以使一个索引临时不可见来测试删除此索引的效果。
1、创建不可见索引
create index idx_test on test(tname)
invisible;
2、更改索引使其不可见
alter index idx_test invisible;
alter index idx_test visible;
3、查询索引是否可见
select index_name,visibility from user_indexes
where index_name='IDX_TEST';
--关于创建 Oracle 表的有效索引的准则:
1、如果需要访问的数据不超过表中的4%或5%,则可以使用索引。全表扫描适用于请求的数据占全表数据百分比较高的查询。请记住,用索引来检索行需要两个读操作:即读索引和读表。
2、相对较小的表应该避免使用索引。全表扫描很适合小表。对于小表不需要同时存储表的数据和索引的数据。
3、为所有表创建主键。在指定一列作为主键时,Oracle自动创建该列的索引。
4、对包括在多表联接操作中使用的列建立索引。
5、对 where 子句中频繁使用的列建立索引。
6、对包括在 order by 和 group by 操作的列或涉及排序的 union 和 distinct 等其他操作中的列建立索引。由于索引已经被排序,因此执行前述操作的排序要求将显著减少。
7、由长字符串组成的列通常不是索引的候选列。
8、被频繁更改的列由于涉及开销问题,理论上不建索引。
9、使索引数目较少。
10、当唯一列值可能不唯一时需要使用组合索引。在组合索引中,驱动列或第一列应该为选择性最强的列。
建立索引的黄金法则:表的索引应该基于你锁期望的查询中出现的表列。一个表可以创建多个索引:可以选择创建X列或Y列或二者的组合索引。
Oracle基础 12 对象 objects 同义词/序列/试图/索引的更多相关文章
- Oracle数据库对象(表空间/同义词/序列/视图/索引)
数据库对象 Oracle数据库对象: 数据库对象是数据库的组成部分,常常用 CREATE 命令进行创建,可以使用 ALTER 命令修改,用 DROP 执行删除操作. 种类: (1)表空间:所有的数据对 ...
- oracle 10g 学习之视图、序列、索引、同义词(9)
目标 通过本章学习,您将可以: l 描述视图 l 创建和修改视图的定义,删除视图 l 从视图中查询数据 l 通过视图插入, 修改和删除数据 l 使用“Top-N” 分析 l 创建, 维护, ...
- Oracle基础维护02-表、主键、索引、表结构维护手册
目录 一.项目新建表.主键.索引注意事项 二.举例说明建表.主建.索引的操作方法 2.1 设定需求如下 2.1.1 查询数据库有哪些表空间 2.1.2 本文档假设数据库有这两个业务用户的表空间 2.2 ...
- Oracle 学习笔记 12 -- 序列、索引、同义词
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/Topyuluo/article/details/24232449 数据库的对象包含:表.视图.序列. ...
- Oracle数据库对象_同义词
同义词是一种数据库对象,它是为一个数据库对象定义的别名,使用同义词的主要目的是为了简化SQL语句的书写. 同义词的概念和类型 利用同义词可以为用户的一个对象,或者其他用户的一个对象定义别名,从而简化命 ...
- Oracle——序列、索引、同义词
一.常见的数据库对象 二.序列 序列: 可供多个用户用来产生唯一数值的数据库对象 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以提高访问效率 ①.创建序列 CREATE SEQ ...
- Oracle系列十四 序列、索引和同义词
序列 : 提供有规律的数值.索引 : 提高查询的效率同义词 :给对象起别名 序列: 可供多个用户用来产生唯一数值的数据库对象 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以 ...
- Oracle对象(视图、序列、索引)
数据库对象:表.视图.序列.索引.同义词创建视图:create view 名 as 子查询描述结构:describe 对象名修改视图:create or replace view 名 as 子查询 视 ...
- oracle基础知识过一遍(原创)
用户.角色.权限.表空间 create tablespace test1_tablespace datafile ‘test1file.dbf’ size 10m; create temporary ...
随机推荐
- vs code 代码格式化整理
vs code格式化代码的快捷键如下:(来源于这里) On Windows Shift + Alt + F On Mac Shift + Option + F On Ubuntu Ctrl + Shi ...
- day-11 python自带库实现2层简单神经网络算法
深度神经网络算法,是基于神经网络算法的一种拓展,其层数更深,达到多层,本文以简单神经网络为例,利用梯度下降算法进行反向更新来训练神经网络权重和偏向参数,文章最后,基于Python 库实现了一个简单神经 ...
- DFS(1)——hdu1518Square
一.题目回顾 题目链接:Square 题意:给你M根木棒,请判断这些木棒能否组成正方形. 二.解题思路 DFS+剪枝 [变量说明] sum:木棒的总长度 ave:形成的正方形的边长 maxlen:最长 ...
- Android Service 服务(三)—— bindService与remoteService
(转自:http://blog.csdn.net/ithomer/article/details/7366396) 一.bindService简介 bindService是绑定Service服务, ...
- IDEA使用maven构建时控制台中文乱码的解决办法
使用maven clean install 项目时控制台中文乱码,解决办法如下: Setting->maven->runner VMoptions: -Dfile.encoding=UTF ...
- C#中async和await用法
.net 4.5中新增了async和await这一对用于异步编程的关键字. async放在方法中存在await代码的方法中,await放在调用返回Task的方法前. class Class1 { pr ...
- java线程(2)——模拟生产者与消费者
前言: 我们都听说过生产者和消费者的例子吧,现在来模拟一下.生产者生产面包,消费者消费面包.假定生产者将生成出来的面包放入篮子中,消费者从篮子中取.这样,当篮子中没有面包时,消费者不能取.当篮子满了以 ...
- Codeforces数据结构(水题)小结
最近在使用codeblock,所以就先刷一些水题上上手 使用codeblock遇到的问题 1.无法进行编译-------从setting中的编译器设置中配置编译器 2.建立cpp后无法调试------ ...
- 【考试记录】4.8 Table ( 数论数学 --组合数 & 杨辉三角)
陆陆续续的开始考很多的试,也会更新这些题目记录下来,免得做完了之后毫无印象,就这么水过去了(以前的考试都是如此,哎……) Table (T1) : 样例: 出于对数学题本能的恐惧考场上放弃了此题专攻T ...
- phaser常用API总结
1. 游戏画布的尺寸 var width = game.width, height = game.height; 2. 中心点坐标 var game = new Phaser.Game(...); ...