首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么这个SQL语法会引发错误?

为什么这个SQL语法会引发错误?
EN

Stack Overflow用户
提问于 2018-08-02 19:09:28
回答 1查看 62关注 0票数 1

在较长的脚本中执行此语句时,我一直会收到一个错误:

代码语言:javascript
复制
IF EXISTS (SELECT 1 FROM sys.columns
           WHERE name = N'uncertainty_requested' 
             AND object_id = object_id(N'workorder'))
BEGIN
    PRINT 'workorder.uncertainty_requested exists';
END
ELSE
BEGIN
    ALTER TABLE workorder
        ADD uncertainty_requested CHAR(1);

    UPDATE workorder
    SET uncertainty_requested = 'F';

    PRINT 'workorder.uncertainty_requested added.'
END 
GO

错误信息是:

Msg 207,第16级,状态1,第10行 无效的列名‘不确定性_请求’。

使用Server 2012。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-02 19:11:33

代码在执行之前被编译,缺少的列是编译时错误。您可以使用动态SQL处理此问题:

代码语言:javascript
复制
ALTER TABLE workorder
    ADD uncertainty_requested CHAR(1);
exec sp_executesql N'UPDATE workorder SET uncertainty_requested = ''F''';
PRINT 'workorder.uncertainty_requested added.'
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51660623

复制
相关文章

相似问题

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