Java中的Java继承/重用能力

时间:2015-05-05 14:58:46

标签: java swing jdbc

package fisheriesdatabase;

import java.sql.*;
import java.awt.Container;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTextField;

public class FisheriesDatabase {

public static void main(String[] args) {
    JFrame frame=new JFrame("Fish Data Entry");
    frame.setSize(500,500);
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    JPanel panel=new JPanel();
    frame.add(panel);
    placeComponents(panel);

    frame.setVisible(true);
}

public static void placeComponents(JPanel panel){
    panel.setLayout(null);

    JLabel idlabel=new JLabel("id");
    idlabel.setBounds(10, 10, 80, 25);
    panel.add(idlabel);
    JTextField idtextfield=new JTextField(20);
    idtextfield.setBounds(100, 10, 160, 25);
    panel.add(idtextfield);

    JLabel namelabel=new JLabel("Name");
    namelabel.setBounds(10, 40, 80, 25);
    panel.add(namelabel);        
    JTextField nametextfield=new JTextField(20);
    nametextfield.setBounds(100, 40, 160, 25);
    panel.add(nametextfield);

    JButton button=new JButton("Enter Data");
    button.setBounds(10, 80, 80, 25);
    panel.add(button);

}

public static void connectDB() throws SQLException{
    final String url="jdbc:mysql://localhost:3306";
    final String driver="com.mysql.jdbc.Driver";
    final String dbName="netbeans_test";
    final String uname="root";
    final String pass="";

    Connection conn=null;
    try{
        //Registering the Driver
        Class.forName(driver).newInstance();

        //Open a connection
        conn=DriverManager.getConnection(url+dbName,uname,pass);
        Statement st=conn.createStatement();
        st.executeUpdate("insert into test values('"+idtextfield.getText()+"','"+nametextfield.getText()+"')");            

    }
    catch(ClassNotFoundException | InstantiationException | IllegalAccessException se){
        if(conn==null)
            System.err.println("DATABASE NOT CONNECTED");
        se.printStackTrace();
    }
}
}

上面提到的代码是我开始使用Swing,作为一个新手我只是想创建2个方法

  • 一个用于数据库连接
  • 其他的gui
    当我尝试访问connectDB()中的placeComponent()属性时出现错误。有人可以帮帮我吗?

错误发生在executeUpdate语句中,它无法识别' idtextfield'和' nametextfield'

谢谢!

3 个答案:

答案 0 :(得分:2)

我建议您从Swing tutorial的示例开始,了解如何更好地构建您的程序。

也许How to Use Labels上的部分是一个很好的简单示例。在此示例中,面板用于包含所有组件。这将允许您创建可以从面板类中实现的任何方法访问的实例变量。

从工作示例开始的其他好处:

  1. 你摆脱了静态方法。

  2. 它不使用setBounds()。 Swing旨在与布局管理器一起使用。请参阅布局管理器的教程部分。

  3. 代码将在EDT上创建。请参阅Concurrency上的教程部分。

答案 1 :(得分:0)

在班级声明/定义它们:

NSSliderCell

答案 2 :(得分:0)

您的计划中基本上存在一个问题。您使用的是placeComponentsconnectDB()两种方法。您已在idtextfield方法中声明并初始化变量nametextfieldplaceComponents(),并尝试从connectDB()方法访问它。变量的范围仅在方法placeComponents()中。因此,它给出的错误是无法识别' idtextfield'和' nametextfield'"。

您可以通过两种方式解决此问题。

  1. 您可以在课堂上声明它们。

  2. 您可以从JPanel实例获取实例。

  3. 同样在这方面,我想提请你注意另一件事。您已使用Statement使用用户输入的文本执行查询。 SQL注入的可能性很大。因此,如果您使用PreparedStatement代替它会更好。