函数的创建和调用及删除

Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645

函数和存储过程非常类似,也是可以存储在 Oracle 数据库中的 PL/SQL代码块,但是有返回值。

可以把经常使用的功能定义为一个函数,就像系统自带的函数(例如前面章节介绍的大小写转换,求绝对值等函数)一样使用。

函数创建的基本语法格式如下所示

CREATE OR REPLACE FUNCTION 函数名
[< 参数 1> INIOUTIIN OUT<参数类型 >[ 默认值 |:= 初始值 ]]
[,<参数 2> INIOUTIIN OUT< 参数类型 >[ 默认值 |:= 初始值 ],…]
RETURN 返回数据类型
ISIAS
[局部变量声明 ]
BEGIN
程序语句序列
[EXCEPTION]
异常处理语句序列
END 过程名

其中的参数说明如下。
(1)OR REPLACE 为可选参数,表示如果数据库中已经存在要创建的函数,则先把原先函数删除再重新建立函数,或者说覆盖原先的函数。
(2)如果过程中存在参数,则需要在参数后面使用“INIOUTIN OUT”关键字。

如果是输入参数则参数后面用“IN”关键字,表示接受外部过程传递来的值;如果是输出参数,

则参数后面用“OUT’关键字,表示此参数将在过程中被复制,并传递给过程体外;如果是“IN OUT”关键字,

则表示该参数既具有输入参数特性,又具有输出参数的特性。默认是 I 参数,即如果不写就默认为 IN 参数。

(3)参数类型不能指定长度,只需给出类型即可
(4)函数的返回类型是必选项
(5)局部变量声明中所定义的变量只在该函数中有效。

(6)局部变量声明、程序语句序列和异常处理语句序列定义以及使用同上一章 PL/SQL块。在函数的主程序段中,必须使用 RETURN 语句返回最终的函数值,并且返回值的数据类型要和声明的时候说明的类型一样。

函数的调用基本上与系统内置函数的调用方法相同。可以直接在 SQL Plus 中使用,也可以在存储过程中使用。后面将通过范例来介绍如何调用。
函数的删除与存储过程的删除类似,基本语法格式如下所示。

DROP FUNCTION 函数名

  • 21
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 14
    评论
要完成这个任务,你可以使用MySQL的自定义函数和条件语句来实现。以下是一个示例代码,演示如何创建一个名为show_sign的函数: ```sql DELIMITER // CREATE FUNCTION show_sign(birthdate DATE) RETURNS VARCHAR(20) DETERMINISTIC BEGIN DECLARE sign_name VARCHAR(20); SET sign_name = CASE WHEN (MONTH(birthdate) = 1 AND DAY(birthdate) >= 20) OR (MONTH(birthdate) = 2 AND DAY(birthdate) <= 18) THEN '水瓶座' WHEN (MONTH(birthdate) = 2 AND DAY(birthdate) >= 19) OR (MONTH(birthdate) = 3 AND DAY(birthdate) <= 20) THEN '双鱼座' WHEN (MONTH(birthdate) = 3 AND DAY(birthdate) >= 21) OR (MONTH(birthdate) = 4 AND DAY(birthdate) <= 19) THEN '白羊座' WHEN (MONTH(birthdate) = 4 AND DAY(birthdate) >= 20) OR (MONTH(birthdate) = 5 AND DAY(birthdate) <= 20) THEN '金牛座' WHEN (MONTH(birthdate) = 5 AND DAY(birthdate) >= 21) OR (MONTH(birthdate) = 6 AND DAY(birthdate) <= 21) THEN '双子座' WHEN (MONTH(birthdate) = 6 AND DAY(birthdate) >= 22) OR (MONTH(birthdate) = 7 AND DAY(birthdate) <= 22) THEN '巨蟹座' WHEN (MONTH(birthdate) = 7 AND DAY(birthdate) >= 23) OR (MONTH(birthdate) = 8 AND DAY(birthdate) <= 22) THEN '狮子座' WHEN (MONTH(birthdate) = 8 AND DAY(birthdate) >= 23) OR (MONTH(birthdate) = 9 AND DAY(birthdate) <= 22) THEN '处女座' WHEN (MONTH(birthdate) = 9 AND DAY(birthdate) >= 23) OR (MONTH(birthdate) = 10 AND DAY(birthdate) <= 22) THEN '天秤座' WHEN (MONTH(birthdate) = 10 AND DAY(birthdate) >= 23) OR (MONTH(birthdate) = 11 AND DAY(birthdate) <= 21) THEN '天蝎座' WHEN (MONTH(birthdate) = 11 AND DAY(birthdate) >= 22) OR (MONTH(birthdate) = 12 AND DAY(birthdate) <= 21) THEN '射手座' ELSE '摩羯座' END; RETURN sign_name; END // DELIMITER ; ``` 这个函数使用了CASE语句根据月份和日期来判断星座名称,并将结果存储在sign_name变量中。最后,通过RETURN语句返回星座名称。 要调用这个函数,你可以使用SELECT语句,如下所示: ```sql SELECT show_sign('1990-07-15'); ``` 这将返回出生日期为1990年7月15日的用户所属的星座名称。 要查看已创建函数,你可以使用SHOW FUNCTION STATUS语句,如下所示: ```sql SHOW FUNCTION STATUS; ``` 这将列出所有已创建函数。 要删除这个函数,你可以使用DROP FUNCTION语句,如下所示: ```sql DROP FUNCTION IF EXISTS show_sign; ``` 这将删除名为show_sign的函数。 请注意,以上代码是一个示例,你可以根据实际需求进行修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

橙子味冰可乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值