首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Polybase无法在XLSX目标上放置WHERE条件

Polybase无法在XLSX目标上放置WHERE条件
EN

Stack Overflow用户
提问于 2020-04-16 03:00:53
回答 1查看 116关注 0票数 1

从SQL2019 polybase到.XLSX文件,我的T-SQL查询中的WHERE条件没有返回任何行

下面是我创建Polybase的代码:

代码语言:javascript
复制
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
);

下面的查询是有效的:

代码语言:javascript
复制
select * from customerData

然而,这不是:

代码语言:javascript
复制
select * from customerData where customername = 'Steve'

该查询不会返回任何行,尽管有一个名为Steve的客户。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-19 05:32:05

如果在创建外部数据源时未指定设置,则默认情况下会自动启用下推。不幸的是,这个特定的驱动程序不能在启用下推的情况下工作,因此您将通过简单的查询得到错误。关闭下推将会解决这个问题。

外部数据源定义应如下所示:

代码语言:javascript
复制
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
);
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61236568

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档