我正在使用 Access 数据库和 vb6。我的表有一个名为“InvoiceDate”的字段,它是一个文本字段。我无权修改数据库。所以我想我唯一的选择是将查询中的文本字段更改为日期/时间字段。我找到了几种方法来做到这一点。它们如下。
但这4种方法都不起作用。我无法弄清楚这一点。
我使用的查询如下
SELECT Invoice.InvoiceDate, InvoicedProduct.InvoiceType, Invoice.InvoiceStatus,
Invoice.RetailerID, Invoice.DailySalesID, Invoice.RepID,
InvoicedProduct.Quantity, InvoicedProduct.UnitRate,
InvoicedProduct.TotalItemValue
FROM Invoice
INNER JOIN InvoicedProduct
ON (Invoice.DailySalesID = InvoicedProduct.DailySalesID)
AND (Invoice.RepID = InvoicedProduct.RepID)
AND (Invoice.InvoiceID = InvoicedProduct.InvoiceID)
WHERE (((InvoicedProduct.ProductID)='9010001174130.4')
AND (DateValue(Invoice.InvoiceDate) Between #2015/01/01# And #2016/01/01#))
GROUP BY Invoice.InvoiceDate, InvoicedProduct.InvoiceType, Invoice.InvoiceStatus,
Invoice.RetailerID, Invoice.DailySalesID, Invoice.RepID,
InvoicedProduct.Quantity, InvoicedProduct.UnitRate,
InvoicedProduct.TotalItemValue
HAVING (((InvoicedProduct.InvoiceType)='Invoice' OR (InvoicedProduct.InvoiceType)='Sound')
AND ((Invoice.InvoiceStatus)='VALID'))
ORDER BY Invoice.InvoiceDate;
Run Code Online (Sandbox Code Playgroud)
这给了我错误“条件表达式中的数据类型不匹配”
我的 InvoiceDate 字段中包含以下两种类型
2016/01/04 10:00: 上午和 2016/01/20 08:25 下午
唯一的区别是时间后面的冒号
请帮忙。谢谢。
您的标准:
DateValue(Invoice.InvoiceDate) Between #2015/01/01# And #2016/01/01#
Run Code Online (Sandbox Code Playgroud)
是正确的,因此错误消息表明InvoiceDate中的一个或多个文本日期不代表有效日期,例如 2015-06-31 或 Null。
运行查询来检查这一点:
Select *, IsDate(InvoiceDate) As ValidDate From Invoice
Run Code Online (Sandbox Code Playgroud)
并查看ValidDate的值是否有 False。
要忽略额外的冒号:
DateValue(Replace(Invoice.InvoiceDate, ": ", " ")) Between #2015/01/01# And #2016/01/01#
Run Code Online (Sandbox Code Playgroud)