###前提・実現したいこと
javaのswingを使用し、アプリケーションを作成しています。
パネル上に設置しているチェックボックスがすべてオフならば
SQLの検索条件から除外するようなコードを書きたいのですが、
方法がわからないです。
###該当のソースコード
sql = new StringBuilder();
sql.append(" select ");
sql.append(" T_SHAININFO.SHAIN_ID ");
sql.append(" ,T_SHAININFO.SHAIN_NAME ");
sql.append(" ,T_SHAININFO.SHAIN_KANA ");
・
・
・
とappendでSQL文を随時追加していく構成になっています。
そこで、画面上にあるチェックボック(1~6まで)がすべてオフならば
appendを使用し、SQLを追加する処理を抜けるよう条件分岐させたいです。
ただ最初の比較として、社員コード == 0 --tureならば処理を行わないといった処理にしたいと考えています。
わかりにくいとは思いますが、ご教授願います。
###ヘディングのテキスト
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答1件
0
ベストアンサー
質問内容の趣旨とは違うかもしれませんが、サンプルを書いてみました。
ボタンを押したときの処理について、以下のようなことをしたいのでしょうか。
lang
1import java.awt.FlowLayout; 2import java.awt.GridLayout; 3import java.sql.Connection; 4import java.sql.DriverManager; 5import java.sql.PreparedStatement; 6import java.sql.ResultSet; 7 8import javax.swing.JButton; 9import javax.swing.JCheckBox; 10import javax.swing.JFrame; 11import javax.swing.JPanel; 12import javax.swing.JTextField; 13 14public class Test { 15 16 public static void main(String[] args) { 17 18 // フレーム表示 19 JFrame frame = new JFrame("test"); 20 frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 21 frame.setSize(400, 400); 22 frame.getContentPane().setLayout(null); 23 frame.setLayout(new FlowLayout()); 24 25 // パネル 26 JPanel panel = new JPanel(); 27 panel.setLayout(new GridLayout(4, 2)); 28 frame.add(panel); 29 30 // チェックボックス定義 31 JCheckBox[] checkBoxs = new JCheckBox[3]; 32 checkBoxs[0] = new JCheckBox("社員ID"); 33 checkBoxs[1] = new JCheckBox("社員名"); 34 checkBoxs[2] = new JCheckBox("社員名カナ"); 35 36 // テキストフィールド定義 37 JTextField[] textFields = new JTextField[3]; 38 textFields[0] = new JTextField(10); 39 textFields[1] = new JTextField(10); 40 textFields[2] = new JTextField(10); 41 42 // 配置 43 panel.add(checkBoxs[0]); 44 panel.add(textFields[0]); 45 panel.add(checkBoxs[1]); 46 panel.add(textFields[1]); 47 panel.add(checkBoxs[2]); 48 panel.add(textFields[2]); 49 50 51 // ボタン 52 JButton button = new JButton("SQL発行"); 53 panel.add(button); 54 55 // アクション 56 button.addActionListener(event -> { 57 58 // ★★★質問内容の処理★★★ 59 if (!textFields[0].getText().equals("0")) { 60 // 社員コード == 0 --tureならば処理を行わない 61 StringBuilder sql = new StringBuilder(); 62 sql.append(" select "); 63 sql.append(" T_SHAININFO.SHAIN_ID "); 64 sql.append(" , T_SHAININFO.SHAIN_NAME "); 65 sql.append(" , T_SHAININFO.SHAIN_KANA "); 66 sql.append("FROM T_SHAININFO"); 67 if (checkBoxs[0].isSelected() || checkBoxs[1].isSelected() || checkBoxs[2].isSelected()) { 68 // 「画面上にあるチェックボック(1~6まで)がすべてオフ」以外 69 // sql追加処理 70 System.out.println("「画面上にあるチェックボック(1~6まで)がすべてオフ」以外"); 71 } 72 73 // sql発行 74 doSelect(sql.toString()); 75 } else { 76 System.out.println("SQL発行を中止しました。"); 77 } 78 79 }); 80 81 // 表示 82 frame.setVisible(true); 83 84 } 85 86 private static void doSelect(String sql){ 87 try (Connection connection = DriverManager.getConnection("jdbc:h2:~/test", "sa", "")) { 88 89 try (PreparedStatement ps = connection.prepareStatement(sql.toString())) { 90 91 try (ResultSet rs = ps.executeQuery()) { 92 System.out.println("-結果-"); 93 while (rs.next()) { 94 System.out.println(rs.getString(1)); 95 } 96 System.out.println("----"); 97 } 98 99 } catch (Exception e) { 100 e.printStackTrace(); 101 } 102 103 104 } catch (Exception e) { 105 e.printStackTrace(); 106 } 107 } 108 109} 110
投稿2016/09/15 06:56
総合スコア452
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。