Кнопка обновления в системе управления запасами не работает, MySQL, Netbeans - PullRequest
1 голос
/ 04 апреля 2019

Кнопка обновления в моей простой системе управления запасами не обновляет запас.При щелчке на нем отображается диалог обновления продукта, но ничего не происходит.Он не выдает ошибок, и я не могу найти проблему.

Это работало, когда у меня было только 5 строк, но когда я добавил строку категории и количества, он остановился.

private void btn_updateActionPerformed(java.awt.event.ActionEvent evt) {

        if(checkInputs() && txt_id.getText() != null)
        {
            String UpdateQuery = null;
            PreparedStatement ps = null;
            Connection con = getConnection();

            //update without image
            if(ImgPath == null)
            {
                try {
                    UpdateQuery = "UPDATE products SET name = ?, price = ?"
                            + ", add_date = ?, category = ?, quantity = ?, WHERE id = ?";
                    ps = con.prepareStatement(UpdateQuery);

                    ps.setString(1, txt_name.getText());
                    ps.setString(2, txt_price.getText());

                    SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
                    String addDate = dateFormat.format(txt_AddDate.getDate());

                    ps.setString(3, addDate);

                    ps.setInt(4, Integer.parseInt(txt_id.getText()));

                    String value = combo_category.getSelectedItem().toString();
                    ps.setString(5, value);

                    ps.setString(6, txt_quantity.getText());


                    ps.executeUpdate();
                    Show_Products_In_JTable();
                    JOptionPane.showMessageDialog(null, "Product Updated");

                } catch (SQLException ex) {
                    Logger.getLogger(Main_Window.class.getName()).log(Level.SEVERE, null, ex);
                }

            }
            //update with Image
            else{
                try{
                InputStream img = new FileInputStream(new File(ImgPath));

                UpdateQuery = "UPDATE products SET name = ?, price = ?"
                            + ", add_date = ?,image = ?, category = ?, quantity = ?, WHERE id = ?";

                    ps = con.prepareStatement(UpdateQuery);

                    ps.setString(1, txt_name.getText());
                    ps.setString(2, txt_price.getText());

                    SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
                    String addDate = dateFormat.format(txt_AddDate.getDate());

                    ps.setString(3, addDate);

                    ps.setBlob(4, img);

                    String value = combo_category.getSelectedItem().toString();
                    ps.setString(5, value);


                    ps.setInt(6, Integer.parseInt(txt_id.getText()));

                    ps.executeUpdate();
                    Show_Products_In_JTable();
                    JOptionPane.showMessageDialog(null, "Product Updated");

            }catch(Exception ex)      
            {
                    JOptionPane.showMessageDialog(null, ex.getMessage());
            }
        }
        }else{
            JOptionPane.showMessageDialog(null, "One or More Fields Are Empty Or Wrong");
        } 
    }

1 Ответ

0 голосов
/ 04 апреля 2019

с первого взгляда

quantity = ?, WHERE id = ?

должно быть

quantity = ? WHERE id = ?
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...