我将该函数转换为流动的应用程序 应用程序使用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();
答案 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();
}