小编典典

在JDBC规范不问候时区定义的任何细节。尽管如此,我们大多数人都知道必须处理JDBC时区差异的痛苦。

最终,日期/时间数据库类型的时区处理归结为数据库服务器,JDBC驱动程序以及两者之间的所有内容。您甚至受JDBC驱动程序错误的支配。PostgreSQL修复了版本8.3中的错误,其中

传递给Calendar对象的Statement.getTime,.getDate和.getTimestamp方法使时区朝错误的方向旋转。

当您使用创建新日期时new Date(0)(假设您正在使用Oracle JavaSE

java.sql.Date,则会创建您的日期

使用给定的毫秒时间值。如果给定的毫秒值包含时间信息,则驱动程序会将时间分量设置为默认时区(运行应用程序的Java虚拟机的时区)中与GMT零相对应的时间。

因此,new Date(0)应使用GMT。

调用时ResultSet.getDate(int),您正在执行JDBC实现。JDBC规范没有规定JDBC实现应如何处理时区细节。因此,您无法实现。从Oracle

11g

oracle.sql.DATEJavaDoc看,Oracle

DB似乎没有存储时区信息,因此它执行自己的转换以将日期转换为java.sql.Date。我没有使用Oracle

DB的经验,但是我想JDBC的实现是使用服务器的本地JVM的时区设置来进行从oracle.sql.DATE到的转换java.sql.Date。

您提到了多个RDBMS实现可以正确处理时区,但SQLite除外。让我们看一下将日期值发送到JDBC驱动程序以及从JDBC驱动程序获取日期值时H2和SQLite的工作方式。

使用此SQLite JDBC驱动程序,RS.getDate(int)代码要简单得多。它只是java.sql.Date使用long存储在数据库中的日期值返回a

因此,我们看到H2 JDBC驱动程序在处理带日期的时区转换方面很聪明,而SQLite

JDBC驱动程序则不明智(并不是说这个决定不明智,它可能很适合SQLite设计决定)。如果您追查提到的其他RDBMS

JDBC驱动程序的源代码,则可能会发现大多数驱动程序都以与H2相似的方式接近日期和时区。

尽管JDBC规范没有详细说明时区处理,但是RDBMS和JDBC实现设计人员考虑时区并会正确处理时区是很有意义的。特别是如果他们希望自己的产品在全球舞台上可销售。这些设计师非常聪明,即使没有具体规范,大多数人也都能做到这一点,我对此并不感到惊讶。

我在Microsoft SQL Server博客中找到了使用SQL Server

2008中的时区数据,它说明了时区如何使事情变得复杂:

时区是一个复杂的区域,每个应用程序都需要解决如何处理时区数据的问题,以使程序更加用户友好。

不幸的是,当前没有时区名称和值的国际标准权威。每个系统都需要使用自己选择的系统,并且直到有国际标准之前,尝试让SQL

Server提供一个系统都是不可行的,最终将导致比解决的问题更多的问题。

2020-09-11

java 中的sql.date_SQL DATE中的时区vs java.sql.Date相关推荐

  1. SQL语句oracle中如何插入Date类型的数据

    在开发的时候,经常要写条SQL语句将信息插入表中,插入的数据如果字段是date类型,就必须将date类型转换成字符串String类型在通过sql语句插入数据库.这是我字段唯一的方法,如果有高人请另赐教 ...

  2. java中date如何获取月份_Java:从Date获取月份整数

    如何从Date对象(java.util.Date)获取整数作为整数? 实际上,Date上的getMonth()因为永远而被弃用;) @slhck:已弃用. 从JDK 1.1版开始,由Calendar. ...

  3. java得到sql语句表名_使用fdb-sql-parser替换SQL语句中的表名

    导语 因为项目中要做跨数据源的数据分析功能,所以使用Presto这个开源框架.但是使用Presto的时候需要指定当前表所在的数据库类型和数据库名,所以需要对SQL语句中的表名进行捕获和替换. 一.探索 ...

  4. java索引丢失怎么解决_java.sql.SQLException: 索引中丢失 IN 或 OUT 参数:: 1解决办法...

    java.sql.SQLException: 索引中丢失  IN 或 OUT 参数:: 1 at oracle.jdbc.driver.DatabaseError.throwSqlException( ...

  5. java定时执行sql语句_spring中使用quartz动态添加定时任务执行sql

    系统用来每天插入视图数据... 一.数据库表设计 1.接口配置表(t_m_db_interface_config) 2.接口日志表(t_m_db_interface_log) 3.前端配置页面 查询页 ...

  6. java 防止sql注入_Java中SQL注入以及如何轻松防止它

    java 防止sql注入 什么是SQL注入? (What is SQL Injection?) SQL Injection is one of the top 10 web application v ...

  7. date在java中是什么类型_java中date 是什么类型

    满意答案 1engwen 2016.08.20 采纳率:41%    等级:8 已帮助:1115人 java语言中的date类介绍及使用 在JDK1.0中,Date类是唯一的一个代表时间的类,但是由于 ...

  8. java date加月_关于java:在日期中添加月份

    我想根据用户选择的持续时间添加月数. 我已经编写了以下代码,它采用当前日期并根据用户选择的持续时间添加月份,但我希望它采用从前端传递的开始日期并根据持续时间添加月份. String le=ra.get ...

  9. java将date类型转成yyyymmdd_Java中Date转换大全,返回yyyy-MM-dd的Date类型

    import java.text.*; import java.util.Calendar;public classVeDate {/** * 获取现在时间 * * @return 返回时间类型 yy ...

最新文章

  1. 逻辑模型三要素-完整性约束
  2. BZOJ5323 洛谷4562:[JXOI2018]游戏——题解
  3. 面试问烂的 MySQL 四种隔离级别,看完吊打面试官!
  4. blockhouses
  5. 关于jupyter几个不得不知道的tips
  6. linux socket API / socket
  7. Java实现心跳机制
  8. 探讨.NET Core的未来
  9. C++——《算法分析》实验叁——贪心算法与回溯法
  10. java md5加密解密_java MD5加密解密 | 学步园
  11. 开源正在蚕食 500 亿美元的数据库行业!
  12. 申请CSDN博客专家的成功历程
  13. jdk命令行工具:jstat与jmap
  14. MagicDraw建模显示中文问题
  15. 曲线运动与万有引力公式_高一物理曲线运动万有引力试题
  16. python程序写诗_python:为你写诗
  17. CMMB手机电视自毁长城?
  18. python表格绘制斜线表头_Excel表格绘制斜线表头的三种方法,懂得这些技巧就够了...
  19. CDOJ 796 DAGE(Big Brother)
  20. 表达式计算器-iExpr

热门文章

  1. 交换机用python定时备份
  2. Confluence 6 配置系统属性
  3. python对文件夹内文件去重
  4. getOutputStream() has already been called for this response异常的原因和解决方法
  5. Atitit.5gl 第五代语言编程语言 PROLOG教程  人工智能语言的标准 与实现
  6. hdu-3790最短路径问题
  7. 【整理】各种语言的API文档
  8. c#的Marshal
  9. C++中#ifndef/#define/#endif使用详解
  10. codeforces 483B Friends and Presents