SQLite JDBC rs.getDate() getTimestamp() 等都返回错误值

SQLite JDBC rs.getDate() getTimestamp() etc. all return wrong values(SQLite JDBC rs.getDate() getTimestamp() 等都返回错误值)
本文介绍了SQLite JDBC rs.getDate() getTimestamp() 等都返回错误值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当出于某种原因使用 JDBC for SQLite 时,日期和时间戳值正确存储在数据库中,在使用命令行 sqlite3 工具时正确显示,但是当使用 ResultSet 函数检索这些值时,它不起作用.下面是一个小型测试类,演示了我的意思.

When using the JDBC for SQLite for some reason Date and Timestamp values are stored correctly in the DB, are displayed correctly when using the command line sqlite3 tool, but when using the ResultSet functions to retrieve these values it doesn't work. Below is a small test class that demonstrates what I mean.

import java.sql.*;

public class Test {
  public static void main(String[] args) throws Exception {
    Class.forName("org.sqlite.JDBC");
    Connection conn = DriverManager.getConnection("jdbc:sqlite:test.db");
    Statement stat = conn.createStatement();
    stat.executeUpdate("drop table if exists people;");
    stat.executeUpdate("create table people (name, occupation, date date);");
stat.executeUpdate("insert into people values ('Turing', 'Computers', date('now'));");

    ResultSet rs = stat.executeQuery("select * from people;");
    while (rs.next()) {
      System.out.println("name = " + rs.getString("name"));
      System.out.println("job = " + rs.getString("occupation"));
      System.out.println("date = " + rs.getDate("date"));
      System.out.println("dateAsString = " + rs.getString("date"));
    }
    rs.close();
    conn.close();
  }
}

我得到的输出是:

name = 图灵
工作 = 计算机
日期 = 1970-01-01
dateAsString = 2011-03-24

name = Turing
job = Computers
date = 1970-01-01
dateAsString = 2011-03-24

推荐答案

就像 Scott 说的:SQLite 没有 Date 类型.

Like Scott says: SQLite does not have a Date type.

您可以让 SQLite 使用 strftime 函数为您进行转换:strftime('%s', 日期).然后就可以在Java端使用rs.getDate了.

You could have SQLite do the conversion for you with the strftime function: strftime('%s', date). Then you can use rs.getDate on the Java side.

您还可以将 SQLite 日期作为字符串检索,并将其解析为日期:

You can also retrieve the SQLite date as string, and parse that into a date:

DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
try {
    Date today = df.parse(rs.getString("date"));
    System.out.println("Today = " + df.format(today));
} catch (ParseException e) {
   e.printStackTrace();
}

这篇关于SQLite JDBC rs.getDate() getTimestamp() 等都返回错误值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)
FastAPI + Tortoise ORM + FastAPI Users (Python) - Relationship - Many To Many(FastAPI+Tortoise ORM+FastAPI用户(Python)-关系-多对多)
Window functions not working in pd.read_sql; Its shows error(窗口函数在pd.read_sql中不起作用;它显示错误)
How to group by continuous records in SQL(如何在SQL中按连续记录分组)
(Closed) Leaflet.js: How I can Do Editing Geometry On Specific Object I Select Only?((已关闭)Leaflet.js:如何仅在我选择的特定对象上编辑几何图形?)
How do I set SQL mode in the JDBC connection string for MySQL 8?(如何在MySQL 8的JDBC连接字符串中设置SQL模式?)