Freak_Van 2016-01-04 13:08 采纳率: 50%
浏览 17364
已采纳

java中Date类型如何与mysql中的datetime类型联系

我在Mysql中建了一个datetime类型的数据
然后想在java中用Date类型来获取当前时间(变量名为inTime)并添加到数据库中
构造了一个函数,在传参数的时候应该怎么传,
还是到底是Import java.util.Date还是import java.sql.Date
并且我希望的时间格式为:2016-01-04 21:09:23
构造函数这样写对吗
public CheckIn( java.sql.Date inTime) {
inTime = new Date(System.currentTimeMillis());
}

public static void main(String args[]){
    CheckIn cin = new CheckIn( new Date());
}



希望大神能将详细的代码写出来并讲解,谢谢了
  • 写回答

3条回答 默认 最新

  • 毕小宝 博客专家认证 2016-01-08 03:05
    关注

    首先java.sql.Date是java.uti.Date的子类,但是java.sql.Date是sql相关的日期类型,我们用纯JDBC写数据库连接、查询时所用的日期就是这个类型。所以通常实体类用java.sql.Date和表结构中datetime类型映射,也可以用java.uti.Date,没有影响的。
    其次,在MySQL中以'YYYY-MM-DD HH:MM:SS'的形式显示DATETIME类型的值,但是使用jdbc取出的数据格式并不是这种格式的字符串的,需要我们自己转换一下。就你的需求,提供了一个简单的转换方法如下:

    import java.sql.Date;
    import java.text.DateFormat;
    import java.text.SimpleDateFormat;
    
    /**
     * 在MySQL中以'YYYY-MM-DD HH:MM:SS'的形式显示DATETIME类型的值
     * java代码中使用java.sql.Date和datetime字段对应
     * 但是java程序中对应java.sql.Date的显示问题需要进行转换
     * @author 金涛
     *
     */
    public class CheckIn {
        private Date inTime;
    
        public CheckIn(Date inTime) {
            this.inTime = inTime;
        }
    
        public String getFormatTime(String format) {
            String value = null;
            DateFormat dateFormat = new SimpleDateFormat(format);
            value =dateFormat.format(inTime);
            return value;
        }
    
        public static void main(String args[]) {
            CheckIn cin = new CheckIn(new Date(System.currentTimeMillis()));
            String formatTime = cin.getFormatTime("YYYY-MM-DD HH:MM:ss");
            System.out.println(formatTime);
        }
    
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境
  • ¥30 关于#java#的问题,请各位专家解答!
  • ¥30 vue+element根据数据循环生成多个table,如何实现最后一列 平均分合并
  • ¥20 pcf8563时钟芯片不启振