質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

4593閲覧

TimestampをLocalDateTimeに変換したい。(DAO)

kulkul

総合スコア12

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2020/06/01 05:18

環境:Java11

Java

1public boolean create(Mutter mutter) { 2 try(Connection conn = DriverManager.getConnection(JDBC_URL,DB_USER,DB_PASS)){ 3 String sql = "INSERT TNTO MUTTER(POSTCONTENT,POSTUSERNAME,CREATED_AT,UPDATED_AT,ENABLED) VALUES(?,?,?,?,?)"; 4 PreparedStatement pstmt = conn.prepareStatement(sql); 5 6 pstmt.setString(1,mutter.getPostContent()); 7 pstmt.setString(2,mutter.getPostUserName()); 8 pstmt.setTimestamp(3,mutter.getCreated_at()); --不明点 9 pstmt.setTimestamp(4,mutter.getUpdated_at()); --不明点 10 pstmt.setBoolean(5,mutter.getEnabled());

DAO内のメソッドです。
Created_at,Updated_atは別のクラスでLocalDateTime型で定義しています。(DBのエンティティです)
3文目でDBにINSERTする記述をしています。
そのためSETTimestampの中身をtoLocalDateTime()のようにキャストしたいのですが、そのメソッドが使えないようです。
他に型の変換をする方法があれば教えていただきたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

そもそもSQLパラメーターの型とjava型の関係性はたいしてないので

LocalDate date = LocalDate.now(); String text = date.format(formatter); st.setString(text);

のように SQL が日付型を認識できる文字列に変換して設定してあげればいいです。

相関性が発生するのは ResultSet だけです!!

投稿2020/06/01 12:44

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

そのためSETTimestampの中身をtoLocalDateTime()のようにキャストしたいのですが、そのメソッドが使えないようです。

なにをどうしたいのかよくわかりませんが、setTimeStamp()の第二引数はTimeStampなので、こうすればいいのでは?

java

1//pstmt.setTimestamp(3,mutter.getCreated_at()); --不明点 2pstmt.setTimestamp(3, new Timestamp(mutter.getCreated_at().toInstant(ZoneOffset.of("+0900")).toEpochMilli()));

投稿2020/06/01 12:24

shiketa

総合スコア4061

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問