1.尽可能了解oracle的功能,因为很多业务逻辑oracle已经为我们做了,比如oracle已经预定义了大量的异常代码,我们不必要写自己的异常而增加代码的复杂度。

例如oracle定义了当找不到符合要求的数据时定义的异常:no_data_found,而很多开发人员经常使用自己的逻辑去判断是否找到数据。

 declare
ln_deptno number;
ln_tempno number:=1;
begin
select deptno into ln_deptno
from scott.dept
where deptno=ln_tempno;
dbms_output.put_line(ln_deptno);
exception
when no_data_found then
dbms_output.put_line('No deptno for: '||ln_tempno);
end;
/ SQL> @a.sql;
No deptno for: 1 PL/SQL procedure successfully completed.

  2.管线表函数,可以把她的返回值作为像数据库表 一样在查询语句中使用。

 create or replace type color_hex_code as object
(
color_name varchar2(10),
color_code varchar2(10)
);
/
create or replace type color_type as table of color_hex_code;
/
create or replace function f_pipeline_test return color_type pipelined as
begin
pipe row(color_hex_code('black','#000000'));
pipe row(color_hex_code('red','#ff0000'));
pipe row(color_hex_code('green','#00ff00'));
pipe row(color_hex_code('blue','#0000ff'));
pipe row(color_hex_code('white','#ffffff'));
return;
end;
/ SQL> select * from table(f_pipeline_test); COLOR_NAME COLOR_CODE
---------- ----------
black #000000
red #ff0000
green #00ff00
blue #0000ff
white #ffffff

  3.传址函数的几种类型

 create or replace function adding
(a in number,b in out number)
return number is
begin
b :=b+1;
return a+b;
end;
/
variable one number;
/
variable two number;
/
begin
:one :=1;
:two :=0;
end;
/
variable output number;
/
call adding(:one,:two) into :output;
/
call adding(:one,:two) into :output;
/ select :one, :two from dual; :ONE :TWO
---------- ----------
1 4

  4.使用rollup对分组数据进行汇总

 select deptno,sum(sal) from emp where deptno is not null
group by rollup(deptno); DEPTNO SUM(SAL)
---------- ----------
10 8750
20 10875
30 9400
29025

  5.使用cube对分组内每一组的数据和总数据同时汇总,同时包含对不同分组依据进行汇总

 select deptno,job,sum(sal) from emp where deptno is not null
group by cube(deptno,job)
order by deptno,job; DEPTNO JOB SUM(SAL)
---------- --------- ----------
10 CLERK 1300
10 MANAGER 2450
10 PRESIDENT 5000
10 8750
20 ANALYST 6000
20 CLERK 1900
20 MANAGER 2975
20 10875
30 CLERK 950
30 MANAGER 2850
30 SALESMAN 5600
30 9400
ANALYST 6000
CLERK 4150
MANAGER 8275
PRESIDENT 5000
SALESMAN 5600
29025 18 rows selected.

  6.使用grouping sets 只显示汇总,不列出原始分组数据

 SELECT deptno,job,SUM(sal)
FROM emp
WHERE deptno IS NOT NULL
GROUP BY GROUPING SETS(deptno,job)
ORDER BY deptno,job; DEPTNO JOB SUM(SAL)
---------- --------- ----------
10 8750
20 10875
30 9400
ANALYST 6000
CLERK 4150
MANAGER 8275
PRESIDENT 5000
SALESMAN 5600

  7.grouping_id函数可以用来标记汇总数据的行,比如第一个维度的汇总用1表示,第二个维度的汇总用2表示,两个维度的所以汇总用3表示。因此可以过滤未汇总的行。

 ELECT deptno,job,
GROUPING_ID(deptno,job),SUM(sal)
FROM emp
WHERE deptno IS NOT NULL
GROUP BY CUBE(deptno,job)
HAVING GROUPING_ID(deptno,job) > 0
ORDER BY deptno,job; DEPTNO JOB GROUPING_ID(DEPTNO,JOB) SUM(SAL)
---------- --------- ----------------------- ----------
10 1 8750
20 1 10875
30 1 9400
ANALYST 2 6000
CLERK 2 4150
MANAGER 2 8275
PRESIDENT 2 5000
SALESMAN 2 5600
3 29025

  8.利用子查询克隆表结构

 CREATE TABLE emp2
AS
SELECT *
FROM scott.emp
WHERE 1=2; SQL> SELECT * FROM emp2; no rows selected

  9.用户查看自身表的使用情况(user_extents)

  SELECT segment_name,segment_type,
tablespace_name,
bytes/1024/1024 "size",
blocks from user_extents; SEGMENT_NAME SEGMENT_TYPE TABLESPACE_NAME size BLOCKS
-------------------- ------------------ ------------------------------ ---------- ----------
ORDERS TABLE USERS .0625 8
EMP TABLE USERS .0625 8
EMP2 TABLE USERS .0625 8

  10.用户查看自身表的使用情况(user_segments)

 SELECT segment_name,segment_type,tablespace_name,
bytes/1024/1024 byt,buffer_pool
FROM user_segments; SEGMENT_NAME SEGMENT_TYPE TABLESPACE_NAME BYT BUFFER_
---------------------------------------- ------------------ ------------------- ---------- -------
EMP2 TABLE USERS .0625 DEFAULT
EMP TABLE USERS .0625 DEFAULT
ORDERS TABLE USERS .0625 DEFAULT
BIN$iZfhhmba19rgQKjAZQETvA==$0 TABLE USERS .0625 DEFAULT
BIN$iZfhhmbZ19rgQKjAZQETvA==$0 TABLE USERS .0625 DEFAULT
BIN$iZfhhmbY19rgQKjAZQETvA==$0 TABLE USERS .0625 DEFAULT

pl sql练习(2)的更多相关文章

  1. Oracle PL/SQL随堂笔记总结

    1.pl/sql编程 2.存储过程 3.函数 4.触发器 5.包 6.pl/sql基础 -定义并使用变量 7.pl/sql的进阶 8.oracle的视图 1.pl/sql编程 1.理解oracle的p ...

  2. Oracle学习笔记十 使用PL/SQL

    PL/SQL 简介 PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言,是对 SQL 的扩展,它支持多种数据类型,如大对象和集合类型,可使用 ...

  3. PL/SQL连接错误:ora-12705:cannot access NLS data files or invalid environment specified

    适合自己的解决方法: 排查问题: 1. 你没有安装Oracle Client软件.这是使用PL/SQL Developer的必须条件.安装Oracle Client后再重试.2. 你安装了多个Orac ...

  4. PL/SQL循环

    1.if循环做判断 SET SERVEROUTPUT ON accept num prompt 'qinshuu'; DECLARE pnum NUMBER :=& num ; BEGIN T ...

  5. PL/SQL存储过程编程

    PL/SQL存储过程编程 /**author huangchaobiao *Email:huangchaobiao111@163.com */ PL/SQL存储过程编程(上) 1. Oracle应用编 ...

  6. PL/SQL连接Oracle数据库,中文乱码,显示问号

    问题描述: 登陆PL/SQL,执行SQL语句后,输出的中文标题显示成问号????:条件包含中文,则无数据.         如果不是中文,需要修改注册表值,方法如下: 进入注册表:Win+r,输入re ...

  7. PL/SQL客户端中执行insert语句,插入中文乱码

    问题描述:在PL/SQL客户端中执行insert语句,插入中文乱码 解决方案: 1.执行脚本 select userenv('language') from dual;    结果为AMERICAN_ ...

  8. PL/SQL Developer如何连接64位的Oracle图解

    在64位Win7系统上安装64位的Oracle数据库,但是没有对应的64位PL/SQL Developer,此时就不能使用PL/SQL Developer来进行直接连接的,所以要想实现连接还得需要其他 ...

  9. 每周一书《Oracle 12 c PL(SQL)程序设计终极指南》

    本周为大家送出的书是<Oracle 12 c PL(SQL)程序设计终极指南>,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著. 内容简介: <Oracle 12c PL/SQ ...

  10. pl/sql里的exists和in的差别

    项目中有个需要需要如下pl/sql(数据库是MariaDB) ) AS small FROM cmp_ent_main a WHERE createTime<'2016-9-21' ,,) ) ...

随机推荐

  1. PHP学习笔记二十一【全局变量】

    <?PHP //定义全局变量 global $a; $a=9; //给全局变量赋值 function test1() { global $a; $a=45; } test1(); echo $a ...

  2. javascript版1024游戏源码

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  3. OpenCV——Sobel和拉普拉斯变换

    Sobel变换和拉普拉斯变换都是高通滤波器. 什么是高通滤波器呢?就是保留图像的高频分量(变化剧烈的部分),抑制图像的低频分量(变化缓慢的部分).而图像变化剧烈的部分,往往反应的就是图像的边沿信息了. ...

  4. PHP--变量部分知识点

    PHP全局变量 PHP全局变量作用域不同与C,在函数内部不可以使用全局变量,要在函数内部使用全局变量需要,global $var或者使用超全局变量数组$GLOBALS['var']. 静态变量 PHP ...

  5. Tomcat学习笔记 - 错误日志 - Tomcat安装版安装后第二次启动后闪退(转)-- javac不是内部或外部命令 -- 配置java环境教程

    如果安装成功并且安装完成第一次启动是成功的,第二次就闪退的话,原因之一是没有配置java的环境.在网上找的配制方法有很多错误,测试javac命令时候会提示不是内部或外部命令,找到一个正确的教程.如下, ...

  6. java压缩文件出现中文乱码问题

    在项目中需要压缩文件下载,做完了发现有中文乱码问题,终于明白了. 引入ant.jar包 import org.apache.tools.zip.ZipEntry;   import org.apach ...

  7. PyQuery基本操作介绍

    PyQuery基本操作介绍 PyQuery为Python提供一个类似于jQuery对HTML的操作方式,可以使用jQuery的语法对html文档进行查询操作. 本文以百度首页为例来介绍PyQuery的 ...

  8. 1006 Do the Untwist

    考察编程基础知识,用到字符和数字相互转化等.形式是描述清楚明文和暗文的转化规则. #include <stdio.h> #include <string.h> #define ...

  9. hdu 2489 Minimal Ratio Tree

    http://acm.hdu.edu.cn/showproblem.php?pid=2489 这道题就是n个点中选择m个点形成一个生成树使得生成树的ratio最小.暴力枚举+最小生成树. #inclu ...

  10. VIJOS 1889 天真的因数分解(莫比乌斯反演,容斥原理)

    https://vijos.org/p/1889 同BZOJ2440..,不过这题要求的是有因数因子的,所以莫比乌斯函数要稍微改一下 #include<algorithm> #includ ...