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

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

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

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

Q&A

解決済

1回答

714閲覧

日付のフォーマットの変更について

satosi.kikeo

総合スコア9

Java

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

0グッド

0クリップ

投稿2020/01/25 07:51

編集2020/01/25 10:21

dao

1public BuyDataBeans refer(String id) { 2 Connection conn = null; 3 try { 4 conn = DBManager.getConnection(); 5 String sql ="select \r\n" + 6 "t_buy.id,\r\n" + 7 "t_buy.user_id,\r\n" + 8 "t_buy.total_price,\r\n" + 9 "t_buy.delivery_method_id,\r\n" + 10 "t_buy.create_date,\r\n" + 11 "t_buy_detail.buy_id \r\n" + 12 "from \r\n" + 13 "t_buy \r\n" + 14 "inner join \r\n" + 15 "t_buy_detail \r\n" + 16 "on \r\n" + 17 "t_buy.id = t_buy_detail.buy_id \r\n" + 18 "where t_buy_detail.buy_id = ?\r\n" + 19 "group by t_buy.id "; 20 PreparedStatement pStmt = conn.prepareStatement(sql); 21 pStmt.setString(1,id); 22 23 ResultSet rs = pStmt.executeQuery(); 24 if (!rs.next()) { 25 return null; 26 } 27 28 29 30 int formatTotalPrice= rs.getInt("total_price"); 31 Timestamp name2 = rs.getTimestamp("create_date"); 32 33 34 return new BuyDataBeans(formatTotalPrice,name2); 35 36 } catch (SQLException e) { 37 38 e.printStackTrace(); 39 } finally { 40 41 if (conn != null) { 42 try { 43 conn.close(); 44 } catch (SQLException e) { 45 e.printStackTrace(); 46 47 } 48 } 49 } 50 51 52 return null; 53 54 } 55      public static void main(String[] args) { 56 Calendar cl = Calendar.getInstance(); 57 58 // SimpleDateFormatクラスを使用して、パターンを設定する 59 SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日"); 60 System.out.println(sdf.format(cl.getTime())); 61 }

beans

1package beans; 2 3import java.io.Serializable; 4import java.sql.Timestamp; 5import java.text.SimpleDateFormat; 6import java.util.Date; 7 8 9/** 10 * 購入データ 11 * @author d-yamaguchi 12 * 13 */ 14public class BuyDataBeans implements Serializable { 15 private int id; 16 private int userId; 17 private int totalPrice; 18 private int delivertMethodId; 19 private Date buyDate; 20 private Date create_date; 21 22 private String deliveryMethodName; 23 private int deliveryMethodPrice; 24 private String name; 25 private int item_id; 26 private int price; 27 28 29 30 31 32 33 34 35 36 public BuyDataBeans(int id2, int user_id, int total_price, String delivertMethodname, java.sql.Date create_date2) { 37 this.id = id2; 38 this.userId = user_id; 39 this.totalPrice = total_price; 40 this.deliveryMethodName = delivertMethodname; 41 this.create_date = create_date2; 42} 43 44 45 46 47 public BuyDataBeans(java.sql.Date create_date2, String delivertMethodname, int total_price) { 48 this.create_date = create_date2; 49 this.deliveryMethodName = delivertMethodname; 50 this.totalPrice = total_price; 51 // TODO 自動生成されたコンストラクター・スタブ 52 } 53 54 55 56 57 58 59 public BuyDataBeans(String name2, int price2) { 60 this.name = name2; 61 this.setPrice(price2); 62 } 63 64 65 66 67 68 69 70 71 72 73 74 public BuyDataBeans() { 75 // TODO 自動生成されたコンストラクター・スタブ 76 } 77 78 79 80 81 82 83 84 85 86 87 88 89 public BuyDataBeans(int formatTotalPrice, Timestamp name2) { 90 this.totalPrice = formatTotalPrice; 91 this.create_date = name2; 92 } 93 94 95 96 97 public BuyDataBeans(String name2) { 98 this.name = name2; 99 } 100 101 102 103 104 public int getId() { 105 return id; 106 } 107 public void setId(int id) { 108 this.id = id; 109 } 110 public int getUserId() { 111 return userId; 112 } 113 public void setUserId(int userId) { 114 this.userId = userId; 115 } 116 public int getTotalPrice() { 117 return totalPrice; 118 } 119 public void setTotalPrice(int totalPrice) { 120 this.totalPrice = totalPrice; 121 } 122 123 124 public int getDelivertMethodId() { 125 return delivertMethodId; 126 } 127 public void setDelivertMethodId(int delivertMethodId) { 128 this.delivertMethodId = delivertMethodId; 129 } 130 public Date getBuyDate() { 131 return buyDate; 132 } 133 public void setBuyDate(Date buyDate) { 134 this.buyDate = buyDate; 135 } 136 public String getDeliveryMethodName() { 137 return deliveryMethodName; 138 } 139 public void setDeliveryMethodName(String deliveryMethodName) { 140 this.deliveryMethodName = deliveryMethodName; 141 } 142 143 public String getFormatDate() { 144 SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日HH時mm分"); 145 return sdf.format(buyDate); 146 } 147 148 public String getFormatTotalPrice() { 149 return String.format("%,d", this.totalPrice); 150 } 151 public int getDeliveryMethodPrice() { 152 return deliveryMethodPrice; 153 } 154 public void setDeliveryMethodPrice(int deliveryMethodPrice) { 155 this.deliveryMethodPrice = deliveryMethodPrice; 156 } 157 158 159 160 161 162 public Date getCreate_date() { 163 return create_date; 164 } 165 166 167 168 169 170 public void setCreate_date(Date create_date) { 171 this.create_date = create_date; 172 } 173 174 175 176 177 178 public String getName() { 179 return name; 180 } 181 182 183 184 185 186 public void setName(String name) { 187 this.name = name; 188 } 189 190 191 192 193 194 public int getItem_id() { 195 return item_id; 196 } 197 198 199 200 201 202 public void setItem_id(int item_id) { 203 this.item_id = item_id; 204 } 205 206 207 208 209 public int getPrice() { 210 return price; 211 } 212 213 214 215 216 public void setPrice(int price) { 217 this.price = price; 218 } 219 220 221 222 223 224 225 226} 227

初めて投稿させていただきます
よろしくお願いします。
日付のフォーマットの変更についてどうすればいいかなやんでいます
データベースのほうにはcreate_dateとして登録をしています。
それを
public String getFormatDate() {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日HH時mm分");
return sdf.format(buyDate);
}
の所のように変換したいのですが2020-01-25 00:53:06.0というふうに出力していしまいます
Timestamp name2 = rs.getTimestamp("create_date");が原因だとはわかっているのですがどのように書けばいいか悩んでいます
ご回答ありがとうございます
参考資料を見させていただいたのですが
使い方、意味がよく理解できませんでした
上のDAOでも編集いたしましたがDAOの中で使うということでしょうか?
至らない所が多いいとは思いますがご回答お願いします

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

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

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

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

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

dodox86

2020/01/25 19:04 編集

やりたいことが少し分からないのですが、どこに出力したときのお話でしょうか。 DBのcreate_dateはbeanの内容からして java.sql.Date(インスタンスフィールドはjava.util.Date)ですが、DBの種類は分からないものの、DBのカラムもそれに沿ってDATETIME型やTIMESTAMP型のようなものだと推察します。SELECT文でDBから読み込んだ後、htmlや画面に表示出力するときにSimpleDateFormat("yyyy年MM月dd日HH時mm分")のような形で変換して出力したい、と言う意味でしょうか。
dodox86

2020/01/25 19:02

提示されたコードの中で、"// この部分でこの値をこんな感じで出力したい" とのようにコメントすると、やりたいことが明確になると思います。他回答者さんらにとっても要望を把握しやすいかと。あと、コード中の無用な空行が多くて読みづらいと思いますので、整理してもらえるとより良いです。
satosi.kikeo

2020/01/25 23:51

ご回答、ご指摘ありがとうございました。 要点の整理など今後気を付けようとおもいます。 問題は解決できました。 ありがとうございました
guest

回答1

0

ベストアンサー

投稿2020/01/25 07:58

cateye

総合スコア6851

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問