sql 存储过程中 如何使用declare 有的存储过程声明了,有的没有声明。请回答的详细点。。谢谢 200

 我来答
节子不哭
2017-07-27 · TA获得超过461个赞
知道小有建树答主
回答量:340
采纳率:85%
帮助的人:166万
展开全部

存储过程既可以有declare语句,也可以没有,declare声明的是一个语句块,是pl/sql执行的基本单位,

案例:一个基本的declare语句块

DECLARE
  e_invalid_department EXCEPTION; -- 声明部分,给例外命名
BEGIN
  UPDATE departments
     SET department_name = 'Oracle Technology Center'
   WHERE department_id = 60;
  IF SQL%NOTFOUND THEN
    RAISE e_invalid_department; -- 程序执行部分,使用raise 语句显示抛出例外
  END IF;
  COMMIT;
EXCEPTION
  WHEN e_invalid_department THEN --例外处理部分,处理抛出的例外
    DBMS_OUTPUT.PUT_LINE('No such department id.');
END;

一个简单的存储过程案例:

CREATE PROCEDURE query_emp(p_id     IN employees.employee_id%TYPE,
                           p_name   OUT employees.last_name%TYPE,
                           p_salary OUT employees.salary%TYPE,
                           p_comm   OUT employees.commission_pct%TYPE)
  AUTHID CURRENT_USER IS
BEGIN
  SELECT last_name, salary, commission_pct
    INTO p_name, p_salary, p_comm
    FROM employees
   WHERE employee_id = p_id;
END query_emp;
沐沐烟雨
2017-07-27 · TA获得超过337个赞
知道答主
回答量:49
采纳率:66%
帮助的人:8.3万
展开全部
如果你把存储过程看作是批处理语句就好理解多了!

存储过程只不过是一个带着名称的SQL批处理语句,如果在整个过程中需要变量时就是可以声明,但该变量声明后只能存活在批处理(存储过程)的运行中,运行完毕后就会消失,这种声明的格式就是
declare 变量名 类型
其中变量名为了与数据库中的列名相互区别,所以变量名有一个前置@符号,比如说
declare @count int
就是将变量@count声明为int类型的,以后可以使用变量@count作为整型变量使用。在这里可能有一些误解,有人认为@count是变量名,也有人认为count是变量名,而@只是一个符号,其实不管那一种理解对于声明变量上来说是不影响的,事实上应该来说@count被称为变量名较为合适些。

刚才说过,该变量声明后只存活于批处理或是存储过程的运行中而已,也就是说是一个局部变量,其实在SQL中还有一种变量是全局变量的,他们以@@开头,但目前的SQL中还不允许客户自己的声明全局变量,只是系统中存的。比如查询系统版本,就可以使用select @@version的方式进行查看的。因为不能够声明,所以不与declare一块使用的情况。

其实在SQL中将变量一词演译的非常深,还有一类变量就是表名,列名,存储过程等名称,这些名称其实也算是数据库的全局变量的,只要表存在,那么表名一定会存在于master数据库中的一个表中,列名也是一样,这一类的变量有一个特殊,都是已经存在的boject的,所以不须要进行声明,等于是建库或表时进行了声明,然后就可以了使用了,这种情况下的变量前边是没有@符号提示的。

所以一般情况下,我们只称@前置的为变量,没有前置的为数据库相关变量,而@@是系统变量不须声明。但只要是在使用@自定义的变量时,就必须选进行声明,而其他的则不须要。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式