龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

ORACLE数据库PL/SQL编程之把过程与函数说透(1)(3)

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
第三种参数传递格式:组合传递。 即在调用一个函数时,同时使用位置表示法和名称表示法为函数传递参数。采用这种参数传递方法时,使用位置表示法

第三种参数传递格式:组合传递。

即在调用一个函数时,同时使用位置表示法和名称表示法为函数传递参数。采用这种参数传递方法时,使用位置表示法所传递的参数必须放在名称表示法所传递的参数前面。也就是说,无论函数具有多少个参数,只要其中有一个参数使用名称表示法,其后所有的参数都必须使用名称表示法。

例4:

  1. CREATE OR REPLACE FUNCTION demo_fun(  
  2.  
  3. Name VARCHAR2,--注意VARCHAR2不能给精度,如:VARCHAR2(10),其它类似  
  4.  
  5. Age INTEGER,  
  6.  
  7. Sex VARCHAR2)  
  8.  
  9. RETURN VARCHAR2 AS  
  10.  
  11. V_var VARCHAR2(32);BEGIN  
  12.  
  13. V_var :name||':'||TO_CHAR(age)||'岁.'||sex;  RETURN v_var;END;DECLARE  
  14.  
  15. Var VARCHAR(32);BEGIN  Var :demo_fun('user1', 30, sex => '男');  
  16.  
  17. DBMS_OUTPUT.PUT_LINE(var);  Var :demo_fun('user2', age => 40, sex => '男');  
  18.  
  19. DBMS_OUTPUT.PUT_LINE(var);  Var :demo_fun('user3', sex => '女', age => 20); 

无论采用哪一种参数传递方法,实际参数和形式参数之间的数据传递只有两种方法:传址法和传值法。所谓传址法是指在调用函数时,将实际参数的地址指针传递给形式参数,使形式参数和实际参数指向内存中的同一区域,从而实现参数数据的传递。这种方法又称作参照法,即形式参数参照实际参数数据。输入参数均采用传址法传递数据。

传值法是指将实际参数的数据拷贝到形式参数,而不是传递实际参数的地址。默认时,输出参数和输入/输出参数均采用传值法。在函数调用时,ORACLE将实际参数数据拷贝到输入/输出参数,而当函数正常运行退出时,又将输出形式参数和输入/输出形式参数数据拷贝到实际参数变量中。

3. 参数默认值

在CREATE OR REPLACE FUNCTION 语句中声明函数参数时可以使用DEFAULT关键字为输入参数指定默认值。

例5:

  1. CREATE OR REPLACE FUNCTION demo_fun(  Name VARCHAR2,  
  2.  
  3. Age INTEGER,  
  4.  
  5. Sex VARCHAR2 DEFAULT '男')  
  6.  
  7. RETURN VARCHAR2 AS  
  8.  
  9. V_var VARCHAR2(32);BEGIN  
  10.  
  11. V_var :name||':'||TO_CHAR(age)||'岁.'||sex;  
  12.  
  13. RETURN v_var;END; 

具有默认值的函数创建后,在函数调用时,如果没有为具有默认值的参数提供实际参数值,函数将使用该参数的默认值。但当调用者为默认参数提供实际参数时,函数将使用实际参数值。在创建函数时,只能为输入参数设置默认值,而不能为输入/输出参数设置默认值。

  1. DECLARE var VARCHAR(32);BEGIN Var :demo_fun('user1', 30);  
  2.  
  3. DBMS_OUTPUT.PUT_LINE(var); Var :demo_fun('user2', age => 40);  
  4.  
  5. DBMS_OUTPUT.PUT_LINE(var); Var :demo_fun('user3', sex => '女',  
  6.  
  7. age => 20); DBMS_OUTPUT.PUT_LINE(var);END; 

关于PL/SQL编程中函数和过程的相关知识就介绍到这里,如果想了解更多Oracle数据库的知识请到我们网站的Oracle专栏:http://database.51cto.com/oracle/,谢谢大家的支持!

精彩图集

赞助商链接