万金流
以码会友。 吾Q:578751655。 水平有限,轻喷,谢!
随笔 - 189,  文章 - 0,  评论 - 7,  阅读 - 14万

学会了存储过程,存储函数就很简单了。

概念上,存储函数比存储过程多了个返回值。使用方式和以前学过的系统函数相同,如:year('2020-12-01')。

语法上,少许修改,多了一点关于返回值的东西。

例:

复制代码
 1 delimiter ~
 2 drop function if exists get_one~
 3 create function get_one(a varchar(20),b varchar(20))
 4 returns varchar(50)
 5 DETERMINISTIC
 6  begin
 7   declare c varchar(50);
 8   set c=concat(a,' and ',b,'are good friends.');
 9   return c;
10  end~
11 delimiter ;
复制代码

说明:

1、以上代码与存储过程相似,差不多把所有procedure替换为function。

2、第5行DETERMINISTIC用于声明该存储函数是确定性的,即相同输入总是相同输出,不会对可能存在的主从服务器造成不一致的影响,以避免1418错误。

3、第4行表示该存储过程返回一个字符串,第9行给出这个字符串是什么。

调用:

 

 另例:在数据库d1中,输入姓名,获得该学生的最高分:

复制代码
delimiter ~
drop function if exists get_one~
create function get_one(axm varchar(20))
returns int
DETERMINISTIC
 begin
  declare axh int;
  declare acj int;
  select xh into axh from t1 where xm=axm;
  select max(cj) into acj from t2 where xh=axh;
  return acj;
 end~
delimiter ;
复制代码

运行结果:

 存储函数的修改删除,和存储过程类似。

posted on   万金流  阅读(301)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
历史上的今天:
2020-12-25 邻接矩阵有向图拓扑排序

点击右上角即可分享
微信分享提示