为什么我的Java程序没有更新关联的postgresql表?

时间:2015-08-04 11:01:43

标签: java postgresql sql-update row

我的代码存在问题让我很难过。我创建了一个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       |

1 个答案:

答案 0 :(得分:1)

使用myRs.updateString("salary", salaries[counter] );后,您应该使用updateRow()更新行,如下所示:

myRs.updateString("salary", salaries[counter] );
myRs.updateRow();