博客
关于我
API--02--Java.util.date与java.sql.date
阅读量:282 次
发布时间:2019-03-01

本文共 3321 字,大约阅读时间需要 11 分钟。

JDK8 之前日期时间 API

在这里插入图片描述

System类 currentTimeMillis();

在这里插入图片描述

时间戳

  1. 返回当前时间与1970年1月1日0时0分0秒之间以毫秒为单位的时间差
  2. 称为时间戳
    在这里插入图片描述

java.util.Date类

在这里插入图片描述

两个构造器的使用

  • 构造器一:Date():创建一个对应当前时间的Date对象
  • 构造器二:创建指定毫秒数的Date对象

两个方法的使用

  • toString():显示当前的年、月、日、时、分、秒
  • getTime():获取当前Date对象对应的毫秒数。(时间戳

案例:

@Test    public void test2(){           //构造器一:Date():创建一个对应当前时间的Date对象        Date date1 = new Date();        System.out.println(date1.toString());//Sat Feb 16 16:35:31 GMT+08:00 2019        System.out.println(date1.getTime());//1550306204104        //构造器二:创建指定毫秒数的Date对象        Date date2 = new Date(155030620410L);        System.out.println(date2.toString());    }

在这里插入图片描述

默认格式:

  • date1.toString() 月日 时分秒 时区 年

Sat Feb 16 16:35:31 GMT+08:00 2019

Java.sql.Date类

一. java.sql.Date是java.util.Date的==子类

在这里插入图片描述

可见这三个类都是java.utl.Date的子类

而这三个类都是对应与jdbc处理日期格式的类,有着 不同的日期精度和格式

二. java.sql.Date对应着数据库中的日期类型的变量

  1. java中有两个Date类,一个是java.util.Date通常情况下用它获取当前时间构造时间
  2. java.sql.Date是针对SQL语句使用的.

在这里插入图片描述

三. java.sql.Date时间格式

在这里插入图片描述

  • java.sql.Date也是一个时间戳
  • 但它把当前的时间剪掉了,保证它一定是那个日期的0点0分0秒的时间戳
  • java.sql.Date.tostring的时候 格式 是 年 月 日

java.sql包下给出三个与数据库相关的日期时间类型:

  • Date:表示日期,只有年月日,没有时分秒。会丢失时间;
  • Time:表示时间,只有时分秒,没有年月日。会丢失日期;
  • Timestamp:表示时间戳,有年月日时分秒,以及毫秒
@Test    public void  test03(){           Date utilDate = new Date();//util utilDate        System.out.println("utilDate : " + utilDate);        //uilt date转sql date        java.sql.Date sqldate = new java.sql.Date(utilDate.getTime());        Time sqltime = new Time(utilDate.getTime());        Timestamp Timestamp = new Timestamp(utilDate.getTime());        System.out.println("sqldate : " + sqldate);        System.out.println("sqltime : " + sqltime);        System.out.println("Timestamp : " + Timestamp);    }

在这里插入图片描述

util.Date与sql.Date的相互转换

一: java.sql.Date=>java.util.Date

因为本身sql.Date就是 java.util.Date子类 .多态呈现

上向转型,会自动转换

Date date4 = new java.sql.Date(2343243242323L);

二 如何将java.util.Date对象转换为 => java.sql.Date对象

  • 情况一:(java.sql.Date) date4;强转
  • 情况二:new java.sql.Date(date6.getTime()); 利用时间戳,通过构造函数
@Test    public void  test04(){           //如何将java.util.Date对象转换为java.sql.Date对象        //情况一:       Date date4 = new java.sql.Date(2343243242323L);       java.sql.Date date5 = (java.sql.Date) date4;               System.out.println(date4);        System.out.println(date5);        //情况二:        Date date6 = new Date();        java.sql.Date date7 = new java.sql.Date(date6.getTime());                System.out.println(date6);        System.out.println(date7);    }}

在这里插入图片描述

补充:

同时util.Date和sql.Date都可以用SimpleDateFormat格式化

@Test    public void  test05(){           Date utilDate = new Date();//uilt.Date        System.out.println("utilDate :        " + utilDate);        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");        System.out.println("format utilDate : " + format.format(utilDate));        System.out.println("**********************************************");        java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());        Timestamp Timestamp = new Timestamp(utilDate.getTime());//uilt.Date转sql.Date        System.out.println("sqlDate :          " + sqlDate);        System.out.println("format sqlDate:    " + format.format(sqlDate));        System.out.println("**********************************************");        System.out.println("Timestamp        : " + Timestamp);        System.out.println("format Timestamp : " + format.format(Timestamp));    }

在这里插入图片描述

转载地址:http://yxmo.baihongyu.com/

你可能感兴趣的文章
navicat 系列软件一点击菜单栏就闪退
查看>>
navicat 自动关闭_干掉Navicat!MySQL官方客户端到底行不行?
查看>>
Navicat 设置时间默认值(当前最新时间)
查看>>
navicat 连接远程mysql
查看>>
navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
查看>>
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>