1

我想通过链接服务器(openquery)执行以下语句:

UPDATE SAP_PLANT 
SET (OWNER, OWNER_COUNTRY) = (SELECT import.AFNAME, import.COUNTRY
                                FROM SAP_IMPORT_CUSTOMERS import, SAP_PLANT plant
                                WHERE plant.SAP_FL = import.SAP_NO
                                AND import.role ='OWNER')

我试图将其形成以下语法,但没有成功:(

update openquery(‘my_linked_server, ‘select column_1, column_2 from table_schema.table_name where pk = pk_value’)
set column_1 = ‘my_value1′, column_2 = ‘my_value2′

我希望对你来说这没问题?

4

2 回答 2

5

我猜这并不是你想要打开的查询,而是你想要执行的 SQL 语句。因此,您应该使用执行而不是 openquery。请参阅此处的示例 G:http: //msdn.microsoft.com/en-us/library/ms188332.aspx

所以你的脚本应该看起来像

execute ('your sql command here') at my_linked_server
于 2012-05-06T19:10:40.443 回答
1

您是否收到语法错误?您在 中的服务器参数update openquery缺少尾随引号。更改```my_linked_server tomy_linked_server'`。

于 2010-08-06T17:01:08.817 回答