Posted on 2007-02-11 19:57
dennis 阅读(1049)
评论(0) 编辑 收藏 所属分类:
数据库技术
这部分主要讲述在PL/SQL中如何访问oracle
(一)检索单行数据
在PL/SQL嵌入select语句,使用方法:
SELECT select_list INTO variable_name1,variable_name2,variable_name3... FROM TABLE WHRE condition
例:
DECLARE
v_sal
NUMBER
(
6
,
2
);
v_id
NUMBER
;
BEGIN
v_id:
=
'
&id
'
;
SELECT
salary
into
v_sal
FROM
employee
WHERE
id
=
v_id;
.
需要注意事项:
1.不仅可以使用普通标量接受数据,也可以使用Record接受数据
2.使用的SELECT语句必须返回一条记录,并且只能返回一条记录,否则会触发PL/SQL异常,或者显示错误信息
(1)NO_DATA_FOUND异常,当没有数据返回时抛出此异常
(2)TOO_MANY_ROWS异常,返回多条数据时抛出此异常
(3)在WHERE子句中使用变量时必须注意,变量名不能字段名相同,否则会触发TOO_MANY_ROWS异常
(二)使用DML语句
1.在PL/SQL中使用DML语句(insert,update,delete)语句与直接在sqlplus使用没什么不同,只不过可以使用变量代替具体的值,不再举例
2.SQL游标:
(1)在执行SELECT,INSERT,UPDATE,DELETE语句时,Oracle Server会为这些SQL语句分配相应的Context Area,并且Oracle使用此Context Area解析并执行相应的SQL语句,而游标就是指向Context Area的指针。在oracle中,游标又分为显式和隐式两种,其中隐式游标又被成为SQL游标,专门用于处理SELECT INTO,INSERT,DELETE,UPDATE语句。而显式游标多用于处理多行的SELECT语句。
(2)SQL游标的四种属性:
(A) SQL%ISOPEN
用于确定SQL游标是否打开。因为oracle在执行SELECT INTO,INSERT,UPDATE,DELETE语句时会隐含着打开游标,并在执行结束后关闭。所以此值对于开发人员来说一直是false,实际开发中不需要此属性
(B) SQL%FOUND
用于确定SQL语句是否执行成功,当SQL语句有作用行时,它为TRUE,否则为FALSE,如:
DECLARE
v_dept emp.deptno
%
TYPE;
BEGIN
UPDATE
emp
SET
sal
=
sal
*
1.1
WHERE
deptno
=&
no;
if
SQL
%
FOUND
then
dbms_output.put_line(
'
语句执行成功
'
);
else
dbms_output.put_line(
'
语句执行失败
'
);
end
if
;
END
;
(C)与SQL%FOUND相反的就是SQL%NOTFOUND
(D)SQL%ROWCOUNT ,用于返回SQL语句作用的行数
(三)事务控制语句
在PL/SQL中同样可以使用COMMIT,ROLLBACK,SAVEPOINT等事务控制语句,与直接使用没有什么不同。