我的代码存在问题让我很难过。我创建了一个Java应用程序来测试在postgresql中操作表中行的不同方法。我可以很好地连接到数据库,但是当我尝试更新表时出现问题。首先,这是我在执行查询select * from "testTable" order by "p_id" ASC;
后的postgresql中的表:
|name |age |p_id |salary
character integer integer character varying(10)
1 |Bob |25 |1 |20
2 |Mary |22 |2 |
3 |Abraham |55 |3 |22
4 |Ellen |31 |4 |
我想做的是给Mary和Ellen一份工资。我使用下面的Java代码尝试完成此任务:
import java.util.ArrayList;
import org.postgresql.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.Arrays;
import java.util.regex.*;
import java.io.IOException;
import java.sql.*;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.text.ParseException;
import java.util.Date;
import java.text.NumberFormat;
import java.text.DecimalFormat;
import java.util.*;
public class Test
{
public static void main(String[] args) throws IOException
{
{
String s1 = "";
String s2 = "";
String s3 = "";
String s4 = "";
try{
Connection conn = DriverManager.getConnection("jdbc:postgresql://localhost:5432/myapp5_development", "alex", "");
Statement myStmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
ResultSet myRs = myStmt.executeQuery("select \"salary\", \"p_id\" from \"testTable\" where \"salary\" is null order by p_id ASC");
int counter = 0;
String[] salaries = {"45", "17"};
while (myRs.next())
{
s3 = myRs.getString("p_id");
s4 = myRs.getString("salary");
System.out.println("ID: " + s3 +", salary: " + s4);
myRs.updateString("salary", salaries[counter] );
System.out.println(salaries[counter]);
System.out.println(counter);
counter++;
}
}
catch(Exception exc){
exc.printStackTrace();
}
}
}
}
“while”循环中的代码假设遍历表中“salary”值为null的每一行。然后使用“salaries”数组中的值填充null值。输出显示在循环中找到具有空薪水值的行,并且计数器相应地递增。 “薪水”数组中的相应值也是根据计数器的值找到的。但是,行本身未更新。我该怎么做才能让表格的行正确更新?以下是控制台的输出:
ID: 2, salary: null
45
0
ID: 4, salary: null
17
1
以下是发送相同SQL查询时的结果表:
|name |age |p_id |salary
character integer integer character varying(10)
1 |Bob |25 |1 |20
2 |Mary |22 |2 |
3 |Abraham |55 |3 |22
4 |Ellen |31 |4 |
答案 0 :(得分:1)
使用myRs.updateString("salary", salaries[counter] );
后,您应该使用updateRow()
更新行,如下所示:
myRs.updateString("salary", salaries[counter] );
myRs.updateRow();