如何在JAVA Netbeans中使用JComboBox将记录ID代替Varchar插入MySql

时间:2019-06-08 18:26:43

标签: java mysql swing jcombobox

enter image description here enter image description here

嗨,

我想寻求有关使用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");
        }
    }

}                          

1 个答案:

答案 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());