【发布时间】:2010-12-25 22:59:08
【问题描述】:
我创建了一个名为 Manager 的类,我有一个名为 BirthList 的框架,这个框架有一个表。我使用 MySQL,我在 MySQL 的“birthtable”中输入了一些数据。我想将 MySQL 表中的这些数据添加到我框架中的表中。 提示:birthList 是 Birth 对象的列表。 但我会发现这个例外,为什么? 请帮帮我:(
经理类:
public Manager class{
Logger logger = Logger.getLogger(this.getClass().getName());
private static Connection conn = DBManager.getConnection();
private static Admin admin;
public static void addToBirthListFromMySQL() throws SQLException {
try{
Statement stmt = conn.createStatement();
ResultSet rs= stmt.executeQuery("SELECT * FROM birthtable");
Birth list1;
while (rs.next()) {
String s1 = rs.getString(2);
if (rs.wasNull()) {
s1 = null;
}
String s2 = rs.getString(3);
if (rs.wasNull()) {
s2 = null;
}
String s3 = rs.getString(4);
if (rs.wasNull()) {
s3 = null;
}
String s4 = rs.getString(5);
if (rs.wasNull()) {
s4 = null;
}
String s5 = rs.getString(6);
if (rs.wasNull()) {
s5 = null;
}
String s6 = rs.getString(7);
if (rs.wasNull()) {
s6 = null;
}
list1 = new Birth(s1, s2, s3, s4, s5, s6);
admin.birthList.add(list1);
}
}
catch(SQLException e){
}
}
我的框架:
public class BirthList extends javax.swing.JFrame {
private Admin admin;
/** Creates new form BirthList */
public BirthList(Admin admin) {
initComponents();
this.admin = admin;
try {
Manager.addToBirthListFromMySQL();
} catch (SQLException ex) {
Logger.getLogger(BirthList.class.getName()).log(Level.SEVERE, null, ex);
}
fillTable();
}
public void fillTable() {
String[] columNames = {"name", "family", "father's name", "mother's name", "date of birth", "place of birth"};
List<Birth> birth = admin.getBirthList();
Object[][] data = new Object[birth.size()][columNames.length];
for (int i = 0; i < data.length; i++) {
Birth birth1 = birth.get(i);
data[i][0] = birth1.getName();
data[i][1] = birth1.getFamily();
data[i][2] = birth1.getFatherName();
data[i][3] = birth1.getMotherName();
data[i][4] = birth1.getDateOfBirth();
data[i][5] = birth1.getPlaceOfBirth();
}
DefaultTableModel model = new DefaultTableModel(data, columNames);
jTable1.setModel(model);
}
public boolean isCellEditable(int row, int col) {
return true;
}
}
堆栈跟踪: 线程“AWT-EventQueue-0”中的异常 java.lang.NullPointerException 在 database.Manager.addToBirthListFromMySQL(Manager.java:272) 在 AdminGUI.BirthList.(BirthList.java:35) 在 AdminGUI.BirthFrame.newButton1ActionPerformed(BirthFrame.java:127) 在 AdminGUI.BirthFrame.access$000(BirthFrame.java:21) 在 AdminGUI.BirthFrame$1.actionPerformed(BirthFrame.java:58) 在 javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995) 在 javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318) 在 javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387) 在 javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242) 在 javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236) 在 java.awt.Component.processMouseEvent(Component.java:6038) 在 javax.swing.JComponent.processMouseEvent(JComponent.java:3265) 在 java.awt.Component.processEvent(Component.java:5803) 在 java.awt.Container.processEvent(Container.java:2058) 在 java.awt.Component.dispatchEventImpl(Component.java:4410) 在 java.awt.Container.dispatchEventImpl(Container.java:2116) 在 java.awt.Component.dispatchEvent(Component.java:4240) 在 java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322) 在 java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986) 在 java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916) 在 java.awt.Container.dispatchEventImpl(Container.java:2102) 在 java.awt.Window.dispatchEventImpl(Window.java:2429) 在 java.awt.Component.dispatchEvent(Component.java:4240) 在 java.awt.EventQueue.dispatchEvent(EventQueue.java:599) 在 java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:273) 在 java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:183) 在 java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:173) 在 java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168) 在 java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:160) 在 java.awt.EventDispatchThread.run(EventDispatchThread.java:121)
第 272 行是:admin.birthList.add(list1);
**我也调试了我的项目,结果是:
调试: 监听 javadebug 用户程序运行 调试器在无法编译的源代码上停止。
*我还使用 system.out.println(admin) 打印我的对象管理员,结果是:
classes.Admin@20be79*
【问题讨论】:
-
如果我们知道
Manager.java:272是哪一行会有所帮助。 -
Ash 是对的。 ps 而且您似乎不需要 list1 变量。你可以这样做: admin.birthList.add(new Birth(s1, s2, s3, s4, s5, s6));
-
在这种情况下,如果您能说出 Manager 类中的第 272 行会有所帮助。顺便说一句,addToBirthListFromMySQL() 中的 try /catch 块将屏蔽/丢弃任何抛出的 SQLException
-
第 272 行是“admin.birthList.add(list1);”
-
刚刚添加了
Manager.admin初始化步骤,以避免NPE。查看我完成的答案