Привет
Я хотел бы попросить помощи относительно добавления записей с использованием JComboBox в базу данных MySql. Дело в том, что у меня есть несколько таблиц в моей базе данных, и большинство из них находятся в отношениях.
Пример:
Таблица Employee_Details, она имеет 3 внешних ключа, которые находятся в другой таблице, такой как Position, Department и Office_Location. Теперь у этих внешних ключей есть значения типа данных INT, теперь проблема в том, что если я выберу одно из заданного значения символа в поле со списком и нажму «Сохранить», это выдаст мне ошибку, поскольку оно явно не соответствует назначенному типу данных в Таблица базы данных employee_details.
Вопрос:
Как я могу выбрать любые заданные символьные значения внутри комбинированного списка, и когда я нажимаю кнопку добавления или вставки, он сохраняет идентификатор этого значения вместо переменного символа.
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");
}
}
}