首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用户定义的函数只能具有select语句。

用户定义的函数只能具有select语句。
EN

Stack Overflow用户
提问于 2018-04-27 13:06:13
回答 2查看 1.7K关注 0票数 0

UDF和SP的主要区别之一是,UDF只能在其中包含select语句,而不能插入/更新/delete语句。有谁能解释一下背后的原因吗?以下功能:

代码语言:javascript
运行
复制
create function test(..)
...
BEGIN 
insert into EMPLOYEE('22',12000,'john');
return 0;
END

是无效的。但为什么会这样呢?

EN

Stack Overflow用户

发布于 2018-04-27 14:01:30

为了总结这些注释,可以在PL/函数中使用。

您不能做的是从SQL调用该函数,因为select语句也不应该将更新和删除等应用于隐藏的副作用。

首先,SQL语言保留按任何顺序以任何方式执行查询的权利,以及它决定使用的任何缓存。(它甚至可能在执行期间停止并重新启动。这取决于SQL引擎。)因此,您的函数可能会按任何顺序被调用一次或一百次,这取决于执行计划,因此结果是不可预测的。

票数 2
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50063080

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档