import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.mysql.jdbc.PreparedStatement;
import com.mysql.jdbc.Statement;
public class AddressDB {
private static enum Procnumlist {
NAME("名前"),
FNAME("フルネーム"),
END("終了");
private String name;
private Procnumlist(String name) {
}
}
//上の列挙型を基にした処理判定用マップを作成
private static final Map<Integer, Procnumlist> procmap;
static {
procmap = new HashMap<Integer, Procnumlist>();
procmap.put(1,Procnumlist.NAME);
procmap.put(2,Procnumlist.FNAME);
procmap.put(6,Procnumlist.END);
}
//結果
//ResultSetは受け取らない
private static void ans(List<Addr> ans) {
try {
System.out.println("検索結果");
for (int i = 0; i < ans.size(); i++) {
Addr addr = ans.get(i);
System.out.println(addr.getName() + ":" );
}
} catch (SQLException e) {
e.printStackTrace();
}
finally {
//閉じる。
close();
}
}
//名前検索(フルネーム)
private static List<Addr> srchFName(String keyword,Connection con) throws IOException {
String sql = "SELECT * FROM data2 where name=?";
PreparedStatement ps = null;
try{
ps = (PreparedStatement) con.prepareStatement(sql);
ps.setString(1,keyword);
ResultSet rs = ps.executeQuery();
//List<Addr> result = new ArrayList(Addr);
while(rs.next()){
rs.getString("name");
}
}catch (SQLException ex) {
}
return null;
}
//名前検索
private static List<Addr> srchName(String keyword,Connection con) throws IOException {
String sql = "SELECT * FROM data2 where name like ?";
PreparedStatement ps = null;
try{
ps = (PreparedStatement) con.prepareStatement(sql);
ps.setString(1,"%"+keyword+"%");
ResultSet rs = ps.executeQuery();
while(rs.next()){
Addr addr = rs.getString("name");
}
}catch (SQLException ex) {
}
return result;
}
private static boolean checkProcNum(int value) {
return procmap.get(value) != null;
}
public static void main(String[] args)throws IOException{
while(true) {
createConeection();
//処理条件入力
System.out.println("検索\n1.名前(ファーストネーム)で検索\n2.フルネームで検索\n6.終了");
//検索値入力
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int procnum = Integer.valueOf(br.readLine());
//入力チェック
if (!checkProcNum(procnum)) {
System.out.println("正しい値を入れてください。");
continue;
}
Procnumlist proc = procmap.get(procnum);
if (proc == Procnumlist.END) {
break;
}
if(proc == Procnumlist.NAME){
System.out.println("名前を入力してください。");
BufferedReader name =
new BufferedReader(new InputStreamReader(System.in));
String keyword = name.readLine();
List<Addr> result = srchName(keyword,null);
ans(result);
}
if(proc == Procnumlist.FNAME){
System.out.println("フルネームを入力してください。");
BufferedReader name =
new BufferedReader(new InputStreamReader(System.in));
String keyword = name.readLine();
List<Addr> result = srchFName(keyword,null);
ans(result);
}
}
}
//コネクション
private static Connection createConeection() {
String url = "jdbc:mysql://localhost/address";
String user = "test";
String password = "pass";
try {
return DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
e.printStackTrace();
return null;
}
}
}
現在JDBCでDB接続し入力された値をDBから検索し出力するものを作成しておりますが詰んでしまいました。
入力した値をsrchで検索し結果をansで出力しようとしています。どのようにしたらよいのでしょうか
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
こんにちは。
どこがどう詰んだのでしょうか?
何かエラーになるとか、思ったとおりの出力にならないとか情報が足り無すぎます。
ぱっと見ておかしいと思ったのはsrchNameもしくはsrchFNameの引数に文字列とコネクションがありますが、
呼び出し側でnullを渡しています。
これでcon.prepareStatement(sql);を実行したらNullpointerExceptionが発生します。
catch ( Exception e ) {
e.printStacktrace();
}
とすることで詳細なエラーを見ることが出来ます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Java java 入力 3 4 3 出力 ABC DEFG HIJ このようなプログラムの書き方を教えてくだ 2 2022/07/15 14:18
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C# DatagridviewにExcelシートを反映するとエラーが出る 2 2023/05/06 17:12
- Ruby 【JAVA】数字をひし形に出力するプログラムについて 2 2022/07/11 23:32
- Java java final 1 2022/06/10 22:49
- Ruby vscode 文字化け 1 2022/05/21 19:17
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Java JavaのSingletonパターンのprivateの持つ意味が分かりません。 5 2022/06/12 10:38
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
equalsの逆
-
九九を横に表示する。
-
BufferedReaderでのエラー
-
javaのfor文が機能してないみた...
-
Windowsでの標準入力の終了の仕方
-
Java int sum = 0は必要ですか?
-
テキストファイルから空白行をよむ
-
Javaのカウント方法について
-
yyyymmddからyyyy/mm/d...
-
InputStream.read()でタイムア...
-
入力文字列が数字かどうかの判別
-
Java 読み込んだテキストファイ...
-
ジャバスクリプトについて。
-
ボタンの複数割り当てについて
-
C言語のポインターに関する警告
-
[JAVA]try 内の変数を外で!?
-
ダブルクォーテーションのrepla...
-
1~100までの数字を表示し、か...
-
ループ処理の際、最後だけ","を...
-
System.err. printlnとSystem.o...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
yyyymmddからyyyy/mm/d...
-
csv出力について
-
equalsの逆
-
InputStream.read()でタイムア...
-
java連結
-
Javaでデータに登録する度にID...
-
ソケットを使ったサーバとクラ...
-
テキストファイルから空白行をよむ
-
JAVAでエラーがでる。
-
[JAVA]エラーが解決できません。
-
Java int sum = 0は必要ですか?
-
javaのfor文が機能してないみた...
-
Class.forNameでエラーになる
-
九九を横に表示する。
-
Inputstreamについて
-
Javaの質問です。テキストファ...
-
テキストファイルにおいて任意...
-
BufferedReaderでのエラー
-
Java FileDialog に関して
-
以下のJAVAプログラムでご質問...
おすすめ情報