mysql的datetime类型在java中的存取

Mysql中的DATE和DATETIME有什么区别?

DATETIME
类型可用于需要同时包含日期和时间信息的值。MySQL 以 'YYYY-MM-DD HH:MM:SS'
格式检索与显示 DATETIME 类型。支持的范围是
'1000-01-01
00:00:00' 到 '9999-12-31
23:59:59'。(“支持”的含义是,尽管更早的值可能工作,但不能保证他们均可以。)

DATE
类型可用于需要一个日期值而不需要时间部分时。MySQL 以 'YYYY-MM-DD' 格式检索与显示
DATE
值。支持的范围是 '1000-01-01' 到
'9999-12-31'。

但是在java中只有Date类型,这样数据存储会出现问题,前台提交的数据,比如2016-10-10 14:30:59,后台用Date接受的时候,由于Date之精确到天,所以,默认接收时间为2016-10-10 00:00:00,保存到mysql数据库之后,重新取出数据的时候又会发现,数据为2016-10-10 00:00:00.0,无缘无故在后面多了一个.0,这样页面渲染的时候就会报错,

解决方法:

前台提交到java后端时:

@NotNull(message = "必须提供时间")
    private Date date;
 public Date getDate() {
        return date;
    }

    public void setDate(String date) {
        SimpleDateFormat f = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
        try {
            this.date = f.parse(date);
        } catch (ParseException e) {
            e.printStackTrace();
        }
    }

从数据库查询出的数据:

    public String getDateStr() {
        return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.date);
    }

在页面渲染的时候获取属性dateStr即可!

  • 8
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值