给定使用以下命令创建的Oracle表:CREATE TABLE Log(WhenAdded TIMESTAMP(6) WITH TIME ZONE);使用来自Win32扩展(来自win32all软件包)的Python ODBC模块,我尝试了以下方法:import dbi, odbcconnection = odbc.odbc("Driver=Oracle in OraHome92;Dbq=SERVER;Uid=USER;Pwd=PASSWD")cursor = connection.cursor()cursor.execute("SELECT WhenAdded FROM Log")results = cursor.fetchall()运行此命令时,将得到以下信息:Traceback (most recent call last):... results = cursor.fetchall()dbi.operation-error: [Oracle][ODBC][Ora]ORA-00932: inconsistent datatypes: expected %s got %s in FETCH我尝试过的其他数据类型(VARCHAR2,BLOB)不会导致此问题。有没有一种获取时间戳的方法?
2 回答

森林海
TA贡献2011条经验 获得超2个赞
我相信这是Oracle ODBC驱动程序中的错误。基本上,Oracle ODBC驱动程序不支持TIMESTAMP WITH (LOCAL) TIME ZONE
数据类型,仅支持TIMESTAMP
数据类型。正如您所发现的,实际上一种解决方法是使用该TO_CHAR
方法。
在您的示例中,您实际上并没有在阅读时区信息。如果您可以控制表格,则可以将其转换为直列TIMESTAMP
。如果你没有在桌子上的控制,另一种解决方案可能是创建一种观点认为,从转换TIMESTAMP WITH TIME ZONE
到TIMESTAMP
通过串-对不起,我不知道是否有直接从转换的方式TIMESTAMP WITH TIME ZONE
来TIMESTAMP
。
添加回答
举报
0/150
提交
取消