如何在 SQL Server 2008 中使用表别名编写 UPDATE SQL?

2023-06-25数据库问题
0

本文介绍了如何在 SQL Server 2008 中使用表别名编写 UPDATE SQL?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有一个非常基本的UPDATE SQL -

I have a very basic UPDATE SQL -

UPDATE HOLD_TABLE Q SET Q.TITLE = "TEST" WHERE Q.ID = 101;

此查询在 OracleDerbyMySQL 中运行良好 - 但它在 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;

不过这里不需要别名.

这篇关于如何在 SQL Server 2008 中使用表别名编写 UPDATE SQL?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

Mysql目录里的ibtmp1文件过大造成磁盘占满的解决办法
ibtmp1是非压缩的innodb临时表的独立表空间,通过innodb_temp_data_file_path参数指定文件的路径,文件名和大小,默认配置为ibtmp1:12M:autoextend,也就是说在文件系统磁盘足够的情况下,这个文件大小是可以无限增长的。 为了避免ibtmp1文件无止境的暴涨导致...
2025-01-02 数据库问题
151

按天分组的 SQL 查询
SQL query to group by day(按天分组的 SQL 查询)...
2024-04-16 数据库问题
77

SQL 子句“GROUP BY 1"是什么意思?意思是?
What does SQL clause quot;GROUP BY 1quot; mean?(SQL 子句“GROUP BY 1是什么意思?意思是?)...
2024-04-16 数据库问题
62

MySQL groupwise MAX() 返回意外结果
MySQL groupwise MAX() returns unexpected results(MySQL groupwise MAX() 返回意外结果)...
2024-04-16 数据库问题
13

MySQL SELECT 按组最频繁
MySQL SELECT most frequent by group(MySQL SELECT 按组最频繁)...
2024-04-16 数据库问题
16

在 Group By 查询中包含缺失的月份
Include missing months in Group By query(在 Group By 查询中包含缺失的月份)...
2024-04-16 数据库问题
12