oracle 表字段 缩短,在某些特定情况下,cxu-oracle在日期字段中缩短了年份

在使用python&cx_Oracle处理日期时,我遇到了下一个问题。在

这个很好:In [29]: cursor.execute("SELECT TO_DATE('23.09.2015','DD.MM.YYYY') FROM dual")

Out[29]: >

In [30]: cursor.fetchone()

Out[30]: (datetime.datetime(2015, 9, 23, 0, 0),)

这也很好:

^{pr2}$

但是当我使用带有日期字段的oracle to_date函数时,cx}oracle将年份值减为2位数,所以我得到的不是2015,而是{}。示例如下:In [31]: cursor.execute("SELECT TO_DATE(TO_DATE('23.09.2015','DD.MM.YYYY'),'DD.MM.YYYY') FROM dual")

Out[31]: >

In [32]: cursor.fetchone()

Out[32]: (datetime.datetime(15, 9, 23, 0, 0),)

在这里:In [36]: cursor.execute("SELECT TO_DATE(sysdate,'DD.MM.YYYY') FROM dual")

Out[36]: >

In [37]: cursor.fetchone()

Out[37]: (datetime.datetime(15, 9, 23, 0, 0),)

oracle中还有一个trunc函数,可用于日期舍入,并且不会引发问题:In [39]: cursor.execute("SELECT TRUNC(sysdate) FROM dual")

Out[39]: >

In [40]: cursor.fetchone()

Out[40]: (datetime.datetime(2015, 9, 23, 0, 0),)

但是我认为我的工具可以处理用户定义的DB对象(包括视图),而不需要任何特定的限制。不幸的是,这个问题不能让我正确地处理日期,目前我找不到任何合适的解决方案。在

编辑。Rajesh的asnwer之后的工作示例:In [104]: cursor.execute("ALTER SESSION SET NLS_DATE_FORMAT='DD.MM.YYYY'")

In [105]: cursor.execute("SELECT TO_DATE(sysdate,'DD.MM.YYYY') FROM dual")

Out[105]: >

In [106]: cursor.fetchone()

Out[106]: (datetime.datetime(2015, 9, 23, 0, 0),)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值