作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 JOOQ 3.4.1 作为中间件与 Oracle 数据库通信,但是当我在代码中编写以下查询时,我得到了 SqlDataException: AM/A.M.或下午/下午必填。
select 0 prodid, cast(((cast('31-DEC-' as varchar2(4000)) || cast(YearForBilling as varchar2(4000))) || ' 12.59.00.000000000 PM ') as timestamp) theDate 0 Balance from ProductDetails where productRSN = 71
group by YearForBilling
有人可以帮我解决这个问题吗?
最佳答案
我永远不会依赖与区域设置相关的格式化日期和时间戳字符串。 从不。您永远不知道这些设置是否会在某个时间点发生变化,例如作为系统默认值,或作为 session 设置等。不要依赖它。 不要。
如果可以,请使用完全不依赖于 NLS
设置 ( I've blogged about this here ) 的 SQL 标准时间戳文字。例如:
TIMESTAMP '2016-12-31 23:59:00.0'
在您的情况下,您正在动态创建日期,因此时间戳文字将不起作用。但仍然请使用 ISO 8601 date formatting, as such
TO_TIMESTAMP(YearForBilling || '-12-31 23:59:00', 'YYYY-MM-DD HH24:MI:SS')
关于java - JOOQ 问题 : AM/A. M. 或 PM/P.M.必需的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39224782/
我是一名优秀的程序员,十分优秀!