U-SQL 查询数据源

Posted

技术标签:

【中文标题】U-SQL 查询数据源【英文标题】:U-SQL Query data source 【发布时间】:2017-03-03 13:16:58 【问题描述】:

我想向远程 Azure SQL 数据库写入查询。

我通过查询数据源 - 方法 1

关注了tutorial

我已成功运行教程中的查询:

@results1 =
  SELECT *
  FROM EXTERNAL MyAzureSQLDBDataSource EXECUTE @"SELECT @@SERVERNAME AS serverName, GETDATE() AS dayTime, DB_NAME() AS databaseName";

但是……

我想将此查询更新为以下形式:

DECLARE @queryA string = @"SELECT @@SERVERNAME AS serverName, GETDATE() AS dayTime, DB_NAME() AS databaseName";

@results2 =
  SELECT *
  FROM EXTERNAL MyAzureSQLDBDataSource EXECUTE @queryA;

我遇到了一个错误

E_CSC_USER_SYNTAXERROR:语法错误。预期之一:字符串文字

知道为什么我不能使用存储在字符串值中的查询吗?

在实际查询中,我需要根据 where 语句中的参数动态创建查询。

提前谢谢你

【问题讨论】:

【参考方案1】:

根据这篇文章https://msdn.microsoft.com/en-us/library/azure/mt621291.aspx,您只能提供文字,而不是变量:

执行 csharp_string_literal

字符串文字包含一个查询 远程数据源支持的语言的表达式。例如。, 如果数据源是 Azure SQL 数据库,则查询字符串 应该是 T-SQL。

【讨论】:

为什么不能使用文字的串联?例如@results1 = SELECT * FROM EXTERNAL MyAzureSQLDBDataSource EXECUTE @"SELECT @@SERVERNAME AS serverName, GETDATE() AS dayTime, " + @"DB_NAME() AS databaseName";

以上是关于U-SQL 查询数据源的主要内容,如果未能解决你的问题,请参考以下文章

U-SQL 从模式中获取文件路径

以编程方式提交带有代码隐藏的 U-SQL 作业

如何使用U-SQL修改文本文件

SQL左反半连接等效查询

查询数据

mysql如何批量查询大量数据