MySQL的连接断开

本文介绍如何连接和断开MYSQL数据库,包括本地和远程连接的方法。此外还提供了修改密码及增加新用户的步骤,帮助读者掌握基本的数据库管理技能。


一、MYSQL数据库的连接

格式:mysql -h 主机地址 -u 用户名 -p

1.例1:连接到本机上的MYSQL。
首先在打开 DOS 窗口,然后进入目录 mysqlbin,再键入命令mysql -uroot -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root 是没有密码的,故直接回车即可进入到 MySQL 中了,MySQL 的提示符是:mysql>
2.例2:连接到远程主机上的MYSQL。假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:
mysql -h110.110.110.110 -uroot -pabcd123
(注:u与root可以不用加空格,其它也一样)

二、MYSQL数据库的断开

格式: exit 、quit

注意:想要成功连接到远程主机,需要在远程主机打开MySQL远程访问权限
方法如下:
在远程主机中以管理员身份进入,输入如下命令
mysql>GRANT ALL PRIVILEGES ON *.* TO 'agui'@%'IDENTIFIEDBY '123' WITH GRANT OPTION;
FLUSH PRIVILEGES;
//赋予任何主机访问数据的权限
mysql>FLUSH PRIVILEGES
//修改生效
agui为我们使用的用户名
密码为 123
即:在远程主机上作好设置,我们即可通过mysql -h110.110.110.110 -uagui -p123连接进远程主机

三、修改密码

格式:mysqladmin -u用户名 -p旧密码 password 新密码

1.例1:给root加个密码ab12。首先在DOS下进入目录mysqlbin,然后键入以下命令

mysqladmin -uroot -password ab12

注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。
2.例2:再将root的密码改为djg345。
mysqladmin -uroot -pab12 password djg345

四、增加新用户

格式:grant select on 数据库.* to 用户名@登录主机 identified by “密码”;

(注意:和上面不同,下面的因为是 MySQL 环境中的命令,所以后面都带一个分号作为命令结束符)
例1、增加一个用户 test1 密码为 abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以 root 用户连入 MySQL,然后键入以下命令:

grant select,insert,update,delete on *.* to test1@“%” Identified by “abc”;
但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。

例2、增加一个用户 test2 密码为 abc,让他只可以在 localhost 上登录,并可以对数据库 mydb 进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。

grant select, insert, update, delete on mydb.* to test2@localhost identified by “abc”;

如果你不想 test2 有密码,可以再打一个命令将密码消掉。
grant select, insert, update, delete on mydb.* to test2@localhost identified by “”;









在程序中添加MySQL连接的重连机制,可以通过以下步骤实现: 1. **捕获异常**:在每次进行数据库操作时,捕获SQLException异常。 2. **重试机制**:在捕获到异常后,进行重试。可以设置一个最大重试次数,超过最大重试次数后,程序可以选择退出或进行其他处理。 3. **重连逻辑**:在重试过程中,重新建立数据库连接。 以下是一个示例代码,展示了如何在Java中实现MySQL连接的重连机制: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class MySQLReconnect { private static final String URL = "jdbc:mysql://localhost:3306/your_database"; private static final String USER = "your_username"; private static final String PASSWORD = "your_password"; private static final int MAX_RETRIES = 3; public static Connection getConnection() throws SQLException { int retries = 0; while (true) { try { return DriverManager.getConnection(URL, USER, PASSWORD); } catch (SQLException e) { retries++; if (retries >= MAX_RETRIES) { throw e; } System.out.println("Connection failed. Retrying... (" + retries + "/" + MAX_RETRIES + ")"); try { Thread.sleep(1000); // Wait for 1 second before retrying } catch (InterruptedException ie) { Thread.currentThread().interrupt(); throw new SQLException("Thread interrupted while waiting to retry", ie); } } } } public static void main(String[] args) { try { Connection connection = getConnection(); System.out.println("Connected to the database successfully!"); // Perform database operations here } catch (SQLException e) { System.err.println("Failed to connect to the database after multiple attempts."); e.printStackTrace(); } } } ``` 在这个示例中,`getConnection`方法尝试建立数据库连接,并在连接失败时进行重试。如果重试次数达到最大重试次数(`MAX_RETRIES`),则抛出异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值