java - 通过java更改mysql密码

标签 java mysql sql

我正在尝试使用 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/

相关文章:

java - @jsonview 在未知属性上失败

java - window 尺寸不匹配

java - 如果失败或不稳定,构建函数不会返回构建对象

javascript - 使用sequelize从两个模型表获取数据

mysql - 使用数组值分割逗号分隔的字符串

没有部分结果的 SQL 移动聚合 SUM

java - 减少查询执行次数

sql - 问号不可见

java - 意外的顶级异常 : com. android.dex.DexException:多个 dex 文件定义

mysql - 发票和任务表的参照完整性