plsql及oracle基本对象使用

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1plsql基本操作及oracle基本对象
plsql基本操作
1、命令窗口、SQL窗口、测试窗口
2、数据表备份:
●创建备份表,plsql的三种备份方式
●备份查询出来的语句到csv、sql脚本,导出结果到excel

oracle基本对象
1、表
2、函数
函数和存储过程都是命名的预编译过的sql程序段。

函数必须要有返回值,只能返回一个值
3、存储过程
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集。

函数和存储过程的区别:
●返回值的区别,函数有1个返回值,而存储过程是通过参数返回的,可以有多个或者没有
●调用的区别,函数可以在查询语句中直接调用,而存储过程必须单独调用.
函数一般情况下是用来计算并返回一个计算结果而存储过程一般是用来完成特定的数据操作(比如修改、插入数据库表或执行某些DDL语句等等)
create or replace procedure p_jd
as
hello varchar2(20);
begin
select 'Hello World' into hello from dual;
dbms_output.put_line(hello);
end;
执行存储过程的方法
<1> execute p_jd; (SQL*PLUS中SQL>)
<2> begin
p_jd;
end;
4、包
包是用来存储相关程序结构的对象,他存储与数据字典中,包由两个分离的部分组成,包头(Package)和包体(Package body).包头是包的说明部分,是对外的操作接口,对应用是可见的,包体是包的代码的实现部分。

存放常量、变量、游标、函数、存储过程的容器,统一编译执行速度快。

5、触发器
<1>加强约束条件
<2>实现关联操作在一个表中修改数据导致另一个表数据的修改
触发器基本参数
after/before 以后/以前
insert/update/delete 触发的SQL语句
for each row 行级- 语句级
什么时候触发
--inserting(boolean值) insert语句
--updating(boolean值) update语句
--deleting(boolean值) delete语句
6、序列
序列sequence --- 自动编号---- IDENTITY (SQLSERVER)
create sequence seq1; 从1开始每次自动增加1 没有最大值
create sequence seq2
start with 1000 --起始值1000
increment by 2 --步长2
maxvalue 9000 --最大值9000
minvalue 900 --最小值900
cycle --循环序列
7、视图
视图的作用:隐藏数据,增加系统的安全性、视图不存放数据,只存放查询
保证了查询到的数据是和表中的数据是一致的,数据随着表的变化而变化。

8、数据库链
跨数据库取数据时使用
create database link yb
connect to erp identified by erp
using 'erp';
9、同义词
基于数据库链或者其他用户建立一种映射关系
10、job
oracle里定期执行。

2常见select语句优化
2.1避免使用‘* ‘
当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用‘*’是一个方便方法.不幸的是,这是一个非常低效的方法. 实际上,ORACLE在解析的过程中, 会将’*’依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间。

2.2选择最有效率的表名顺序
ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,因此FROM子句中写在最后的表(基础表driving table)将被最先处理. 在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表.当ORACLE处理多个表时, 会运用排序及合并的方式连接它们.首先,扫描第一个表(FROM子句中最后的那个表)并对记录进行派序,然后扫描第二个表(FROM子句中最后第二个表),最后将所有从第二个表中检索出的记录与第一个表中合适记录进行合并.
例如:
表TAB1 16,384 条记录
表TAB2 1 条记录
选择TAB2作为基础表(最好的方法)
select count(*) from tab1,tab2 执行时间0.96秒
选择TAB2作为基础表(不佳的方法)
select count(*) from tab2,tab1 执行时间26.09秒
2.3WHERE子句中的连接顺序
ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾. 例如:
(低效,执行时间156.3秒)
SELECT …
FROM EMP E
WHERE SAL > 50000
AND JOB = ‘MANAGER'
AND 25 < (SELECT COUNT(*) FROM EMP
WHERE MGR=E.EMPNO);
(高效,执行时间10.6秒)
SELECT …
FROM EMP E
WHERE 25 < (SELECT COUNT(*) FROM EMP
WHERE MGR=E.EMPNO)
AND SAL > 50000
AND JOB = ‘MANAGER';
2.4用EXISTS、表关联替代IN
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接.在这种情况下, 使用EXISTS(或NOT EXISTS)通常将提高查询的效率.
低效:
SELECT *
FROM EMP (基础表)
WHERE EMPNO > 0
AND DEPTNO IN (SELECT DEPTNO
FROM DEPT
WHERE LOC = ‘MELB')
高效:
SELECT *
FROM EMP (基础表)
WHERE EMPNO > 0
AND EXISTS (SELECT ‘X'
FROM DEPT
WHERE DEPT.DEPTNO = EMP.DEPTNO
AND LOC = ‘MELB')
2.5用NOT EXISTS替代NOT IN
在子查询中,NOT IN子句将执行一个内部的排序和合并. 无论在哪种情况下,NOT IN都是最低效的(因为它对子查询中的表执行了一个全表遍历). 为了避免使用NOT IN ,我们可以把它改写成外连接(Outer Joins)或NOT EXISTS.
例如:
SELECT …
FROM EMP
WHERE DEPT_NO NOT IN (SELECT DEPT_NO
FROM DEPT
WHERE DEPT_CAT='A');
为了提高效率.改写为:
(方法二: 最高效)
SELECT ….
FROM EMP E
WHERE NOT EXISTS (SELECT ‘X'
FROM DEPT D
WHERE D.DEPT_NO = E.DEPT_NO
AND DEPT_CAT = ‘A');
2.6用UNION、UNION ALL或者IN替换OR 高效:
SELECT LOC_ID , LOC_DESC , REGION
FROM LOCATION
WHERE LOC_ID = 10
UNION
SELECT LOC_ID , LOC_DESC , REGION
FROM LOCATION
WHERE REGION = “MELBOURNE”
低效:
SELECT LOC_ID , LOC_DESC , REGION
FROM LOCATION
WHERE LOC_ID = 10 OR REGION = “MELBOURNE”
低效
SELECT….
FROM LOCATION
WHERE LOC_ID = 10
OR LOC_ID = 20
OR LOC_ID = 30
高效
SELECT…
FROM LOCATION
WHERE LOC_IN IN (10,20,30);。

相关文档
最新文档