我正在尝试使用 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')");
没有任何效果,请帮忙
最佳答案
你应该使用 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");
因此使用此连接我们只能更改当前密码。
下面是基于this code at 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
关于java - 通过java更改mysql密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19740603/