先讲讲Oracle数据库的索引
-- 索引 一定要建立在大数据量的基础上才有用 位图索引 大写函数索引 主键索引 唯一索引 方向键索引
-- 唯一索引
create unique index index_u_age on scott.student(sage);
-- 方向键索引
create unique index index_u_age on scott.student(sage) reverse;
-- 位图索引
create bitmap index index_u_age on scott.student(sage);
-- 大写函数索引
create index index_u_age on scott.student(upper(sage));
-- 删除索引
drop index index_u_age;
然后是同义词
Oracle的同义词(synonyms)从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系。它可以节省大量的数据库空间,对不同用户的操作同一张表没有多少差别;它扩展了数据库的使用范围,能够在不同的数据库用户之间实现无缝交互;Oracle数据库中提供了同义词管理的功能。同义词是数据库对象的一个别名,经常用于简化对象访问和提高对象访问的安全性。在使用同义词时,Oracle数据库将它翻译成对应方案对象的名字。与视图类似,同义词并不占用实际存储空间,只有在数据字典中保存了同义词的定义。在Oracle数据库中的大部分数据库对象,如表、视图、物化视图、序列、函数、存储过程、包、同义词等等,数据库管理员都可以根据实际情况为他们定义同义词。
-- 创建同义词
-- scott为用户,student为用户下的表
create or replace synonym SCOTT.S for SCOTT.STUDENT;
-- 同义词
select * from S;
select * from STUDENT;
--创建同义词后上面两条语句是一个意思
存储过程
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来调用存储过程。 简单的说就是专门干一件事一段sql语句。 可以由数据库自己去调用,也可以由java程序去调用。 在oracle数据库中存储过程是procedure。
-- 存储过程的创建
create procedure add_student(形参名称1 形参类型1,形参名称2 形参类型2, xxx xxx) is
begin
代码段
end;