同时采用了UCanAccess JDBC驱动程序格式化日期

问题描述 投票:5回答:1

当使用Java中的UCanAccess司机,我发现输出日期,特定的格式也非常困难。目前,我使用需要的时间是在格式[YYYY-MM-DD HH:MM:SS]的了PreparedStatement.setDate()方法。所产生的输出,当用户打开该文件时,也正是在这种格式。

编辑* - 我不使用与格式化的日期的setDate()方法,这个方法只接受没有格式化的Java Date对象。我的意思写的是,我使用setString()方法格式化的日期打交道时,但UCanAccess需要此日期字符串是格式为[YYYY-MM-DD HH:MM:SS]。我真的只是想弄清楚如何可以给它不同的格式或更改格式我已经叫了setString()之后。

到目前为止,这已经很好,但现在我有一个需要提供的日期在文件中各种格式如[MM-DD。我可以通过使所产生的访问字段中键入一个备注或文本已经做到这一点,但是当我需要的日期是该格式,而且还有所产生的访问字段类型是日期/时间的问题就越大。

我注意到在UCanAccess front page,它提到支持访问日期的格式,但我经过几次谷歌搜索我没有找到任何例子的任何地方。任何人都知道如何格式化使用此驱动程序,同时保持正确的日期/时间类型的日期?

提前致谢!

java datetime ms-access jdbc ucanaccess
1个回答
4
投票

当您检索通过UCanAccess日期/时间字段的值,你得到一个java.sql.Timestamp对象。它包含日期/时间值,但它不具有本身的格式。

如果你想表示一个特定的方式,日期/时间值,你只需要对其进行格式化,以自己的喜好。也许这样做最简单的方法是用java.text.SimpleDateFormat。例如:

try (ResultSet rs = s.executeQuery("SELECT DateJoined FROM Members WHERE MemberID=1")) {
    rs.next();
    System.out.printf(
            "         \"raw\" value (via .toString()): %s%n", 
            rs.getTimestamp(1).toString());
    SimpleDateFormat mmddFormat = new SimpleDateFormat("MM-dd");
    System.out.printf(
            "formatted value (via SimpleDateFormat): %s%n", 
            mmddFormat.format(rs.getTimestamp(1)));
}

给我们

         "raw" value (via .toString()): 2014-01-23 00:00:00.0
formatted value (via SimpleDateFormat): 01-23

(请注意,当有关“访问日期格式”的UCanAccess页会谈是指包含在哈希标记这样的日期/时间文字:#11/22/2003 10:42:58 PM#然而,你应该几乎从不需要包括日期文字在您的查询,因为你应该使用具有适当PreparedStatement参数.setTimestamp()。)

附录

同样,将日期/时间值到Access数据库时:Java中的日期/时间值的格式,使该日期/时间值存储在访问的方式没有什么区别(只要它是正确的解释),和路它会显示在访问是在Access格式设置的功能。举例来说,如果我们运行下面的Java代码

try (Statement s = conn.createStatement()) {
    s.executeUpdate(
            "INSERT INTO tblDates " +
            "(ID, mmddyyyy) " +
            "VALUES " +
            "('literal', #12/25/2014#)"
            );
}

SimpleDateFormat mmddyyyyFormat = new SimpleDateFormat("MM/dd/yyyy");
Timestamp mmddyyyyXmas = 
        new Timestamp(mmddyyyyFormat.parse("12/25/2014").getTime());

SimpleDateFormat ddmmyyyyFormat = new SimpleDateFormat("dd/MM/yyyy");
Timestamp ddmmyyyyXmas = 
        new Timestamp(ddmmyyyyFormat.parse("25/12/2014").getTime());

SimpleDateFormat yyyymmddFormat = new SimpleDateFormat("yyyy/MM/dd");
Timestamp yyyymmddXmas = 
        new Timestamp(yyyymmddFormat.parse("2014/12/25").getTime());

try (PreparedStatement ps = conn.prepareStatement(
        "INSERT INTO tblDates " +
        "(ID, mmddyyyy, ddmmyyyy, yyyymmdd) " +
        "VALUES " +
        "('parameters', ?, ?, ?)"
        )) {
    ps.setTimestamp(1, mmddyyyyXmas);
    ps.setTimestamp(2, ddmmyyyyXmas);
    ps.setTimestamp(3, yyyymmddXmas);
    ps.executeUpdate();
}

然后打开Access数据库与Windows设置为使用默认格式“英语(美国)”我们看到

如果我们更改Windows中的格式设置为“英语(英国)”,那么我们看到的

如果我们要使用特定的格式为一个或多个字段,我们需要在Access中使用特定的格式设置,例如,像这样的东西

我们看

© www.soinside.com 2019 - 2024. All rights reserved.