Java 如何从SQL数据库中读取记录,然后将其显示在JFrame上?

Java 如何从SQL数据库中读取记录,然后将其显示在JFrame上?,java,mysql,sql,Java,Mysql,Sql,我已经想了一段时间了,但我仍然不知道该怎么做,所以我希望你们中的一些人能帮我:) 以下是我的连接代码: public class Conn { private Connection conn = null; public Connection getConn() throws ClassNotFoundException { try { Class.forName("com.mysql.jdbc.Driver"); conn = (Connection) DriverMa

我已经想了一段时间了,但我仍然不知道该怎么做,所以我希望你们中的一些人能帮我:)

以下是我的连接代码:

public class Conn {
private Connection conn = null;


public Connection getConn() throws ClassNotFoundException {
  try {
    Class.forName("com.mysql.jdbc.Driver");
    conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/bloodbank","root","");
    } catch(SQLException e) {
      System.out.println(e);
    }
    return conn;
  }
}
下面是我的代码,用于读取并尝试显示它:

public void read() throws ClassNotFoundException, SQLException {
  readForm r = new readForm();
  PreparedStatement st;
  Connection con = getConn();
  ResultSet rs;

  String query = "SELECT * FROM patients";
  try {
    st = con.prepareStatement(query);
    rs = st.executeQuery();
    DefaultTableModel tm = (DefaultTableModel)r.table.getModel();
    tm.setRowCount(0);
    Object row[] = new Object[5];
    for(Patients u : list){
      row[0] = u.getId();
      row[1] = u.getfName();
      row[2] = u.getlName();
      row[3] = u.getGender();
      row[4] = u.getAge();
      tm.addRow(row);
    }
    r.setVisible(true);
  } catch (SQLException e) {
     System.out.println(e);
  }            
}

在我的readForm类中,没有代码,只有设计,我正试图从另一个类插入到该表中

您不需要select查询的预处理语句,只需要insert查询,而需要create语句。此外,rs是不包含在for循环中的结果集,您使用的是未初始化的列表实例

public void read() throws ClassNotFoundException, SQLException {
  Connection con = getConn();
  ResultSet rs;
  String query = "SELECT * FROM patients";
  try {
    stmt = con.createStatement();
    rs = stmt.executeQuery(query);
    DefaultTableModel tm = (DefaultTableModel)r.table.getModel();
    tm.setRowCount(0);
    String[] values = new String[5];
    //give data of the table line by line, replace tbl column with your column names
    while(rs.next()) {
      values[0] = rs.getString("tbl_column");
      values[1] = rs.getString("tbl_column");
      values[2] = rs.getString("tbl_column");
      values[3] = rs.getString("tbl_column");
      values[4] = rs.getString("tbl_column");
      tm.addRow(values);
    }
    r.setVisible(true);
  } catch (SQLException e) {
    System.out.println(e);
  }            
}

对于选择命令,您需要一条语句和一个结果集,例如:

try {
  st=conn.createStatement();
  String qry="select * from current_login";
  rst=st.executeQuery(qry);
  if(rst.next()) {
    u_name=rst.getString("username");
    password=rst.getString("password");
  }
  String qry1="select * from sign_up where username='"+u_name+"' and password= '"+password+"'";
  rst1=st.executeQuery(qry1);
  if(rst1.next()) {
    name=rst1.getString("name");
    cat=rst1.getString("game_category");
  }
代码的其余部分是正确的