0

私は Java にかなり慣れていないので、JList にデータベースのデータを入力しようとしています。データは、Database クラスのメソッド visKunder() を介してデータベースから取得されます。

public ArrayList<Kunde> visKunder(){
    String s1 = "select kundenavn, adresse, telefon from kunde";
    Statement setning = null;
    String kundenavn = null;
    String adresse = null;
    int telefon = 0;
    ResultSet res = null;
    ArrayList<Kunde> kunder = new ArrayList<>();
    try{
        forbindelse.setAutoCommit(false);
        setning = forbindelse.createStatement();
        res = setning.executeQuery(s1);
        while(res.next()){
            kundenavn = res.getString("kundenavn");
            adresse = res.getString("adresse");
            telefon = res.getInt("telefon");
            Kunde kunde = new Kunde(kundenavn, telefon, adresse);
            kunder.add(kunde);
        }
        forbindelse.commit();
    }catch(SQLException error){
        Opprydder.rullTilbake(forbindelse);
        Opprydder.skrivMelding(error, "visKunder()");
    }finally{
        Opprydder.lukkSetning(setning);
        Opprydder.lukkResSet(res);
        try {
            forbindelse.setAutoCommit(true);
        } catch (SQLException ex) {
            Opprydder.skrivMelding(ex, "setAutoCommit()");
        }
    }
    return kunder;

}

この問題は、GUI クラス RegVedKjøp で visKunder() を呼び出すと発生します。printStackTrace() は、NullPointerException の問題として visKunder() をリストします。

public class RegVedKjøp extends javax.swing.JFrame {
private static Database d1;

public RegVedKjøp(Database d1) {
    initComponents();
    this.d1 = d1;
}
private void initComponents(){
    ...
    JList jList2 = new JList();
    fyllListe(jList2);
    ...
}
private void fyllListe(JList list){
   ArrayList<Kunde> kunder = d1.visKunder(); 
   list = new JList(kunder.toArray());
}

関連するかどうかはわかりませんが、NetBeans の GUI ビルダーを使用して GUI を設計しました。この問題を解決するためのヒントをいただければ幸いです。

編集:

    private void initComponents() {

    scrollbar1 = new java.awt.Scrollbar();
    lagreKnapp = new javax.swing.JButton();
    tKnapp = new javax.swing.JButton();
    label1 = new java.awt.Label();
    jLabel2 = new javax.swing.JLabel();
    txtType = new javax.swing.JTextField();
    jLabel1 = new javax.swing.JLabel();
    txtAntall = new javax.swing.JTextField();
    jLabel3 = new javax.swing.JLabel();
    txtPris = new javax.swing.JTextField();
    jLabel4 = new javax.swing.JLabel();
    jButton1 = new javax.swing.JButton();
    jScrollPane2 = new javax.swing.JScrollPane();
    jList2 = new JList();

    setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
    setTitle("Registrer kjøp av ved - Dagsverket");
    setAlwaysOnTop(true);
    setResizable(false);

    lagreKnapp.setFont(new java.awt.Font("sansserif", 0, 14)); // NOI18N
    lagreKnapp.setText("Lagre");
    lagreKnapp.setPreferredSize(new java.awt.Dimension(95, 50));
    lagreKnapp.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            lagreKnappActionPerformed(evt);
        }
    });

    tKnapp.setFont(new java.awt.Font("sansserif", 0, 14)); // NOI18N
    tKnapp.setText("Tilbake");
    tKnapp.setPreferredSize(new java.awt.Dimension(75, 30));
    tKnapp.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            tKnappActionPerformed(evt);
        }
    });

    label1.setText("label1");

    jLabel2.setFont(new java.awt.Font("sansserif", 1, 14)); // NOI18N
    jLabel2.setText("Vedtype:");
    jLabel2.setFocusable(false);
    jLabel2.setPreferredSize(new java.awt.Dimension(70, 25));

    jLabel1.setFont(new java.awt.Font("sansserif", 1, 14)); // NOI18N
    jLabel1.setText("Antall sekker:");
    jLabel1.setFocusable(false);
    jLabel1.setName(""); // NOI18N
    jLabel1.setPreferredSize(new java.awt.Dimension(70, 25));

    jLabel3.setFont(new java.awt.Font("sansserif", 1, 14)); // NOI18N
    jLabel3.setText("Pris pr/sekk:");

    jLabel4.setFont(new java.awt.Font("SansSerif", 1, 14)); // NOI18N
    jLabel4.setText("Kunde:");

    jButton1.setFont(new java.awt.Font("SansSerif", 0, 14)); // NOI18N
    jButton1.setText("Registrer Ny Kunde");
    jButton1.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            jButton1ActionPerformed(evt);
        }
    });

このコードは、GUI ビルダーによって生成されます。また、このクラスは、GUI の表示に役立ついくつかのクラスの 1 つであることも述べておく必要があります。すべてのクラスは、ユーザーが要求した 1 つの操作を担当します。それらはすべて、プログラム全体を実行するクラス System で使用される Mainpage と呼ばれるクラスに収集されます。システムで最初に行われるのは、データベース オブジェクトの作成とデータベースへの接続です。この Database オブジェクトは、すべての GUI クラスでパラメータとして使用されます。

4

2 に答える 2

0

d1は明らかにnull。なんで?コンストラクターでフィールドを初期化する前に、メソッドfyllListe()でメソッドを呼び出すため、順序を変更してください。適切なコンストラクターは次のとおりです。initComponents()d1

public RegVedKjøp(Database d1) {
    this.d1 = d1;
    initComponents();
}
于 2014-04-09T12:05:39.363 に答える
0

あなたが書いたものから。最も可能性の高い原因は、d1 が null であることです。RegVedKjøp が作成されているとき。次に、データベース d1 はクラスに対して null です。

私があなたなら。データベース d1 が null かどうかをデバッグして確認します。ただし、スタックトレースを追加していないため、正確に言うのは困難です。メソッド visKunde 内にいくつかの変数があり、これも null になる可能性があります。それらはメソッドの外で作成されるためです。

于 2014-04-09T11:19:21.823 に答える