基础巩固10-- java.util.date 和java.sql.date 的转化,格式化,以及与数据库的交互

在这里插入图片描述
一、先来看不同date类的转化

package com.javabase.javabase.usualClass;

import org.junit.Test;

import java.sql.Time;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;

/**
 * @Author ShawnYang
 * @Date 2019-09-27 16:10
 * @Description util.date 和sql.date 之间的转换以及自定义格式化输出
 * 修改人:
 * 修改时间:
 * 修改备注:
 */
public class UtilDateTransforSqlDate {

    @Test
    public void test01() {

//      1 util.date 转化为 sql.date
        java.util.Date utldate = new java.util.Date();

        System.out.println("1    "+utldate);//Fri Sep 27 16:29:56 CST 2019

//        java.sql包下给出三个与数据库相关的日期时间类型:(这三者都是java.sql.Date的子类)
//          Date:表示日期,只有年月日,没有时分秒。会丢失时间;
//          Time:表示时间,只有时分秒,没有年月日。会丢失日期;
//          Timestamp:表示时间戳,有年月日时分秒,以及毫秒。
//      1.1 这种转换方式只有年月日
        java.sql.Date sqldate = new java.sql.Date(utldate.getTime());
        System.out.println("1.1    "+sqldate);//2019-09-27
//      1.2 这种转换方式只有时分秒
        Time time = new java.sql.Time(utldate.getTime());
        System.out.println("1.2    "+time);//16:29:56
//      1.3 这种方式两者都有
        Timestamp timestamp=new java.sql.Timestamp(utldate.getTime());
        System.out.println("1.3    "+timestamp);//2019-09-27 16:35:37.491

//      2 sql.date 转化为 util.date
        java.util.Date utldate2 = new java.util.Date(sqldate.getTime());
        System.out.println("2.1    "+utldate2);//Fri Sep 27 16:53:19 CST 2019
//      由于是子类的关系,所以也可如下进行赋值,通过向上转型进行
        java.util.Date utldate3=sqldate;
        System.out.println("2.2    "+utldate3);

        java.util.Date utldate4=time;
        System.out.println("2.3    "+utldate4);

        java.util.Date utldate5=timestamp;
        System.out.println("2.4    "+utldate5);

//      3 自定义格式化输出
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

//      格式化并输出 java.util.date 对象
        String format = simpleDateFormat.format(utldate);

        System.out.println(format);//2019-09-27 16:16:15

//      格式化并输出 java.sql.date 对象
        String format1 = simpleDateFormat.format(sqldate);

        System.out.println(format1);//2019-09-27 16:16:15
//      格式化并输出 java.sql.time 对象
        String format2 = simpleDateFormat.format(time);

        System.out.println(format2);//2019-09-27 16:16:15
//      格式化并输出 java.sql.timeStamp 对象
        String format3 = simpleDateFormat.format(timestamp);

        System.out.println(format3);//2019-09-27 16:16:15
    }
}


在这里插入图片描述
这部分内容参考:https://blog.csdn.net/engerla/article/details/81298645
https://blog.csdn.net/maoyuanming0806/article/details/78011700 这两篇博文

由此,存入数据库时的date类型装换的问题
参照:
https://blog.csdn.net/tomoto_zh/article/details/51606822

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值