1、如何将java.util.Date转化为java.sql.Date?

转化:

java.sql.Date sd;

java.util.Date ud;

//initialize the ud such as ud = new java.util.Date();

sd = new java.sql.Date(ud.getTime());

2、如果要插入到数据库并且相应的字段为Date类型

那么可以用PreparedStatement.setDate(int ,java.sql.Date)方法

其中的java.sql.Date可以用上面的方法得到

也可以用数据库提供TO_DATE函数

比如 现有 ud

TO_DATE(new SimpleDateFormat().format(ud,"yyyy-MM-dd HH:mm:ss"),

"YYYY-MM-DD HH24:MI:SS")

注意java中表示格式和数据库提供的格式的不同

一个实际的例子

sql="update tablename set timer=to_date('"+t+"','yyyymmddhh24miss') where ....."

这里的t为变量为类似:20051211131223

3、如何将"yyyy-mm-dd"格式的字符串转换为java.sql.Date

方法1

SimpleDateFormat bartDateFormat =

new SimpleDateFormat("yyyy-MM-dd");

String dateStringToParse = "2007-7-12";

try {

java.util.Date date = bartDateFormat.parse(dateStringToParse);

java.sql.Date sqlDate = new java.sql.Date(date.getTime());

System.out.println(sqlDate.getTime());

}

catch (Exception ex) {

System.out.println(ex.getMessage());

}

------------------------------------------------------------

方法2

String     strDate     =     "2002-08-09";

StringTokenizer     st     =     new     StringTokenizer(strDate,     "-");

java.sql.Date     date     =     new     java.sql.Date(Integer.parseInt(st.nextToken()),

Integer.parseInt(st.nextToken()),

Integer.parseInt(st.nextToken()));

java.util.Date和java.sql.Date的异同

java.sql.Date,java.sql.Time和java.sql.Timestamp三个都是java.util.Date的子类(包装类)。

但是为什么java.sql.Date类型的值插入到数据库中Date字段中会发生数据截取呢?

java.sql.Date是为了配合SQL DATE而设置的数据类型。“规范化”的java.sql.Date只包含年月日信息,时分秒毫秒都会清零。格式类似:YYYY-MM-DD。当我们调用ResultSet的getDate()方法来获得返回值时,java程序会参照"规范"的java.sql.Date来格式化数据库中的数值。因此,如果数据库中存在的非规范化部分的信息将会被劫取。

在sun提供的ResultSet.java中这样对getDate进行注释的:

Retrieves the of the designated column in the current row of this ResultSet object as a “java.sql.Date” object in the Java programming language.

同理。如果我们把一个java.sql.Date值通过PrepareStatement的setDate方法存入数据库时,java程序会对传入的java.sql.Date规范化,非规范化的部分将会被劫取。然而,我们java.sql.Date一般由java.util.Date转换过来,如:java.sql.Date sqlDate=new java.sql.Date(new java.util.Date().getTime()).

显然,这样转换过来的java.sql.Date往往不是一个规范的java.sql.Date.要保存java.util.Date的精确值,

我们需要利用java.sql.Timestamp.

Calendar

Calendar   calendar=Calendar.getInstance();

//获得当前时间,声明时间变量

int   year=calendar.get(Calendar.YEAR);

//得到年

int   month=calendar.get(Calendar.MONTH);

//得到月,但是,月份要加上1

month=month+1;

int   date=calendar.get(Calendar.DATE);

//获得日期

String   today=""+year+"-"+month+"-"+date+"";

java中将date插入mysql中date_JAVA 处理时间 - java.sql.Date、java.util.Date与数据库中的Date字段的转换方法[转]...相关推荐

  1. java 日期类Date插入mysql数据库时间总是比参数时间少一天

    问题发生: 插入日期比预想的少了一天,查看java 中执行的sql INSERT INTO t3b_msg (send_dt) values(str_to_date('2019 - 10 - 18', ...

  2. c#中将集合写入文本_在C#中将记录插入MySQL数据库

    c#中将集合写入文本 In the last tutorial (how to connect with MySQL database in C#?), we learned about making ...

  3. java操作mysql导表_Java实现批量导入excel表格数据到数据库中的方法

    本文实例讲述了Java实现批量导入excel表格数据到数据库中的方法.分享给大家供大家参考,具体如下: 1.创建导入抽象类 package com.gcloud.common.excel; impor ...

  4. jdbc mysql api_JDBC---一种用于执行SQL的Java API

    JDBC是一种用于执行SQL的Java API,它本身是个商标名,但很多人把它认为是Java Database Connectivity(Java 数据库连接)的缩写. JDBC是一组访问数据库的AP ...

  5. C++ 开发中如何利用sql语句(insert语句)向数据库中插入变量

    **问题描述:**在C/S开发过程中,当客户端向服务端发送接口(结构体)信息时,服务端需要将接收到的信息存入数据库,但是,常规insert语句只能存确定的值到数据,当客户端传入的值不确定,且为了保证代 ...

  6. mysql根据id删除数据sql语句_删除数据sql-sql数据库删除数据-sql中实现数据删除的语句是...

    怎样用sql语言删除一行数据 在SQL数据库中删除记录一般使用Delete语句,下面就将为您介绍SQL中用于删除记录的DELETE语句的语法 DELETE FROM 表名称 WHERE 列名称 = 值 ...

  7. JAVA中string.replace()和string.replaceAll()的区别及用法 数据库中[]转义

    JAVA中string.replace()和string.replaceAll()的区别及用法 乍一看,字面上理解好像replace只替换第一个出现的字符(受javascript的影响),replac ...

  8. mysql怎么把文字图片保存在一起_如何在数据库中同时保存文本和图片

    展开全部 向数据库中保存不同类型的文件,和在数据库中保存图e69da5e887aa3231313335323631343130323136353331333337613164片是一样的.就是向数据库以 ...

  9. android 对象数据库中,解析嵌套的JSON对象,并存储在数据库中的Android

    我只是试图让存储在我的JSON文件中的值,并将其保存到SQLite数据库:解析嵌套的JSON对象,并存储在数据库中的Android 这是我的JSON文件: { "list": { ...

最新文章

  1. 如何使用Azure API管理服务?
  2. 使用elasticsearch遇到的一些问题以及解决方法(不断更新)
  3. Linux之ping命令使用详解—网络故障定位(六)
  4. 【嵌入式开发】ARM 代码搬移 ( ARM 启动流程 | 代码搬移 起点 终点 | 链接地址 | 汇编代码 )
  5. Nginx源码研究之nginx限流模块详解
  6. 神经网络输出数量对迭代次数的影响
  7. Gitlab 10.1.4 (汉化版) for CentOS 7.4安装
  8. docker network基础
  9. 疯狂游戏型计算机配置清单,电脑配置清单
  10. golang 标准库间依赖的可视化展示
  11. Java ASM与Javassit
  12. docker构建oracle集群,docker 构建 oracle数据库 镜像-Go语言中文社区
  13. 互联网晚报 | 1月16日 星期日 | 微信新增语音播放暂停功能;小米MIUI“纯净模式”上线;全国首例“刷单案”宣判...
  14. 【英语学习】【Daily English】U14 Transportation L02 I'm afraid that you're going in the wrong direction.
  15. 计算机组成的ir是指,2002.10计算机组成原理§1控制器的基本概念⑵指令寄存器IR指令.ppt...
  16. linux 网络监控 邮件,一种基于Linux的邮件监控方法与流程
  17. 渐进式加载 - 基础讲解
  18. photoshop柔光模式原理和案例教程
  19. 破解物联网落地困境-阿里云硬件接入最佳实践
  20. 软件质量有什么特性?

热门文章

  1. boost::sort模块实现spreadsort 双排序示例
  2. boost::mpl模块实现copy相关的测试程序
  3. boost::hana::back用法的测试程序
  4. boost::log::attribute_value用法的测试程序
  5. boost::fusion::erase用法的测试程序
  6. GDCM:将gz文件转dcm文件测试程序
  7. ITK:应用Cos图像滤镜
  8. VTK:PolyData之ShrinkPolyData
  9. VTK:PolyData之ThinPlateSplineTransform
  10. VTK:绘图之ChartsOn3DScene