zoukankan      html  css  js  c++  java
  • 错误的SQL脚本,错误消息 4104

    今天要做个报表,其中用到了UPDATE 的多表更新,通常这种更新的语法我是很熟练的,但今天写好后查询分析器检查时总是提示错误:

    消息 4104,级别 16,状态 1,第 1 行
    The multi-part identifier "S.RetailQty" could not be bound.

    我的脚本如下:

    update #StorageDetail set S.RetailQty = R.Qty, S.Amount = R.Amount
      
    from #StorageDetail S inner join #RetailBill R 
      
    on (S.ShopId = R.ShopId) 
      
    and S.prodid = R.prodid 
      
    and S.color = R.color 
      
    and S.Size = R.Size 


    经多方查询无果后,我只有自己用一个最简单的DEMO来测试我得这个更新语法结果发现了问题。

    我的DEMO的代码如下:

    create table #A (a char(10), b char(10),qty int)
    insert into #A(a,b,qty) values('A01','0',10)
    insert into #A(a,b,qty) values('A02','0',9)
    insert into #A(a,b,qty) values('A02','0',9)
    insert into #A(a,b,qty) values('A03','0',8)
    insert into #A(a,b,qty) values('A04','0',7)
    create table #B (a char(10), b char(10),qty int)
    insert into #B(a,b,qty) values('A01','0',1)
    insert into #B(a,b,qty) values('A02','0',2)
    insert into #B(a,b,qty) values('A03','0',3)
    insert into #B(a,b,qty) values('A03','0',8)
    insert into #B(a,b,qty) values('A04','0',4)


    alter table #a add qty2 int

    update a set a.qty2 = b.qty from #a a inner join #b b
     
    on a.a = b.a and a.b = b.b

    select * from #a
    select * from #b

    drop table #a
    drop table #b

    结果这个DEMO执行正常,在仔细比较两个更新语句发现问题处在对表使用别名上。在DEMO中我Update 后跟的表名是#a 的别名a,而我正式脚本中的Update后跟的是表名,而不是别名。后来又把这个临时表改为正式表,也是这样。这说明在一个SQL语句中如果定义了表的别名就必须使用别名,而不能再继续使用表名。否则就会出错。


    洪虎

    2006-10-19
  • 相关阅读:
    KNN 与 K
    k 近邻算法(k-Nearest Neighbor,简称kNN)
    ANN神经网络——Sigmoid 激活函数编程练习 (Python实现)
    ANN神经网络——实现异或XOR (Python实现)
    Logistic Regression 之错误翻译
    浅谈回归(二)——Regression 之历史错误翻译
    浅谈回归Regression(一)
    交叉验证 Cross validation
    Git学习-Git时光机之版本回退(二)
    ubuntu16.04安装网易云音乐
  • 原文地址:https://www.cnblogs.com/eric1394/p/533886.html
Copyright © 2011-2022 走看看