ホームページ >データベース >mysql チュートリアル >JDBC を使用して H2 データベースに「java.time.LocalDate」オブジェクトを挿入および取得する方法

JDBC を使用して H2 データベースに「java.time.LocalDate」オブジェクトを挿入および取得する方法

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-22 01:47:09214ブラウズ

How to Insert and Retrieve `java.time.LocalDate` Objects in an H2 Database Using JDBC?

JDBC を使用して、H2 データベースなどの SQL データベースで java.time.LocalDate オブジェクトを挿入および取得します

質問:

JDBC を使用して H2 データベース エンジンのような SQL データベースに java.time 型 (例: LocalDate) を挿入および取得するにはどうすればよいですか?

答え:

方法 1: JDBC 4.2 と互換性のあるドライバー

JDBC 4.2 仕様以降に準拠した JDBC ドライバーの場合、setObject メソッドと getObject メソッドを直接使用して java.time オブジェクトを処理できます。ドライバーは Java 型を自動的に検出し、対応する SQL 型に変換します。例:

<code class="language-java">preparedStatement.setObject(1, myLocalDate); // LocalDate转换为SQL DATE
LocalDate localDate = myResultSet.getObject("my_date_column_", LocalDate.class); // 指定预期类以确保类型安全</code>

方法 2: JDBC 4.2 より前の古いバージョンのドライバー

JDBC 4.2 に準拠していないドライバーの場合は、java.time オブジェクトを同等の java.sql 型に、またはその逆に簡単に変換する必要があります。従来のクラスに追加された変換メソッドを使用します:

<code class="language-java">java.sql.Date mySqlDate = java.sql.Date.valueOf(myLocalDate);
preparedStatement.setDate(1, mySqlDate);
java.sql.Date sqlDate = myResultSet.getDate("date_"); //尽可能简短地处理转换
LocalDate localDate = sqlDate.toLocalDate();</code>

JDBC 4.2 互換ドライバーの例:

<code class="language-java">import java.sql.*;
import java.time.LocalDate;
import java.time.ZoneId;

public class LocalDateExample {

    public static void main(String[] args) throws SQLException {
        String url = "jdbc:h2:mem:test_db"; // 更改为您的数据库URL
        String user = "user";
        String password = "password";

        try (
                Connection conn = DriverManager.getConnection(url, user, password);
                Statement stmt = conn.createStatement();
        ) {
            stmt.execute("CREATE TABLE IF NOT EXISTS employees (id INT PRIMARY KEY, name VARCHAR(255), birthday DATE)");

            // 插入LocalDate值
            LocalDate today = LocalDate.now(ZoneId.of("America/Montreal"));

            PreparedStatement pstmt = conn.prepareStatement("INSERT INTO employees (name, birthday) VALUES (?, ?)");
            pstmt.setString(1, "John Doe");
            pstmt.setObject(2, today); // 直接传递LocalDate
            pstmt.executeUpdate();

            // 检索LocalDate值
            ResultSet rs = stmt.executeQuery("SELECT * FROM employees");
            while (rs.next()) {
                LocalDate birthday = rs.getObject("birthday", LocalDate.class); // 指定预期类
                System.out.println("员工:" + rs.getString("name") + ",生日:" + birthday);
            }

            rs.close();
            pstmt.close();
            stmt.close();
        }
    }
}</code>

レガシードライバーの例:

<code class="language-java">import java.sql.*;
import java.time.LocalDate;

public class LocalDateExample {

    public static void main(String[] args) throws SQLException {
        String url = "jdbc:h2:mem:test_db"; // 更改为您的数据库URL
        String user = "user";
        String password = "password";

        try (
                Connection conn = DriverManager.getConnection(url, user, password);
                Statement stmt = conn.createStatement();
        ) {
            stmt.execute("CREATE TABLE IF NOT EXISTS employees (id INT PRIMARY KEY, name VARCHAR(255), birthday DATE)");

            // 插入LocalDate值
            LocalDate today = LocalDate.now();
            java.sql.Date sqlDate = java.sql.Date.valueOf(today);

            PreparedStatement pstmt = conn.prepareStatement("INSERT INTO employees (name, birthday) VALUES (?, ?)");
            pstmt.setString(1, "John Doe");
            pstmt.setDate(2, sqlDate); // 将LocalDate转换为java.sql.Date
            pstmt.executeUpdate();

            // 检索LocalDate值
            ResultSet rs = stmt.executeQuery("SELECT * FROM employees");
            while (rs.next()) {
                java.sql.Date sqlDate = rs.getDate("birthday");
                LocalDate birthday = sqlDate.toLocalDate(); // 将java.sql.Date转换为LocalDate
                System.out.println("员工:" + rs.getString("name") + ",生日:" + birthday);
            }

            rs.close();
            pstmt.close();
            stmt.close();
        }
    }
}</code>

以上がJDBC を使用して H2 データベースに「java.time.LocalDate」オブジェクトを挿入および取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。