Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/331.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 更新密码无效_Java_Jdbc - Fatal编程技术网

Java 更新密码无效

Java 更新密码无效,java,jdbc,Java,Jdbc,我的更新密码查询不起作用。我不知道为什么。不显示错误报告 public class CpassDao extends ActionSupport { private static final long serialVersionUID = 1L; public static boolean validate(String username,String password,String npass) { boolean status = false;

我的更新密码查询不起作用。我不知道为什么。不显示错误报告

public class CpassDao extends ActionSupport {

    private static final long serialVersionUID = 1L;

    public static boolean validate(String username,String password,String npass) {
        boolean status = false;
        ChangePass cp = new ChangePass();

        try {
            Connection con = DBConnection.getConnection();
            PreparedStatement ps = con.prepareStatement("select * from doctable where username=? and password=?");

            ps.setString(1, username);
            ps.setString(2, password);

            ResultSet rs= ps.executeQuery();
            status = rs.next();

            if(true) {
                PreparedStatement ps1 = con.prepareStatement("update details set password=? where username=?");
                ps1.setString(1, cp.getNpass());
                ps1.setString(2, cp.getUsername());
                ps1.executeUpdate();
            }
        }

        catch (Exception ex) {
            ex.printStackTrace();

            return status;
        }

        return status;
    }
}

cp已创建,但您未能使用用户名或密码分配它,因此更新将在空usernme上进行


顺便问一下,您是否有
if(true)
哪些是不必要的?您是想使用
rs.hasNext()

我想您忘记了更新后的提交命令。:)

我找到了答案,问题也解决了。现在,数据库将使用新数据进行更新。在if语句之后,而不是给出
“ps1.setString(1,cp.getNpass());”我给出了“ps1.setString(1,npass());”。就这些。问题解决了。谢谢你的建议,朋友。

cp是如何由相关用户填充的?我无法让你弄清楚。我在“如果”条件下使用了cp。在status value的帮助下,我将值插入表中(将密码值更改为表中的密码值)cp.getUsername()返回什么?它返回我从表单中检索的用户名。所有进程都已成功,但未在表中更新。如果有任何更正,您可以这样做。