学会了存储过程,存储函数就很简单了。
概念上,存储函数比存储过程多了个返回值。使用方式和以前学过的系统函数相同,如: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 ;
运行结果:
存储函数的修改删除,和存储过程类似。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
2020-12-25 邻接矩阵有向图拓扑排序