Skip to content

Instantly share code, notes, and snippets.

@kiyokura
Last active August 29, 2015 14:23
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save kiyokura/d76c52e0ad27b409b01c to your computer and use it in GitHub Desktop.
Save kiyokura/d76c52e0ad27b409b01c to your computer and use it in GitHub Desktop.
-- 誰かが作ったProcA
CREATE PROCEDURE usp_ProcA
@param int
AS
BEGIN
SET NOCOUNT ON
-- 実際はどっかのテーブルからデータ持ってくる
SELECT 1 AS hoge UNION SELECT 2 AS hoge
END
Go
-- 誰かが作ったProcB
CREATE PROCEDURE usp_ProcB
@param int
AS
BEGIN
CREATE TABLE #tmp(
hoge int
)
-- 実際はなんかいろいろ処理してる
INSERT INTO #tmp EXEC usp_ProcA 1
SELECT * FROM #tmp
DROP TABLE #tmp
END
Go
-- これを作ってる
CREATE PROCEDURE usp_ProcC
@param int
AS
BEGIN
SET NOCOUNT ON
-- ここでProcBを実行してレコードとってきて、ProcCの中で使いたい
-- (ProcAとProcBのインタフェースは原則触れない…)
-- が、
CREATE TABLE #tmp2(
hoge int
);
INSERT INTO #tmp2 EXEC usp_ProcB 1
-- と書くと「An INSERT EXEC statement cannot be nested.」になる
END
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment