数据库自定义函数

简介: 一、函数   在数据库中都有函数,这些函数属于系统函。除此之外用户也可以编写用户自定义函数。用户定义函数是存储在数据库中的代码块,可以把值返回到调用程序。调用时如同系统函数一样,如max(value)函数,其value被称为参数。

一、函数

  在数据库中都有函数,这些函数属于系统函。除此之外用户也可以编写用户自定义函数。用户定义函数是存储在数据库中的代码块,可以把值返回到调用程序。调用时如同系统函数一样,如max(value)函数,其value被称为参数。函数一般功能比较简单,对于mysql函数只有传入参数,不像存储过程一样,有输入输出参数。

  数据库函数特点如下:

  • 存储函数将向调用者返回一个且仅返回一个结果值。
  • 存储函数嵌入在sql中使用的,可以在select中调用,就像内建函数一样,比如cos()、hex()。
  • 存储函数的参数类型类似于IN参数。

二、自定义函数

自定义函数简单语法:

CREATE FUNCTION 函数名称(
  变量名称 类型,
  变量名称 类型
)
RETURN 类型
BEGIN
  -- 声明, 语句要完成的操作,
RETURN 变量;
END;

三、实例

  例子中的函数使用mysql作为例子。 表结构如下:

DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `password` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;

   1、不带参数的函数

DROP FUNCTION IF EXISTS get_count;
 -- 定义函数
CREATE FUNCTION get_count() 
RETURNS INT -- 返回值类型
BEGIN 
     RETURN (SELECT COUNT(*) FROM person);
END;
-- 调用
SELECT get_count() AS 'total';

   表示获取person表的所有记录,没有参数,有数值返回值。

  2、带有参数的函数

DROP FUNCTION IF EXISTS get_age;
CREATE FUNCTION get_age(
         id INT(11)  -- 参数(参数可以多个)
)
RETURNS INT(11)    -- 返回值类型(只能有一个返回值)
BEGIN 
    DECLARE age INT; -- 定义变量
    SET age = (SELECT p.age FROM person p where p.id = id);
    IF(ISNULL(age)) THEN -- 查询到的年龄不存在(如id错误,没有记录存在)
        RETURN 0; 
    ELSE
        RETURN age;
    END IF;
END;
-- 函数调用
SELECT get_age(2) as 'age';

  表示通过id获取年龄,有id参数,有数值返回值。

  3、函数其他命令

SELECT get_age(2);    -- 函数的调用
SHOW FUNCTION STATUS; -- 查看所有函数
SHOW CREATE FUNCTION get_age; -- 查看具体函数
DROP FUNCTION  get_age;  -- 删除查看具体函数

  函数的功能一般都是比较简单的,如求某个值,格式转换等。不像存储过程,一般逻辑都比较复杂。

目录
相关文章
|
关系型数据库 Java 数据库
PostgreSql | 数据库 |自定义函数的设计和实现
PostgreSql | 数据库 |自定义函数的设计和实现
326 0
|
关系型数据库 MySQL 数据库
MySQL数据库(30):内置函数和自定义函数 function
MySQL数据库(30):内置函数和自定义函数 function
350 0
MySQL数据库(30):内置函数和自定义函数 function
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
135 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
4月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
3月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
3月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
3月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。

热门文章

最新文章