java将数据插入Mysql数据库

时间:2016-05-06 01:20:24

标签: java mysql

我将该函数转换为流动的应用程序 应用程序使用PreparedStatement pstmt来插入二维的String数组,当我启动它时,问题就像照片一样出现

import java.sql.PreparedStatement;

public static void main(String[] args){

java.sql.Connection conn = java.sql.DriverManager.getConnection(
        url, user, password);

要写入数据库的String数组。

String[][] sheetContent={{"100007"," 钢笔", "200", "xxx"},{"100020", "鞋子","700", "AAA"}};
int rows=2;
int columns = 4;
String sql = "INSERT INTO product(编号,商品名,单价,提供商) VALUES(?,?,?,?)";
PreparedStatement pstmt = conn.prepareStatement(sql); 
        for(int r=0;r<rows;r++){
            for(int c=0;c<columns;c++){
                pstmt.setString(c, sheetContent[r][c]);
            }
        }
pstmt.executeUpdate();

enter image description here

3 个答案:

答案 0 :(得分:1)

您需要聪明地使用列索引:

PreparedStatement pstmt = conn.prepareStatement(sql); 
for (int r=0; r < rows; r++) {
    for (int c=0; c < columns; c++) {
        int index = 1 + (r * columns) + c;
        pstmt.setString(index, sheetContent[r][c]);
    }
}
pstmt.executeUpdate();

答案 1 :(得分:1)

你应该从1开始prepareStatement的索引, 你正在做的是从0开始。

index =必须以索引整数1开始。

pstmt.setString(index,sheetContent [r] [c]);

示例:pstmt.setString(1,sheetContent [r] [c]); pstmt.setString(2,sheetContent [r] [c]);

答案 2 :(得分:-1)

问题已经解决。只需将代码更改为以下

for (int r=0; r < rows; r++) {
    for (int c=0; c < columns; c++) {
        int index = 1 +  c;
        pstmt.setString(index, sheetContent[r][c]);
    }
pstmt.executeUpdate();
}