尝试使用netbeans输入数据时出现SQL错误

时间:2013-05-15 13:58:23

标签: java mysql

首先,我会给出我正在处理的代码。

“保存”按钮的操作代码。

    private void saveBtActionPerformed(java.awt.event.ActionEvent evt) {                                       
    try {
        Production production=new Production(batchNoValueLabel.getText(), productIDCombo.getSelectedItem(), rawMaterialUsedCombo.getSelectedItem(), dateValueLabel.getText(), rawMaterialBatchCombo.getSelectedItem(), weightInitialSpinner.getValue(), beforeWeightSpinner.getValue(), afterWeightSpinner.getValue(), finalWeightSpinner.getValue(), packingWeightSpinner.getValue(), noOfUnitSpinner.getValue(), wastageSpinner.getValue());
        int res=ProductionController.addBatch(production);
            if(res==1){
                JOptionPane.showMessageDialog(this, "New Batch Added!");
                String nextid = IDGeneration.getNextid("B", "production", "productionBatchID");
                batchNoValueLabel.setText(nextid);  
                productIDCombo.removeAllItems();
                ArrayList<String> getProductsDetails = ProductsController.getProductID();
                for (String detail : getProductsDetails) {
                    productIDCombo.addItem(detail);
                }                    
            }else{
                JOptionPane.showMessageDialog(this, "New Product Adding Failed!");
            }
    } catch (ClassNotFoundException | SQLException ex) {
        Logger.getLogger(ProductsForm.class.getName()).log(Level.SEVERE, null, ex);
    }
}

然后,模型类。 (Getters和Setters在那里,没有粘贴在这里)

    public Production(String productionBatchID, Object finishedMaterialID, Object rawMaterialID, String productionDate, Object rawMatBatchID, Object initialWeight, Object beforeWeight, Object afterWeight, Object finalWeight, Object packingWeight, Object noOfUnits, Object wastage) {
    this.productionBatchID = productionBatchID;
    this.finishedMaterialID = (String) finishedMaterialID;
    this.rawMaterialID = (String) rawMaterialID;
    this.productionDate = productionDate;
    this.rawMatBatchID = (String) rawMatBatchID;
    this.initialWeight = (int) initialWeight;
    this.beforeWeight = (int) beforeWeight;
    this.afterWeight = (int) afterWeight;
    this.finalWeight = (int) finalWeight;
    this.packingWeight = (int) packingWeight;
    this.noOfUnits = (int) noOfUnits;
    this.wastage = (int) wastage;
}

最后是控制器类。

public class ProductionController {

public static int addBatch(Production production) throws ClassNotFoundException, SQLException {
    Connection conn=DBConnection.getConnection();
    Statement stm=conn.createStatement();
    String sql="insert into production (productionBatchID, finishedMaterialID, rawMaterialID, productionDate, rawMatBatchID, initialWeight, beforeWeight, finalWeight, packingWeight, noOfUnits, wastage) values ('"+production.getProductionBatchID()+"','"+production.getFinishedMaterialID()+"','"+production.getRawMaterialID()+"','"+production.getProductionDate()+"','"+production.getRawMatBatchID()+"','"+production.getInitialWeight()+"','"+production.getBeforeWeight()+"','"+production.getAfterWeight()+"','"+production.getFinalWeight()+"','"+production.getPackingWeight()+"','"+production.getNoOfUnits()+"','"+production.getWastage()+"');";
    int rowCount=stm.executeUpdate(sql);
    return rowCount;
}

}

然而,当我在GUI中输入数据并尝试将数据发送到数据库时,它会发出“java.sql.SQLException:列计数与第1行的值计数不匹配”错误。怎么解决这个?哦,这是MySQL表:

create table production(productionBatchID VARCHAR(4) NOT NULL,finishedMaterialID VARCHAR(4) NOT NULL,rawMaterialID VARCHAR(4) NOT NULL,productionDate VARCHAR(15),rawMatBatchID VARCHAR(4),initialWeight INT(5),beforeWeight INT(5),afterWeight INT(5),finalWeight INT(5),packingWeight INT(5),noOfUnits INT(5),wastage INT(5),CONSTRAINT PRIMARY KEY (productionBatchID))ENGINE=INNODB;

如何解决这个问题?

2 个答案:

答案 0 :(得分:1)

您的VALUES子句有

'"+production.getAfterWeight()+"','"+production.getFinalWeight()+

但你只在列表中有finalWeight。

错误告诉你这个

insert into production (
    productionBatchID, finishedMaterialID, 
    rawMaterialID, productionDate, 
    rawMatBatchID, initialWeight, 
    beforeWeight, finalWeight, 
    packingWeight, noOfUnits, 
    wastage)
values (
    '"+production.getProductionBatchID()+"','"+production.getFinishedMaterialID()+"','"+
    production.getRawMaterialID()+"','"+production.getProductionDate()+"','"+
    production.getRawMatBatchID()+"','"+production.getInitialWeight()+"','"+
    production.getBeforeWeight()+"','"+
                   production.getAfterWeight()+"','"+
                             production.getFinalWeight()+"','"+  there are 3 here
    production.getPackingWeight()+"','"+production.getNoOfUnits()+"','"+
    production.getWastage()+"');";

另外,请参数化您的查询以减轻SQL注入风险

答案 1 :(得分:0)

您在INSERT查询中使用的列数不匹配,'beforeWeight'是列,其值缺失,下面是更正的查询:

String sql="insert into production (productionBatchID, finishedMaterialID, rawMaterialID, productionDate, rawMatBatchID, initialWeight, **beforeWeight**, finalWeight, packingWeight, noOfUnits, wastage) values ('"+production.getProductionBatchID()+"','"+production.getFinishedMaterialID()+"','"+production.getRawMaterialID()+"','"+production.getProductionDate()+"','"+production.getRawMatBatchID()+"','"+production.getInitialWeight()+"','"+production.getBeforeWeight()+"','"+production.getAfterWeight()+"','"+production.getBeforeWeight()+"','"+production.getFinalWeight()+"','"+production.getPackingWeight()+"','"+production.getNoOfUnits()+"','"+production.getWastage()+"');";