庄周梦蝶

生活、程序、未来
   :: 首页 ::  ::  :: 聚合  :: 管理

PL/SQL学习笔记(四)

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等事务控制语句,与直接使用没有什么不同。


只有注册用户登录后才能发表评论。


网站导航: