如何在SQL Server 2008中使用表别名编写UPDATE SQL? [英] How to write UPDATE SQL with Table alias in SQL Server 2008?
本文介绍了如何在SQL Server 2008中使用表别名编写UPDATE SQL?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个非常基本的 UPDATE SQL
-
UPDATE HOLD_TABLE Q SET Q.TITLE = 'TEST' WHERE Q.ID = 101;
此查询在 Oracle
, Derby
, MySQL
-但它在SQL Server 2008中失败
,并出现以下错误:
This query runs fine in Oracle
, Derby
, MySQL
- but it fails in SQL server 2008
with following error:
消息102,级别15,状态1,行1'Q'附近的语法不正确。
"Msg 102, Level 15, State 1, Line 1 Incorrect syntax near 'Q'."
如果我从SQL中删除所有出现的别名 Q,则它起作用。
If I remove all occurrences of the alias, "Q" from SQL then it works.
我需要使用别名。
推荐答案
在SQL Server的更新语句中使用别名的语法如下:
The syntax for using an alias in an update statement on SQL Server is as follows:
UPDATE Q
SET Q.TITLE = 'TEST'
FROM HOLD_TABLE Q
WHERE Q.ID = 101;
不过在这里别名不是必需的。
The alias should not be necessary here though.
这篇关于如何在SQL Server 2008中使用表别名编写UPDATE SQL?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文