java - 将数据插入数据库 - o​​rg.h2.jdbc.JdbcSQLException : Column count does not match; SQL statement:

标签 java database h2

我一直在尝试将值保存到名为“CLIENT”的数据库中。

数据库是通过以下代码创建的:

package Database;

//STEP 1. Import required packages
import java.sql.*;

public class JDBCExampleCreateTables {
    // JDBC driver name and database URL
    private static String JDBC_DRIVER = "org.h2.Driver";
    private static String DB_URL = "jdbc:h2:file:C:/WAKILI/WAKILIdb";

    //  Database credentials
    private static String USER = "sa";
    private static String PASS = "";

    public static void main (String[] args) {
        Connection conn = null;
        Statement stmt = null;

        try {
            //STEP 2: Register JDBC driver
            Class.forName(JDBC_DRIVER);

            //STEP 3: Open a connection
            System.out.println("Connecting to a selected database...");
            conn = DriverManager.getConnection(DB_URL, USER, PASS);
            System.out.println("Connected database successfully...");

            //STEP 4: Execute a query
            System.out.println("Creating table in given database...");
            stmt = conn.createStatement();

            String sql = "CREATE TABLE CLIENT " +
                    "(ID INT UNSIGNED NOT NULL AUTO_INCREMENT, " + 
                    " fullNames VARCHAR(255), " + 
                    " iDNumber VARCHAR(255), " + 
                    " pINNumber VARCHAR(255), " + 
                    " passportNumber VARCHAR(255), " + 
                    " postOfficeBoxNumber VARCHAR(255), " + 
                    " postalCode VARCHAR(255), " + 
                    " telephoneNumberLandline VARCHAR(255), " + 
                    " telephoneNumberMobile VARCHAR(255), " + 
                    " CARD VARCHAR(255)) "; 

            stmt.executeUpdate(sql);
            System.out.println("Created table in given database...");

        } catch (SQLException se) {
            //Handle errors for JDBC
            se.printStackTrace();
        } catch (Exception e) {
            // Handle errors for Class.forName
            e.printStackTrace();
        } finally {
            // finally block used to close resources
            try {
                if (stmt!=null)
                    conn.close();
            } catch(SQLException se) {
            } // do nothing
            try {
                if (conn!=null)
                    conn.close();
            } catch (SQLException se) {
                se.printStackTrace();
            } // end finally try
        } // end try
        System.out.println("Goodbye!");
    } // end main
} // end

我试图保存到数据库中的类是:

package Database;

//STEP 1. Import required packages
import java.sql.*;

public class JDBCExampleInsertRecords {
    public final String values;
    public final String table;

    public JDBCExampleInsertRecords (String values, String table) 
    {
        this.values = values;
        this.table = table;
    }

    // JDBC driver name and database URL
    private static String JDBC_DRIVER = "org.h2.Driver";
    private static String DB_URL = "jdbc:h2:file:C:/WAKILI/WAKILIdb";

    //  Database credentials
    private static String USER = "sa";
    private static String PASS = "";

    public static void main () {
        Connection conn = null;
        Statement stmt = null;

        try {
            //STEP 2: Register JDBC driver
            Class.forName(getJDBC_DRIVER());

            //STEP 3: Open a connection
            System.out.println("Connecting to a selected database...");
            conn = DriverManager.getConnection(getDB_URL(), getUSER(), getPASS());
            System.out.println("Connected database successfully...");

            //STEP 4: Execute a query
            System.out.println("Inserting records into the table...");
            stmt = conn.createStatement();

            String sql = "INSERT INTO CLIENT " + "VALUES ((values))";
            stmt.executeUpdate(sql);

            System.out.println("Inserted records into the table...");

        } catch (SQLException se) {
            //Handle errors for JDBC
            se.printStackTrace();
        } catch (Exception e) {
            //Handle errors for Class.forName
            e.printStackTrace();
        } finally {
            //finally block used to close resources
            try {
                if (stmt != null)
                    conn.close();
            } catch (SQLException se) {
            } // do nothing
            try {
                if (conn!=null)
                    conn.close();
            } catch (SQLException se) {
                se.printStackTrace();
            } //end finally try
        } //end try

        System.out.println("Goodbye!");
    } //end main

    /**
     * @return the JDBC_DRIVER
     */
    public static String getJDBC_DRIVER() {
        return JDBC_DRIVER;
    }

    /**
     * @param aJDBC_DRIVER the JDBC_DRIVER to set
     */
    public static void setJDBC_DRIVER(String aJDBC_DRIVER) {
        JDBC_DRIVER = aJDBC_DRIVER;
    }

    /**
     * @return the DB_URL
     */
    public static String getDB_URL() {
        return DB_URL;
    }

    /**
     * @param aDB_URL the DB_URL to set
     */
    public static void setDB_URL(String aDB_URL) {
        DB_URL = aDB_URL;
    }

    /**
     * @return the USER
     */
    public static String getUSER() {
        return USER;
    }

    /**
     * @param aUSER the USER to set
     */
    public static void setUSER(String aUSER) {
        USER = aUSER;
    }

    /**
     * @return the PASS
     */
    public static String getPASS() {
        return PASS;
    }

    /**
     * @param aPASS the PASS to set
     */
    public static void setPASS(String aPASS) {
        PASS = aPASS;
    }
} //end

获取值的代码位于名为“AddNewClient”的类中,如下所示:

    public String getValues () {
    String fullNames = fullNamesJTextField.getText();
    String iDNumber = identificationNumberJTextField.getText();
    String pINNumber = pINNumberJTextField.getText();
    String passportNumber = passportNumberJTextField.getText();
    String postOfficeBoxNumber = postOfficeBoxNumberJTextField.getText();
    String postalCode = postalCodeJTextField.getText();
    String telephoneNumberLandline = telephoneNumberLandlineJTextField.getText();
    String telephoneNumberMobile = telephoneNumberMobileJTextField.getText();

    List<String> client = new ArrayList<String>();

    client.add(fullNames);
    client.add(iDNumber);
    client.add(pINNumber);
    client.add(passportNumber);
    client.add(postOfficeBoxNumber);
    client.add(postalCode);
    client.add(telephoneNumberLandline);
    client.add(telephoneNumberMobile);

    StringBuilder builder = new StringBuilder();
    String listStringClient = "";

    for (String s : client)
    {
        listStringClient += "NULL" + "'" + s + "'" + ",";
    }

    return listStringClient;
}

我收到一条错误消息:

run:
Connecting to a selected database...
Connected database successfully...
Inserting records into the table...
org.h2.jdbc.JdbcSQLException: Column count does not match; SQL statement:

过去两天我一直在做这件事,但没有取得任何成功。我将非常非常感谢任何愿意拯救我的人。谢谢。

最佳答案

这就是一个问题所在:

String sql = "INSERT INTO CLIENT " + "VALUES ((values))";
stmt.executeUpdate(sql);

Values 应该是 getValues() 方法,而不仅仅是一个字符串,所以

String sql = "INSERT INTO CLIENT VALUES (" + getValues() + ")";

此外,由于您没有指定哪些列,因此假定所有列都已输入到值中。如果 CARD 在您的 SQL 数据库中没有默认值,并且它不能为 NULL,那么您就会遇到问题。

最后,这有点奇怪:

for (String s : client)
{
    listStringClient += "NULL" + "'" + s + "'" + ",";
}

您需要的是值,而不是“NULL”,所以它应该是

for (String s : client)
{
    listStringClient += "'" + s + "'" + ",";
}

最后,按照您的做法,末尾会多一个逗号(例如:'value1','value2','value3',)

剪掉最后一个逗号:

return listStringClient.substring(0, listStringClient.size() - 1);

当然,有一种更好的方法来执行 for 循环,而无需使用额外的逗号。

结束了,sql字符串应该是这样的:

"INSERT INTO CLIENT VALUES('value1','value2','value3','value4','value5','value6')"

执行 System.out.println(sql) 并查看您要执行的 String 语句是什么。然后您就会看到错误。

这里有一个更好的方法来构建值字符串,而不会出现逗号问题:

Iterator<String> iter = client.iterator();
StringBuilder sb = new StringBuilder();

while (iter.hasNext()) {
    sb.append("'").append(iter.next()).append("'");
    if (iter.hasNext())
        sb.append(",");
}
return sb.toString();

关于java - 将数据插入数据库 - o​​rg.h2.jdbc.JdbcSQLException : Column count does not match; SQL statement:,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18371781/

相关文章:

java - 如何在我的 java 项目中存储数据库密码和用户名?

sql - SQL Server:在多列上添加外键

grails - 如何覆盖 Grails GORM 中关系的级联删除?

Java:使用引导类路径阻止找到 H2 驱动程序

java - H2 嵌入模式 - DELETE 命令给出 COLUMN NOT FOUND 错误

java - Spring Batch 中 map 的项目阅读器?

java - Java 骰子游戏分配的困难

java - 关于 Spring @Autowired 和 Spring JDBC 的问题

mysql - Rails 4 使用不同的数据库和不同的表

php - 另一个小错误(可能很明显)