java.sql.Dateをjava.time.LocalDateに変換中にJavaSpring BootJpaエラーが発生しました

ミヒル

Java11とSpringbootv2.3.3.RELEASEを使用しています。以下は私のpom.xmlです。2列と1行を返すDB関数からデータをフェッチしようとしています。返される列はDate(Postgres SQL)です。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.group</groupId>
    <artifactId>artifact</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>demo</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>11</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-cache</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>0.9.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-validation</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <scope>runtime</scope>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.11.2</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.11</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/commons-beanutils/commons-beanutils -->
        <dependency>
            <groupId>commons-beanutils</groupId>
            <artifactId>commons-beanutils</artifactId>
            <version>1.9.4</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

次のモデルクラスがあります。

import com.fasterxml.jackson.annotation.JsonFormat;

import java.time.LocalDate;


public class CachedDate {
    @JsonFormat(
            shape = JsonFormat.Shape.STRING,
            pattern = "yyyy-MM-dd",
            locale = "en_CA")
    private LocalDate businessDate;
    @JsonFormat(
            shape = JsonFormat.Shape.STRING,
            pattern = "yyyy-MM-dd",
            locale = "en_CA")
    private LocalDate previousBusinessDate;
// constructor/ getter and setter ommited
}

DB関数呼び出しに基づいてデータを取得しようとしているリポジトリがあります。

Query query = entityManager.createNativeQuery(
        "SELECT * FROM get_function(:date)"
);
query.setParameter("date", date);
List<Object> result = (List<Object>) query.getResultList();
Iterator it = result.iterator();
CachedDate dates = new CachedDate();

while (it.hasNext()) {
    Object[] row = (Object[]) it.next();
    //dates.setBusinessDate((LocalDate) row[0]);
    //dates.setPreviousBusinessDate((LocalDate) row[1]);
     // This gives error 1


    dates.setBusinessDate(LocalDate.parse((String) row[0]));
    dates.setPreviousBusinessDate(LocalDate.parse((String) row[1]));

    // This gives error 2
}

エラー1

Caused by: java.lang.ClassCastException: class java.sql.Date cannot be cast to class java.time.LocalDate (java.sql.Date is in module java.sql of loader 'platform'; java.time.LocalDate is in module java.base of loader 'bootstrap')

エラー2

Caused by: java.lang.ClassCastException: class java.sql.Date cannot be cast to class java.lang.String (java.sql.Date is in module java.sql of loader 'platform'; java.lang.String is in module java.base of loader 'bootstrap')

ここでの問題は何ですか?モデルクラスはDB内のオブジェクトではないため、エンティティとして持つことはできません。これは、関数から返されるものです。しかし、それが助けになるかどうかはわかりません。

ここでお手伝いできますか?

goldthelocks

クエリの戻り値の型はjava.sql.Dateです。最初にキャストしてからjava.sql.Dateを呼び出し.toLocalDate()てに変換する必要がありLocalDateます。

サンプル:

   dates.setBusinessDate(((java.sql.Date) row[0]).toLocalDate());
   dates.setPreviousBusinessDate(((java.sql.Date) row[1]).toLocalDate());

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

JDBCを介して取得したjava.sql.Date値をjava.time.LocalDateに変換しますか?

java.sql.Dateとjava.util.Dateをorg.joda.time.LocalDateに変換する

java.time.LocalDateをjava.util.Dateタイプに変換します

Javaプログラムを介してpentaho変換(SQLサーバーと通信)を実行中にエラーが発生しました

PNGをTIFF-Javaに変換中にエラーが発生しました

PNGをTIFF-Javaに変換中にエラーが発生しました

SQL:varcharをintに変換中にエラーが発生しました

SQLでvarcharをdatetimeに変換中にエラーが発生しました

java.sql.timestampをLocalDate(java8)java.timeに変換する方法は?

Javaでの日付の変換中にエラーが発生しました

LocalDateをLocalDateTimeまたはjava.sql.Timestampに変換します

データベース(JAVA)への接続中にSQL構文でエラーが発生しました

java.util.Dateをjava.time.LocalDateに変換する

SQLiteからjava.SQL.TimestampにDATETIMEを解析するときにエラーが発生しました

Clojure(cljc.java-time)-日付間の日数の間にキャストエラーが発生しました

生のSQLを雄弁なコードに変換中にエラーが発生しました

WritableRasterとDataBufferByteを使用してJavaで画像をbyte []に変換中にエラーが発生しました。

データ型varcharを数値に変換中にエラーが発生しました。sql t-sql

データ型varcharを数値に変換中にエラーが発生しました。sql t-sql

INSERTクエリSQL(データ型nvarcharを(null)に変換中にエラーが発生しました)

Javaで16進数を緯度と経度に変換中にエラーが発生しました

動的SQLクエリでvarcharを数値に変換中にエラーが発生しました

SQL Server:データ型nvarcharを数値に変換中にエラーが発生しました

SQL Server:データ型nvarcharを日時に変換中にエラーが発生しました

SQL-データ型varcharを数値に変換中にエラーが発生しました

SQL Server:データ型varcharを数値に変換中にエラーが発生しました

SQLで式をデータ型intに変換中にエラーが発生しました

Java:ビルド時にエラーが発生しました

JAVAを使用してSQLへの入力を保存しようとしたときにエラーが発生しました

TOP 一覧

  1. 1

    Unity:未知のスクリプトをGameObject(カスタムエディター)に動的にアタッチする方法

  2. 2

    セレンのモデルダイアログからテキストを抽出するにはどうすればよいですか?

  3. 3

    Ansibleで複数行のシェルスクリプトを実行する方法

  4. 4

    tkinterウィンドウを閉じてもPythonプログラムが終了しない

  5. 5

    Crashlytics:コンパイラー生成とはどういう意味ですか?

  6. 6

    GoDaddyでのCKEditorとKCfinderの画像プレビュー

  7. 7

    Windows 10 Pro 1709を1803、1809、または1903に更新しますか?

  8. 8

    Chromeウェブアプリのウェブビューの高さの問題

  9. 9

    モーダルダイアログを自動的に閉じる-サーバーコードが完了したら、Googleスプレッドシートのダイアログを閉じます

  10. 10

    Windows 10の起動時間:以前は20秒でしたが、現在は6〜8倍になっています

  11. 11

    Reactでclsxを使用する方法

  12. 12

    ファイル内の2つのマーカー間のテキストを、別のファイルのテキストのセクションに置き換えるにはどうすればよいですか?

  13. 13

    MLでのデータ前処理の背後にある直感

  14. 14

    グラフからテーブルに条件付き書式を適用するにはどうすればよいですか?

  15. 15

    Pythonを使用して同じ列の同じ値の間の時差を取得する方法

  16. 16

    mutate_allとifelseを組み合わせるにはどうすればよいですか

  17. 17

    ネットワークグラフで、ネットワークコンポーネントにカーソルを合わせたときに、それらを強調表示するにはどうすればよいですか?

  18. 18

    テキストフィールドの値に基づいて UIslider を移動します

  19. 19

    BLOBストレージからデータを読み取り、Azure関数アプリを使用してデータにアクセスする方法

  20. 20

    PowerShellの分割ファイルへのヘッダーの追加

  21. 21

    ソートされた検索、ターゲット値未満の数をカウント

ホットタグ

アーカイブ