`
javaTo
  • 浏览: 24122 次
  • 性别: Icon_minigender_1
  • 来自: 飘着
社区版块
存档分类
最新评论

Oracle 开发 - 3

阅读更多
--[3]// Oracle PL/SQL 编程
-------------------------------------------------------------------------------------//
--创建错误信息表
CREATE TABLE ErrInfo
(
	ErrCode NUMBER(4) NOT NULL,
	ErrWord VARCHAR2(20) NOT NULL,
	ErrDate VARCHAR2(20) NOT NULL
);

--IF...ELSIF...ELSE...END IF;--------------------------------------//
DECLARE
	var1 NUMBER:=8;
BEGIN
	IF var1=1 THEN
		DBMS_OUTPUT.PUT_LINE('This NUMBER is ' || var1);
	ELSIF var1=2 THEN
		DBMS_OUTPUT.PUT_LINE('This NUMBER is ' || var1);
	ELSE
		DBMS_OUTPUT.PUT_LINE('Unknown the number');
	END IF;
END;
/
--CASE variable WHEN expression1 THEN value1;ELSE...END CASE;------//
--%ROWTYPE是指定义一个变量和数据库中某个表的一条记录数据类型一样,它指向该表的某一条记录
DECLARE 
	rec emp%ROWTYPE;
BEGIN
	SELECT  * INTO rec FROM emp WHERE ename='SCOTT';
	CASE  rec.sal
	WHEN 3000 THEN
		DBMS_OUTPUT.PUT_LINE('More than 3000');
	WHEN  2000 THEN
		DBMS_OUTPUT.PUT_LINE('More than 2000');
	ELSE
		DBMS_OUTPUT.PUT_LINE('Less than 2000');
	END CASE ;
END;
/
--LOOP...expression...EXIT WHEN expression...END LOOP--------------//
DECLARE
	var1 NUMBER:=1;
BEGIN
	LOOP
		DBMS_OUTPUT.PUT_LINE(var1);
		var1:=var1+1;
		EXIT WHEN var1=11;  --退出条件
	END LOOP;
END;
/
--WHILE...condition...LOOP...sentence...END LOOP;------------------//
DECLARE
	var1 NUMBER:=10;
BEGIN
	WHILE var1>=1  --退出条件
	LOOP
		DBMS_OUTPUT.PUT_LINE(var1);
		var1:=var1-1;
	END LOOP;
END;
/
--FOR...variable IN 1...10 LOOP...END LOOP;------------------------//
DECLARE

BEGIN
	FOR i IN 1..10 LOOP  --此条语句如变为 FOR i IN REVERSE 1..10 LOOP ,输出将为降序
		DBMS_OUTPUT.PUT_LINE(i);
 	END LOOP;
END;
/

--GOTO Label...;...;<<Label>>...;----------------------------------//
BEGIN
	GOTO a;  --程序将在一开始跳到标签a
	FOR i IN 1..10 LOOP
		DBMS_OUTPUT.PUT_LINE(i);
		IF i=5 THEN
			GOTO a;
		END IF;
	END LOOP;
	<<a>>
	DBMS_OUTPUT.PUT_LINE('This is new line');
END;
/
--嵌套实现9*9乘法表------------------------------------------------//
DECLARE
	i NUMBER:=0;
BEGIN
	WHILE i<9
	LOOP
		i:=i+1;
		DECLARE
			j NUMBER:=0;
		BEGIN
			WHILE j<i
			LOOP
				j:=j+1;
				DBMS_OUTPUT.PUT(j || '*' || i || '=' || i*j || ' ');
			END LOOP;
		END;
	DBMS_OUTPUT.PUT_LINE('');
	END LOOP;
END;
/

--异常处理---------------------------------------------------------//
--预定义异常
	--NO_DATA_FOUND		没有数据满足查询要求
	--ZERO_DIVIDE		算术错误,如试图用0去除一个数
	--INVALID_NUMBER	在要求数据的地方使用了非数据
	--NOT_LOGGED_ON		没有连接上Oracle
	--TOO_MANY_ROWS		SELECT INTO 返回多行记录
	--VALUE_ERROR		遇到算术的、转换的、截去的或约束错误
	--CURSOR_ALREADY_OPEN	试图打开一个已经打开的游标
	--DUP_VAL_ON_INDEX	试图插入一个已经存在的唯一约束值
	--LOGIN_DENIED		要求进入系统的请求被拒绝
	--TIMEOUT_ON_RESOURCE	等待的系统时间已经超时
	--OTHERS		其它异常

--NO_DATA_FOUND 异常-----------------------------------------------//
--%TYPE是指定义一个变量和数据库中某个表的某个字段的数据类型一样
DECLARE
	v_name emp.ename%TYPE;
BEGIN
	SELECT ename INTO v_name FROM emp WHERE empno='1234';  --异常发生,empno 中没有1234
	DBMS_OUTPUT.PUT_LINE('Name is : ' || v_name);
EXCEPTION
	WHEN NO_DATA_FOUND THEN
		DBMS_OUTPUT.PUT_LINE('No Data Found');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--ZERO_DIVIDE 异常-------------------------------------------------//
BEGIN
	DBMS_OUTPUT.PUT_LINE(5/0);  --异常发生,不能被0除
EXCEPTION
	WHEN ZERO_DIVIDE THEN
		DBMS_OUTPUT.PUT_LINE('Can not divide zero');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--TOO_MANY_ROWS 异常-----------------------------------------------//
DECLARE
	no emp.empno%TYPE;
	name emp.ename%TYPE;
	dept emp.deptno%TYPE;
BEGIN
	SELECT empno,ename,deptno INTO no,name,dept FROM emp WHERE empno = 7369;
	DBMS_OUTPUT.PUT_LINE('员工号 :' || no);
	DBMS_OUTPUT.PUT_LINE('员工名 :' || name);
	DBMS_OUTPUT.PUT_LINE('部门号 :' || dept);
EXCEPTION
	WHEN NO_DATA_FOUND THEN
		DBMS_OUTPUT.PUT_LINE('7369雇员不存在');  --未找到数据
	WHEN TOO_MANY_ROWS THEN
		DBMS_OUTPUT.PUT_LINE('有多个学员号是7369');  --返回多行
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--DUP_VAL_ON_INDEX 异常--------------------------------------------//
BEGIN
	INSERT INTO emp
	VALUES('7788','LaoZhao','Soft','7689','03-12月-81','2600','0','20');
EXCEPTION
	WHEN DUP_VAL_ON_INDEX THEN
		DBMS_OUTPUT.PUT_LINE('违反了PRIMARY KEY约束:7788雇员已经存在');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
-------------------------------------------------------------------//
--如果员工7788的工资小于3000,则更新为3000,如未找到该雇员,则利用异常处理打印相应信息
DECLARE
	salary emp.sal%TYPE;
BEGIN
	SELECT sal INTO salary FROM emp WHERE empno='7788';
	IF salary < 3000 THEN
		UPDATE emp SET sal = '3000' WHERE empno = '7788';
		DBMS_OUTPUT.PUT_LINE('记录已更新');
	ELSE
		DBMS_OUTPUT.PUT_LINE('IF 条件不成立');
	END IF;
EXCEPTION
	WHEN NO_DATA_FOUND THEN
		DBMS_OUTPUT.PUT_LINE('7788雇员不存在');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/

--用户自定义异常---------------------------------------------------//
--001
DECLARE
	--v_num1 NUMBER:=5;
	v_num1 NUMBER:=0;
	--v_num2 NUMBER:=0;
	v_num2 NUMBER:=5;
	MyException EXCEPTION;
BEGIN
	DBMS_OUTPUT.PUT_LINE(v_num1/v_num2);	
		RAISE MyException;  --引发自定义异常
	
	DBMS_OUTPUT.PUT_LINE('OK');  --此句永远不会执行,因为发生异常后程序将直接跳到EXCEPTION段
EXCEPTION
	WHEN MyException THEN
		DBMS_OUTPUT.PUT_LINE('Cannot Divide Zero');
	--WHEN ZERO_DIVIDE THEN
	--	DBMS_OUTPUT.PUT_LINE('Can not Divide Zero');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--002
DECLARE
	id score.id%TYPE;
	java score.java%TYPE;
	MyException EXCEPTION;
BEGIN
	SELECT id,java INTO id,java FROM score WHERE id = 4;
	IF java < 0 OR java > 100 THEN
		RAISE MyException;
	ELSE
		DBMS_OUTPUT.PUT_LINE('OK');
	END IF;

EXCEPTION
	WHEN MyException THEN
		UPDATE score SET java=0 WHERE id = 4;
		DBMS_OUTPUT.PUT_LINE('分数不能大于100或小于0,现已经清0');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--003
DECLARE
	v_date emp.hiredate%TYPE;
	MyException EXCEPTION;
BEGIN
	INSERT INTO emp(empno,hiredate)
		VALUES(1111,TO_DATE('2010-12-25','yyyy-mm-dd'));
	COMMIT;
	SELECT hiredate INTO v_date FROM emp WHERE empno=1111;
	IF v_date > SYSDATE THEN
		RAISE MyException;
	END IF;
	DBMS_OUTPUT.PUT_LINE('执行完毕');
EXCEPTION
	WHEN MyException THEN
		DBMS_OUTPUT.PUT_LINE('雇用日期不能大于当前日期');
		--raise_application_error(-20002,'雇用日期不能大于当前日期');
		UPDATE emp SET hiredate = SYSDATE WHERE empno = 1111;
		DBMS_OUTPUT.PUT_LINE('日期已更新为当前日期');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/

--将定义好的异常与标准的ORACLE错误联系起来-------------------------//
--001
DECLARE
	MyException EXCEPTION;
	PRAGMA EXCEPTION_INIT(MyException,-00001);  --关联语句
BEGIN
	INSERT INTO emp(empno) VALUES(1234);  --发生异常,企图插入有Check约束的重复值
	COMMIT;  --插入后提交
	DBMS_OUTPUT.PUT_LINE('插入正常');
EXCEPTION
	WHEN MyException THEN
		DBMS_OUTPUT.PUT_LINE('ORA-00001: 违反了唯一约束');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--002
CREATE TABLE a
(
	id INT NOT NULL,
	name VARCHAR2(20) NOT NULL
);
DECLARE
	MyException EXCEPTION;
	PRAGMA EXCEPTION_INIT(MyException,-1400);  --关联语句
BEGIN
	INSERT INTO a(id) VALUES(1);  --发生异常,违反了NOT NULL约束
EXCEPTION
	WHEN MyException THEN
		DBMS_OUTPUT.PUT_LINE('错误代号:-1400');
		DBMS_OUTPUT.PUT_LINE('错误描述:违反了NOT NULL约束');
		DBMS_OUTPUT.PUT_LINE('错误发生时间:' || 
					TO_CHAR(SYSDATE,'yyyy-mm-dd hh24:mi:ss'));
		INSERT INTO errinfo 
	  	  VALUES('-1400','违反了 NOT NULL约束',TO_CHAR(SYSDATE,'yyyy-mm-dd hh24:mi:ss'));
		DBMS_OUTPUT.PUT_LINE('已经将错误记录在ErrInfo表');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--003
DECLARE
	MyException EXCEPTION;
	salary emp.sal%TYPE;
BEGIN
	SELECT sal INTO salary FROM emp WHERE empno = '7788';
	IF salary > 2000 THEN
		RAISE MyException;
	END IF;
EXCEPTION
	WHEN MyException THEN
		RAISE_APPLICATION_ERROR(-20001,'RAISE_APPLICATION_ERROR异常发生',FALSE); --TRUE
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--课后练习---------------------------------------------------------//
--001
DECLARE
	gz emp.sal%TYPE;
	MyExc EXCEPTION;
BEGIN
	SELECT sal INTO gz FROM emp WHERE ename='SCOTT';
	DBMS_OUTPUT.PUT_LINE('原工资 : ' || gz);
	IF gz < 2000 THEN
		RAISE MyExc;
	ELSE
		DBMS_OUTPUT.PUT_LINE('工资无需更新');
	END IF;
EXCEPTION
	WHEN MyExc THEN
		UPDATE emp SET sal = 3000 WHERE ename='SCOTT';
		DBMS_OUTPUT.PUT_LINE('记录已经更新');
		SELECT sal INTO gz FROM emp WHERE ename='SCOTT';
		DBMS_OUTPUT.PUT_LINE('更新后工资 : ' || gz);
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/
--002
DECLARE
	lo salgrade.losal%TYPE;
	hi salgrade.hisal%TYPE;
	MyExc EXCEPTION;
BEGIN
	INSERT INTO salgrade VALUES(6,2600,2400);
	COMMIT;
	SELECT losal,hisal INTO lo,hi FROM salgrade WHERE grade = 6;
	IF lo > hi THEN
		RAISE MyExc;
	ELSE
		DBMS_OUTPUT.PUT_LINE('记录已经插入');
	END IF;
EXCEPTION
	WHEN MyExc THEN
		--删除插入的记录并打印相应信息
		delete salgrade WHERE grade = 6;
		DBMS_OUTPUT.PUT_LINE('记录插入失败 LOSAL 必须小于 HISAL');
	WHEN OTHERS THEN
		DBMS_OUTPUT.PUT_LINE('Unknown Error');
END;
/

--附注-------------------------------------------------------------//
--如需在PL\SQL中进行值输入,
DECLARE
  num LONG;
BEGIN
  num := '&num';
  DBMS_OUTPUT.PUT_LINE('Input value is : ' || num);
END;
/
--注意:如果要使你在DBMS_OUTPUT.PUT_LINE(...)中显示的语句得以显示,则必须显示的调用
SET SERVEROUTPUT ON;
----------------------------------------------------------------------------------End//


分享到:
评论
1 楼 ilovemeimei 2007-05-09  
学习中

相关推荐

    Oracle专用Linux操作系统-OracleLinux-R6-U5-Server-x86_64

    3. **Ksplice技术**:Oracle Linux包含了Ksplice技术,允许在不重启系统的情况下应用内核补丁,减少了计划外的停机时间。 4. **DTrace工具**:Oracle Linux引入了源自Solaris的DTrace工具,用于实时分析和调试系统...

    oracle-support oracleasmlib kmod-oracleasm包

    Oracle ASM 是Oracle公司开发的一种集成的存储管理解决方案,它为Oracle数据库提供了自动化的磁盘管理和故障恢复功能。ASM能够简化存储配置,通过自动化的方式创建、扩展和管理磁盘组,同时提供高可用性和性能优化。...

    oracle-xe-11.2.0-1.0.x86_64.rpm.zip

    Oracle XE 11.2.0 是一款轻量级版本的 Oracle 数据库服务器,专为开发和小型生产环境设计。这款数据库系统以其易用性、免费和对资源的低需求而闻名,使得它成为个人开发者和小型企业理想的数据库解决方案。 在描述...

    oracleasm-support-2.1.8-1.el5.i386

    2. 已安装最新的内核开发包,因为ASM驱动需要与当前运行的内核版本匹配。 3. 用户具有足够的权限,通常需要root权限来安装和配置ASM。 安装过程通常涉及使用`rpm`命令,例如: ``` sudo rpm -ivh oracleasm-support...

    安装oracle11gR2数据库环境快速准备神器oracle-rdbms-server-11gR2-preinstall

    1. **自动安装所需RPM包**:Oracle数据库运行需要一系列特定的RPM包,包括开发库、管理工具等。oracle-rdbms-server-11gR2-preinstall会自动识别并安装这些必要的软件包,确保数据库能够正常运行。 2. **创建Oracle...

    oracle-database-server-12cR2-preinstall

    3. **用户和组设置**:创建并配置Oracle相关的用户和组,例如`oracle`用户和`dba`组,这些都是安装数据库时必需的。 4. **权限和安全配置**:执行必要的权限设置,确保敏感数据的安全,并遵循Oracle的最佳实践。 5...

    OracleClient-18C Oracle客户端,包括windows和Linux

    对于开发人员来说,OracleClient-18C提供了ODBC和JDBC驱动程序,使Java、C++、Python等语言的应用程序能够连接到Oracle数据库。同时,它还支持ODPI-C,这是一个开源的C接口,用于构建高性能的Oracle数据库连接器。 ...

    包装物流管理软件:Oracle二次开发-OraclePL-SQL编程技术

    包装物流管理软件:Oracle二次开发_OraclePL-SQL编程技术.docx 包装物流管理软件:Oracle二次开发_Oracle包装物流管理软件二次开发基础.docx 包装物流管理软件:Oracle二次开发_Oracle数据库体系结构与管理.docx ...

    oracleclient-basic-windows.x64-11.2.rar

    3. 设置环境变量,例如TNS_ADMIN指向包含tnsnames.ora文件的目录,该文件定义了Oracle数据库的网络服务名。 4. 安装ODBC驱动程序,通常涉及注册ODBC驱动程序并创建数据源名称(DSN),这样应用程序可以通过指定的DSN...

    tableau10.0-oracle-driver-x64.msi

    tableau10.0-oracle-driver-x64.msi,tableau开发oracle必须包

    OracleEBS-应用开发培训.pptx

    OracleEBS-应用开发培训

    ORACLE 8-8I开发使用手册

    3. **表和索引**:创建和管理表是数据库开发的基础。在Oracle 8-8i中,可以使用CREATE TABLE语句定义表结构,并通过CREATE INDEX创建索引来提高查询性能。 4. **PL/SQL**:PL/SQL是Oracle的内置过程语言,用于编写...

    OracleClient-21C Oracle客户端,包括windows和Linux

    OracleClient-21C是Oracle公司推出的最新版数据库客户端,主要为用户提供与Oracle数据库服务器进行交互的工具和接口。这个版本适用于Windows和Linux操作系统,确保了跨平台的兼容性和灵活性,满足不同用户环境的需求...

    oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm

    1)rpm格式包安装配置 1.1 下载以rpm后缀名的包,以11.2.0.4.0 版本为例...oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm --包含头文件和示例文件,为开发Oracle应用程序的即时客户端; 1.2 使用rpm -ivh

    oracle-SpringBoot Oracle示例-Samples.zip

    这个压缩包很可能包含了一系列Java代码、配置文件和其他必要的资源,用于演示如何在实际开发环境中设置和操作Oracle数据库。 描述中的"oracle_SpringBoot Oracle示例_Samples"进一步确认了这个压缩包的内容,它是一...

    oracle X5-2 产品手册-中文

    - **快速供应测试环境和开发环境**: 使用数据库和VM快照技术加速开发周期。 - **单一供应商提供支持**: 所有硬件和软件组件均由Oracle统一支持,简化了技术支持流程。 综上所述,Oracle数据库机X5-2通过其强大的...

    OracleEBS-报表开发工具

    ### OracleEBS-报表开发工具知识点详解 #### 一、Oracle Report Builder **1.1 概述** Oracle Report Builder 是 Oracle 最初推出的报表开发工具之一。即使在 R12 版本中,它仍然是创建打印凭证等报表的首选工具。...

    oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm

    oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm --包含头文件和示例文件,为开发Oracle应用程序的即时客户端; 1.2 使用rpm -ivh [包名] 进行安装, 如:rpm -ivh oracle-instantclient11.2-basic-11.2....

    OracleClient-19C Oracle客户端,包括windows和Linux

    3. **sqlnet.ora**:此文件控制Oracle网络服务的行为,比如认证方式、加密策略、超时设置等。 4. **ldap.ora**:如果使用LDAP(轻量级目录访问协议)进行身份验证,此文件会包含相关的配置信息。 5. **network/...

    oracle-instantclient12.1-basic-12.1.0.2.0-1.x86_64.rpm

    Oracle Instant Client是Oracle公司提供的一款轻量级的数据库连接工具,用于在Linux系统上与Oracle数据库进行通信...它可以用于开发、测试和监控数据库,而无需完整安装Oracle数据库服务器,从而降低了系统资源的占用。

Global site tag (gtag.js) - Google Analytics