当我使用带有数据库连接的 if...else... 语句时,它不会正确设置图标。
这是具有其值的数据库:
JFrame 上有两个标签,专门用于图标。现在只关注其中一个标签,因为它们的功能相同。
发生的情况是,当提取记录时,“MSGTYPE”列之一包含“INFORMATION”、“ANNOUNCEMENT”、“AWARD”或“WARNING”。JLabel 的图标必须与图像与消息的类型相匹配,例如。如果当前记录是公告,图标需要是“公告”图标。发生了什么,是我使用 if...else... 语句,但它默认为 else 语句。请参阅下面的代码。
try {
String sql = "Select * from app.EBULLETINS ORDER BY msgid DESC FETCH FIRST 2 ROWS ONLY";
Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
Class.forName("org.apache.derby.jdbc.ClientDriver");
Connection con = (Connection) DriverManager.getConnection("jdbc:derby://localhost:1527/GTPADB", "some#uSERn@me, "some#P@$$w0rd");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(sql);
if (rs.next()) {
eBul1_Title = rs.getString("Title");
eBul1_Msg = rs.getString("Msg");
eBul1_Type = rs.getString("MSGTYPE");
}
eBul1T.setText(eBul1_Title + "/" + eBul1_Type);
eBul1M.setText(eBul1_Msg);
System.out.println("Setting Icons");
if (eBul1_Type == "INFORMATION") {
TypeImage1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/Information.png")));
System.out.println("Info");
}
else if (eBul1_Type == "ANNOUNCEMENT") {
TypeImage1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/announcement.png")));
System.out.println("Announce");
}
else if (eBul1_Type == "WARNING") {
TypeImage1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/Warning.png")));
System.out.println("Warning");
}
else if (eBul1_Type == "AWARD") {
TypeImage1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/award.png")));
System.out.println("Award");
}
else {
TypeImage1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/Information.png")));
System.out.println("Other");
}
}
catch (Exception eB1Exc) {
JOptionPane.showMessageDialog(this, eB1Exc);
}
运行时,这会输出以下 printlns:
1. Setting Icons
2. Other
3. Other
JFrame 也是这样显示的:(忽略不显示的字段)
*您会注意到公告与信息具有相同的图标*