MySQL 问题:向数据库中插入时间类型数据,数据库中只有日期没有时分秒

本文讨论了在向MySQL数据库中插入时间数据时遇到的问题,解释了java.util.Date、java.sql.Date和java.sql.Timestamp的区别。在插入数据时,建议使用Timestamp来保留时分秒信息。而在从数据库取出数据并在jsp页面上显示时,由于出现了额外的0,可以通过jstl的<fmt:formatDate>标签进行格式化以解决这个问题。
摘要由CSDN通过智能技术生成

一、关于向MySQL数据库中插入时间只有日期没有时分秒  
  java.util.Date是不能直接插入数据库中的,虽然它包含了日期和时分秒。
  java.sql.Date可以直接插入数据库,但是它只有日期而没有时间;
  java.sql.Time可以直接插入数据库,但是它只有时间,没有日期
Java.util.Date需要转换为Java.sql.Date,常规的方式转换过来只可以得到年月日,如若要取得时分秒,可以用Java.sql.Date类的子类Timestamp
 使用java.sql.Timestamp来向数据库插入。在程序中,我们常常是使用的java.util.Date,所以就要将java.util.Date转化为java.sql.Timestamp
1.插入数据时:

 

Connection conn = null;  
        PreparedStatement psmt = null;  
        ResultSet rs = null;  
  
        try {  
            conn = DBUtil.getConnection();  
            psmt = conn.prepareStatement(sql);  
            psmt.setString(1, message.getmTitle());  
            psmt.setString(2, message.getmContent());  
            psmt.setTimestamp(3, new Timestamp(message.getmPublishTime().getTime()));//将java.util.Date转化为java.sql.Timestamp
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值