gpt4 book ai didi

java - 使用 UCanAccess JDBC 驱动程序时格式化日期

转载 作者:搜寻专家 更新时间:2023-10-31 20:11:14 25 4
gpt4 key购买 nike

在 Java 中使用 UCanAccess 驱动程序时,我发现很难将日期输出为特定格式。目前,我正在使用 PreparedStatement.setDate() 方法,该方法要求日期的格式为 [yyyy-MM-dd HH:mm:ss]。当用户打开文件时,生成的输出也是这种格式。

编辑* - 我没有使用带有格式化日期的 setDate() 方法,此方法只接受没有格式的 Java Date 对象。我想写的是,我在处理格式化日期时使用 setString() 方法,但 UCanAccess 要求此日期字符串的格式为 [yyyy-MM-dd HH:mm:ss]。我真的只是想弄清楚如何在调用 setString() 后为它提供不同的格式或更改格式。

到目前为止一切正常,但现在我需要交付带有各种格式日期的文件,例如 [MM-dd]。我已经可以通过将生成的 Access 字段类型设为备忘录或文本来做到这一点,但是当我需要日期采用该格式并且生成的 Access 字段类型仍然是日期/时间时,问题就来了。

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

提前致谢!

最佳答案

当您通过 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 页面谈到“Access 日期格式”时,它指的是包含在井号中的日期/时间文字,如下所示:#11/22/2003 10:42:58 PM#。但是,您几乎不需要在查询中包含日期文字,因为您应该使用具有适当 .setTimestamp() 参数的 PreparedStatement。)

附录

类似地,将日期/时间值插入 Access 数据库时:Java 中日期/时间值的格式对日期/时间值在 Access 中的存储方式没有影响(前提是它被正确解释),并且它在 Access 中的显示方式是在 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 设置为使用我们看到的“英语(美国)”的默认格式

en_us.png

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

en_gb.png

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

DesignView.png

我们看到了

DatasheetView.png

关于java - 使用 UCanAccess JDBC 驱动程序时格式化日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26938076/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com