1

我正在尝试使用 java 更改 mysql 上的用户密码,我在 phpmyadmin 上成功更改了它,但相同的命令在 java 上不起作用

SET PASSWORD = PASSWORD('12345')

这个命令将改变当前登录的用户,我在java上试过这样

statement = connect.createStatement();
statement.executeUpdate("SET PASSWORD = PASSWORD('12345')");

但什么也没发生

我也用root登录试过这个

statement = connect.createStatement();
statement.executeUpdate("SET PASSWORD FOR 'username'@'localhost' = PASSWORD('123456')");

没有任何工作,请提供任何帮助

4

1 回答 1

1

你不应该使用executeQuery()方法executeUpdate()

statement = connect.createStatement();
statement.executeQuery("SET PASSWORD FOR 'username'@'localhost' = PASSWORD('123456')");

请注意,使用上述查询只能更改已知密码。

例如,如果 root 密码example用于创建我们使用的连接

Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "example");

因此,使用此连接我们只能更改当前密码。

以下是基于roseindia.net 上此代码的示例

import java.sql.*;
class ChangeRootPassword
{
        public static void main(String[] args) 
        {
                try{
                        Class.forName("com.mysql.jdbc.Driver");
                        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "example");
                        String sql = "SET PASSWORD FOR 'root'@'localhost' = PASSWORD('test')";
                        Statement stmt = conn.createStatement();
                        stmt.executeQuery(sql);
                        stmt.close();
                        conn.close();
                        System.out.println("Password is changed successfully!");
                        }
                catch(Exception ex){
                        ex.printStackTrace();
                        }
        }
}

所以现在新的mysql root密码是test

于 2013-11-02T09:34:51.187 回答