数据库之自定义函数

MYSQL系统自带了很多函数,但是在我们生活或者是工作中,经常会用到里面不存在的函数,这时候就需要我们自己来创建自定义函数了。

一、创建不带参数的自定义函数

CREATE FUNCTION   f1()

RETURNS VARCHAR(30)

RETURN  NOW();

f1是创建的函数取名,可以自行定义

第二行描述的是返回值的类型

最后一行是返回的操作,其中NOW();可以改为其他函数;


二、创建带有参数的自定义函数

CREATE FUNCTION  f2(num1 SMALLINT UNSIGNED,num2 SMALLINT UNSIGNED)

RETURNS FLOAT(10,2) UNSIGNED

RETURN (num1+num2)/2;


FLOAT(10,2)10表示整数位加上小数位一共十位,2表示小数位。


三、创建复合结构函数的自定义函数(这里以往表格users添加username的记录为例

)

在不同的返回函数后面要用分号隔开,但是在MYSQL中输入分号就会自动执行,所以我们首先要修改终止符;

输入DELIMITER //;                 //DELIMITER后面有空格,空格后面跟的是修改后的终止符,这里选成//;


然后查看表格是否有了记录


至此,我们已经创建完成,然后记得把终止符改回来


DELIMITER ;


四、删除创建的自定义函数

drop function f3;



### 如何在数据库中创建和使用自定义函数 #### 使用 PostgreSQL 的内置语言 PL/pgSQL 创建自定义函数 为了展示如何利用 PostgreSQL 中的 PL/pgSQL 来构建自定义函数,这里给出一个简单的例子。此示例展示了怎样建立一个接受两个整数作为参数并返回两者之和的新函数。 ```sql CREATE OR REPLACE FUNCTION add_two_numbers(a integer, b integer) RETURNS integer AS $$ BEGIN RETURN a + b; END; $$ LANGUAGE plpgsql; ``` 上述 SQL 命令完成了新函数 `add_two_numbers` 的定义[^1]。 调用这个刚刚创建好的函数可以通过如下方式实现: ```sql SELECT add_two_numbers(3, 7); ``` 这会执行该函数并将传入的具体数值传递给它,从而得到两者的加总结果。 对于更复杂的逻辑处理需求,则可以充分利用 PL/pgSQL 提供的各种特性,比如变量声明、条件判断以及循环结构等来增强函数的功能性。 #### 利用外部编程语言如 Python 或 C 扩展 PostgreSQL 功能 除了内部过程化语言外,PostgreSQL 还允许开发者采用其他高级编程语言开发存储过程或触发器等功能组件。例如,在某些情况下可能希望借助 Python 实现特定业务逻辑;这时就需要先安装必要的扩展包以使目标语言成为合法的选择之一。 假设已经配置好了环境支持 Python 脚本运行于服务器端的话,那么就可以按照下面的方式去注册一个新的聚合函数用于计算列表内所有成员的最大公约数 (GCD): ```sql CREATE EXTENSION IF NOT EXISTS pltcl; CREATE AGGREGATE gcd_agg(integer) ( SFUNC = pgcd, STYPE = int4, INITCOND = '0' ); -- 定义辅助性的状态转换函数 CREATE OR REPLACE FUNCTION pgcd(int4, int4) RETURNS int4 IMMUTABLE STRICT AS $$ from math import gcd as _gcd return _gcd($1,$2) $$ LANGUAGE plpythonu; ``` 这段脚本首先引入了对 Tcl 解释器的支持(因为 Pl/PythonU 需要依赖于此),接着定义了一个名为 `pgcd()` 的 Python 函数用来求解每一对输入值之间的最大公因数,并最终将其封装成可累加的形式以便后续应用时更加方便快捷。 需要注意的是,当涉及到非官方维护的语言绑定模块时应当格外谨慎行事,确保遵循安全编码实践的同时也要留意性能方面的影响因素。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值