我正在调试 ODBC 驱动程序,并在 ODBC 日志中遇到了以下条目
crw32 7e0-235c ENTER SQLGetInfoW
HDBC 0x03816BE0
UWORD 6 <SQL_DRIVER_NAME>
PTR 0x0180EB18
SWORD 256
SWORD * 0x0180E6EC
crw32 7e0-235c EXIT SQLGetInfoW with return code -1 (SQL_ERROR)
HDBC 0x03816BE0
UWORD 6 <SQL_DRIVER_NAME>
PTR 0x0180EB18
SWORD 256
SWORD * 0x0180E6EC
DIAG [IM001] [Microsoft][ODBC Driver Manager] Driver does not support this function (0)
ODBC 如何确定驱动程序是否支持给定函数?
有一个名为 SQLGetFunctions 的 ODBC API(参见 http://msdn.microsoft.com/en-us/library/windows/desktop/ms709291%28v=vs.85%29.aspx)。它通常在 ODBC 驱动程序管理器中处理,但 ODBC 驱动程序可以提供自己的驱动程序。如果驱动程序管理器正在处理它,那么它可能只是查看驱动程序代码导出了哪些函数。
顺便说一句,一个真正不支持SQLGetInfo的驱动程序严重损坏。