在数据块上运行 sql 查询时出现不匹配错误

Posted

技术标签:

【中文标题】在数据块上运行 sql 查询时出现不匹配错误【英文标题】:Missmatch Error when running sql query on databricks 【发布时间】:2021-07-17 15:26:45 【问题描述】:

我正在尝试在数据块上运行一个简单的 sql 查询,但出现不匹配错误。我不知道如何解决这个问题

样本数据

我的代码:

%sql
select UnitPrice, InvoiceDate
from tester2
where InvoiceDate = 2010-01-12

错误

Error in SQL statement: AnalysisException: cannot resolve '(tester2.`InvoiceDate` = ((2010 - 
1) - 12))' due to data type mismatch: differing types in '(tester2.`InvoiceDate` = ((2010 - 1) 
- 12))' (date and int).; line 3 pos 6;
'Project ['UnitPrice, 'InvoiceDate]

【问题讨论】:

将日期放在字符串引号中 @Umar.H,数据类型是日期,但会尝试并回复您 2019-19-07 将产生错误,因为它不是有效的数据类型,引擎将尝试将其读取为 int 直到它遇到连字符然后它会出错 【参考方案1】:

日期时间和日期数据类型值应该用单引号引起来:

select UnitPrice, InvoiceDate
from tester2
where InvoiceDate = '2010-01-12'

【讨论】:

以上是关于在数据块上运行 sql 查询时出现不匹配错误的主要内容,如果未能解决你的问题,请参考以下文章

使用 OleDB 列出所有存储过程和查询时出现不明确的外部连接错误

尝试子查询时出现不明确的列名错误

当我尝试对文件IO使用nextint()时出现不匹配异常错误

尝试使用多个值插入 SQL Server 时出现不正确的语法错误

(Laravel) 运行迁移时出现不正确的日期时间格式错误

运行仪器测试离子Gitlab CI时出现不兼容的AVD错误