在访问查询中将文本字段转换为日期/时间字段不起作用

Kel*_*mal 2 sql vb6 ms-access

我正在使用 Access 数据库和 vb6。我的表有一个名为“InvoiceDate”的字段,它是一个文本字段。我无权修改数据库。所以我想我唯一的选择是将查询中的文本字段更改为日期/时间字段。我找到了几种方法来做到这一点。它们如下。

  • 格式(发票日期,“年/月/日”)
  • (日期序列(左(发票日期,4),中(发票日期,5,2),右(发票日期,2))在#2015/01/01#和#2016/01/01#之间))
  • DateValue(发票日期, "年/月/日")
  • CDate(发票日期, "年/月/日")

但这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 下午

唯一的区别是时间后面的冒号

我的 InvoiceDate 字段中包含以下两种类型

请帮忙。谢谢。

Gus*_*tav 5

您的标准:

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)