我环顾四周,但找不到此 SQL 语句的问题:
strSQL = "SELECT Directory.DisplayName, Department.DisplayName, Call.CallDate, Call.Extension, Call.Duration, Call.CallType, Call.SubType FROM (((Department INNER JOIN Directory ON Department.DepartmentID = Directory.DepartmentID) INNER JOIN Extension ON (Department.DepartmentID = Extension.DepartmentID) AND (Directory.ExtensionID = Extension.ExtensionID)) INNER JOIN Site ON Extension.SiteCode = Site.SiteCode) INNER JOIN Call ON Directory.DirectoryID = Call.DirectoryID WHERE (Call.CallDate)>=27/11/2012"
无论我更改 WHERE 什么,它总是返回数据库中的每一个值(至少我假设它确实如此,因为当我尝试这样做时,excel 完全挂起)这个 SQL 语句在 Access 中工作得非常好(如果日期周围有 ##)。知道如何解决这个问题,目前正在尝试创建一个允许用户在不同日期输入的 SQL 语句,但必须首先克服这个随机障碍。
编辑:SQL 数据库中的日期字段是 DD/MM/YY HH:MM:SS 格式,并且此查询是在 VBA - EXCEL 2010 中完成的。
另外,为了避免混淆,已从语句中删除了 TOP 10,即停止excel 检索数据库中的每一行。
我激活的当前参考是:MicrosoftX Data Objects 2.8 Library
Database 是一个 MSSQL,使用连接字符串:
Provider=SQLOLEDB;Server=#######;Database=#######;User ID=# #######;密码=########;