An INSERT EXEC statement cannot be nested.
今天开发同事有咨询问题,报错An INSERT EXEC statement cannot be nested.
经过在网上查询,最终找到解决方案,具体见:http://www.sommarskog.se/share_data.html#INSERTEXEC
Demo如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | use demo go alter proc usp_a @a int as create table #a(id int ,editdt datetime) insert into #a select @a,getdate() select * from #a alter proc usp_b as create table #c (id int ,editdt datetime) insert into #c exec usp_a '2' select * from #c create table #d (id int ,editdt datetime) insert into #d exec usp_b select * from #d |
Msg 8164, Level 16, State 1, Procedure usp_b, Line 5
An INSERT EXEC statement cannot be nested.
可以采用如下的方式解决:
use demo
go
alter proc usp_c @a int
as
insert #c select @a,getdate()
alter proc usp_d
as
create table #c(id int,editdt datetime)
exec usp_c '2'
select * from #c
create table #e (id int,editdt datetime)
insert into #e exec usp_d
select * from #e
分类:
SQL Server
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· .NET 进程 stackoverflow异常后,还可以接收 TCP 连接请求吗?
· 本地部署 DeepSeek:小白也能轻松搞定!
· 基于DeepSeek R1 满血版大模型的个人知识库,回答都源自对你专属文件的深度学习。
· 在缓慢中沉淀,在挑战中重生!2024个人总结!
· 大人,时代变了! 赶快把自有业务的本地AI“模型”训练起来!
· Tinyfox 简易教程-1:Hello World!