首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用IF将table插入到临时表中。

使用IF将table插入到临时表中。
EN

Stack Overflow用户
提问于 2021-04-23 18:34:39
回答 1查看 40关注 0票数 0

我正在运行以下代码,我相信简单的代码,但是我得到了这个错误:

数据库中已经有一个名为'#tableA‘的对象

有什么办法可以克服这个问题吗?

谢谢

代码语言:javascript
运行
复制
DECLARE @dateA datetime2
SET @dateA = '2015-06-01'

IF @dateA <= '2019-01-01' 
BEGIN
    DROP TABLE IF EXISTS #tableA

    SELECT * 
    INTO #tableA 
    FROM view1 
    WHERE date = @dateA
END
ELSE
BEGIN
    DROP TABLE IF EXISTS #tableA

    SELECT * 
    INTO #tableA 
    FROM view2 
    WHERE date = @dateA
END
EN

回答 1

Stack Overflow用户

发布于 2021-04-23 19:15:56

解决方案是创建一个函数,在给定日期参数的情况下返回适当视图的表。

代码语言:javascript
运行
复制
CREATE FUNCTION [dbo].[return_view_depending_on_date](@dateChoice datetime2)

-- note: @returnTable, view1, view2, all must share identical schema/structure
RETURNS @returnTable TABLE (
    [col_one] [nvarchar](10) NULL,
    ...etc
)

AS

BEGIN

    IF @dateChoice <= '2019-01-01'
        BEGIN
            INSERT INTO @returnTable SELECT * FROM view1 WHERE date_col= @dateChoice
        END
    ELSE
        BEGIN
            INSERT INTO @returnTable SELECT * FROM view2 WHERE date_col= @dateChoice
        END

    RETURN

END
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67235249

复制
相关文章

相似问题

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