使用Python的Win32 ODBC模块检索Oracle时间戳

给定使用以下命令创建的Oracle表:


CREATE TABLE Log(WhenAdded TIMESTAMP(6) WITH TIME ZONE);

使用来自Win32扩展(来自win32all软件包)的Python ODBC模块,我尝试了以下方法:


import dbi, odbc


connection = 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)不会导致此问题。有没有一种获取时间戳的方法?


慕后森
浏览 263回答 2
2回答

森林海

我相信这是Oracle ODBC驱动程序中的错误。基本上,Oracle ODBC驱动程序不支持TIMESTAMP WITH (LOCAL) TIME ZONE数据类型,仅支持TIMESTAMP数据类型。正如您所发现的,实际上一种解决方法是使用该TO_CHAR方法。在您的示例中,您实际上并没有在阅读时区信息。如果您可以控制表格,则可以将其转换为直列TIMESTAMP。如果你没有在桌子上的控制,另一种解决方案可能是创建一种观点认为,从转换TIMESTAMP WITH TIME ZONE到TIMESTAMP通过串-对不起,我不知道是否有直接从转换的方式TIMESTAMP WITH TIME ZONE来TIMESTAMP。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python