从SQL2019 polybase到.XLSX文件,我的T-SQL查询中的WHERE条件没有返回任何行
下面是我创建Polybase的代码:
create master key encryption by password = 'Polybase2CSV';
create external data source myODBCxlsx with
(
LOCATION = 'odbc://localhost',
CONNECTION_OPTIONS = 'Driver={Microsoft Excel Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)}; DBQ=F:\PolybaseSourceData\CustomerData.xlsx'
);
create external table CustomerData(
CUSTOMERID FLOAT(53),
CUSTOMERNAME Nvarchar(255),
DEPARTMENT Nvarchar(255)
) with (
LOCATION='[sheet1$]',
DATA_SOURCE=myODBCxlsx
);下面的查询是有效的:
select * from customerData然而,这不是:
select * from customerData where customername = 'Steve'该查询不会返回任何行,尽管有一个名为Steve的客户。
发布于 2020-04-19 05:32:05
如果在创建外部数据源时未指定设置,则默认情况下会自动启用下推。不幸的是,这个特定的驱动程序不能在启用下推的情况下工作,因此您将通过简单的查询得到错误。关闭下推将会解决这个问题。
外部数据源定义应如下所示:
create external data source myODBCxlsx with
(
LOCATION = 'odbc://localhost',
CONNECTION_OPTIONS = 'Driver={Microsoft Excel Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)}; DBQ=F:\Files\CustomerData.xlsx',
PUSHDOWN=OFF
);https://stackoverflow.com/questions/61236568
复制相似问题