嗨,
我想寻求有关使用JComboBox向MySql数据库添加条目的帮助。关键是,我的数据库中有多个表,其中大多数处于关系中。
示例:
Employee_Details表,它具有3个外键,这些外键来自另一个表,例如Position,Department和Office_Location。现在这些外键的数据类型值为INT,现在的问题是,如果我在组合框中选择给定字符值之一,然后单击保存,它将给我一个错误,因为它显然与指定的数据类型不匹配。 employee_details数据库表。
问题:
如何在组合框中选择任何给定的字符值,当我单击“添加”或“插入”按钮时,它将保存该值的ID而不是可变字符。
private void Position(){ // Position Combo Box
try {
String sqlPosition = "Select * From positions";
pst = con.prepareStatement(sqlPosition);
rs = pst.executeQuery();
while(rs.next()){
JCB_Position.addItem(rs.getString("Position"));
}
} catch (SQLException e) {
JOptionPane.showMessageDialog(null, e);
}
}
private boolean CheckInputs(){
if(jTextFieldFname.getText() != null || jTextFieldLname.getText() !=null || JCB_Department.getSelectedItem() != null
|| JCB_Location.getSelectedItem() != null
|| JCB_Location.getSelectedItem() != null
|| JCB_EmpStat.getSelectedItem() !=null
)
{
return true;
}
return false;
}
private void jButtonAddEmpActionPerformed(java.awt.event.ActionEvent evt) {
int InsertToDB = JOptionPane.showConfirmDialog(null, "Do you want to save this entry?", "SAVE",JOptionPane.YES_NO_OPTION);
if (InsertToDB == 0)
{
String Gender = null;
if(JRB_Male.isSelected())
{
Gender = "Male";
}
else if(JRB_Female.isSelected())
{
Gender = "Female";
}
jTextFieldFname.getText();
jTextFieldLname.getText();
jTextFieldOfficeNumber.getText();
jTextFieldMobNumber.getText();
jTextFieldEmailAdd.getText();
jTextAreaRemarks.getText();
String Position = JCB_Position.getSelectedItem().toString();
//String Dept = JCB_Department.getSelectedItem().toString();
//String Loc = JCB_Location.getSelectedItem().toString();
//String Status = JCB_EmpStat.getSelectedItem().toString();
if(CheckInputs() != false)
{
try {
pst = con.prepareStatement("INSERT INTO employee_details (First_Name, Last_Name, Gender, "
+ "Office_Number, Mobile_Number, Email_Address, Remarks)"
+ "VALUES (?,?,?,?,?,?,?)");
pst.setString(1, jTextFieldFname.getText());
pst.setString(2, jTextFieldLname.getText());
pst.setString(3, Gender);
//pst.setInt(4, Position);
//pst.setString(5, Dept);
//pst.setString(6, Loc);
//pst.setString(7, Status);
pst.setString(4, jTextFieldOfficeNumber.getText());
pst.setString(5, jTextFieldMobNumber.getText());
pst.setString(6, jTextFieldEmailAdd.getText());
pst.setString(7, jTextAreaRemarks.getText());
pst.executeUpdate();
JOptionPane.showMessageDialog(null, "Succesfully Saved");
} catch (SQLException ex) {
Logger.getLogger(Employee_Details.class.getName()).log(Level.SEVERE, null, ex);
}
}
else{
JOptionPane.showMessageDialog(null, "Check the mandatory fields");
}
}
}
答案 0 :(得分:0)
当前,您正在将字符串添加到JComboBox中,因此与ID的关联不再存在。
您可以创建一个包装类,如下所示:
public class PositionWrapper {
private int id;
private String position;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getPosition() {
return position;
}
public void setPosition(String position) {
this.position = position;
}
@Override
public String toString() {
return position;
}
}
像这样将其添加到您的JComboBox中:
while(rs.next()){
PositionWrapper position = new PositionWrapper();
position.setId(rs.getInt("Position_ID"));
position.setPosition(rs.getString("Position"));
JCB_Position.addItem(position);
}
JComboBox将使用toString()
的{{1}}方法作为内容,但是现在使用PositionWrapper
将返回一个JCB_Position.getSelectedItem()
。
现在只需从那里获取ID:
PositionWrapper
如果您的JComboBox是可编辑的,则需要首先检查返回的对象的类型,否则可能会收到异常。
您需要将JComboBox的类型调整为pst.setInt(0, ((PositionWrapper)JCB_Position.getSelectedItem()).getId());
。