現在課題で商品一覧をDBから取得してユーザーが選択し購入するECサイトのようなプログラムを作成しています。
*を入力すると商品コード入力のループを抜けられるように書きたいのですが、調べてもどのように記述すればいいのかわかりません。
一つ目のmainクラスで無限ループと入力フォームや入力チェックを行いここにはない3つ目のクラスとして数量と商品コードを受け取るカートの役割を持ったプログラムを作成予定です。
現状調べて見つけたソースを書き換えたりして試しているのですが
public static void main(String args[]) {
System.out.print("商品コードを入力してください(*で終了): "); Scanner scan = new Scanner(System.in); int inputValue = scan.nextInt(); // inputValue が * でなければループ while (inputValue != *) { System.out.println("入力された値は" + inputValue + "でした"); System.out.print("商品コードを入力してください(*で終了): "); inputValue = scan.nextInt(); } scan.close(); System.out.println("精算します"); }
のような書き方を見つけましたがうまい書き換え方がわかりません。
①
package sample_java;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.HashMap;
import java.util.Map;
public class Main {
public static void main( String args[] ) throws Exception {
String url = "mysqlが入る";
String user = "root";
String pwd = "root";
Map<Integer, Shouhin> map = new HashMap<>() ;
Connection con = null;
try {
// JDBCドライバのロード
Class.forName("com.mysql.cj.jdbc.Driver").newInstance();
// MySQLに接続
con = DriverManager.getConnection(url, user, pwd);
System.out.println("MySQLに接続できました。");
Statement stmt = con.createStatement();
String sql = "SELECT * FROM shouhin_mst";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()) {
int code = rs.getInt("SHOUHIN_CD");
String name = rs.getString("shouhin_name");
int price = rs.getInt("unit_price");
map.put(code,new Shouhin(code,name,price));
System.out.println(map.get(code));
}
rs.close();
stmt.close();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (con != null) {
try {
con.close();
} catch (SQLException e) {
System.out.println("MySQLのクローズに失敗しました。");
}
}
}
}
}
package sample_java;
②
public class Shouhin {
int cd;
String name;
int price;
@Override
public String toString() {//見やすいように変えるメソッド
return cd + ":" + name + "(" + price + ")";
}
public Shouhin(int code, String name, int price){
this.cd = code;
this.name = name;
this.price = price;
}
public int getCd() {
return cd;
}
public String getName() {
return name;
}
public int getPrice() {
return price;
}
}
過去の投稿を踏まえて具体的に書いたつもりです。
あなたの回答
tips
プレビュー