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

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

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

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

0回答

1456閲覧

入力フォームで*入力時に抜ける無限ループを作成したい

ribo

総合スコア11

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

0グッド

0クリップ

投稿2018/06/11 08:05

編集2022/01/12 10:55

現在課題で商品一覧を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;
}

}

過去の投稿を踏まえて具体的に書いたつもりです。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問