当前位置: 首页 > news >正文

常用Mysql命令

前言

本文列举了一些常见的mysql操作

正文

一、连接和登录 MySQL

1. 使用命令行登录 MySQL

注意:需要将mysql的bin目录导入到环境变量中

mysql -u 用户名 -p

示例:

mysql -u root -p

执行上述命令后,系统会提示输入密码,输入正确的密码即可登录到 MySQL 控制台。
如果密码忘记则可以直接跳到六

2. 指定主机和端口登录

mysql -u 用户名 -p -h 主机地址 -P 端口号

示例:

mysql -u root -p -h localhost -P 3306

二、查看 MySQL 用户

1. 查看所有用户

登录到 MySQL 后,执行以下 SQL 语句查看所有用户:

SELECT User, Host FROM mysql.user;

说明:

  • User 列显示用户名。
  • Host 列显示用户可以从哪些主机连接。

2. 查看用户及其权限

SHOW GRANTS FOR '用户名'@'主机';

示例:

SHOW GRANTS FOR 'root'@'localhost';

三、创建和删除用户

1. 创建新用户

CREATE USER '用户名'@'主机' IDENTIFIED BY '密码';

示例:

CREATE USER 'testuser'@'localhost' IDENTIFIED BY 'Test@1234';

说明:

  • '用户名':新用户的名称。
  • '主机':指定用户可以从哪些主机连接,'localhost'表示只能从本地主机连接,'%'表示可以从任何主机连接。
  • '密码':为用户设置的密码。

2. 删除用户

DROP USER '用户名'@'主机';

示例:

DROP USER 'testuser'@'localhost';

四、修改用户密码

在 MySQL 8.0 之前和之后,修改用户密码的方式有所不同。以下是两种不同版本中的密码修改方法:

MySQL 8.0 之前

在 MySQL 8.0 之前,使用 SET PASSWORD 命令或 UPDATE 命令来修改用户密码。常见的方式如下:

  1. 使用 SET PASSWORD 命令:

    SET PASSWORD FOR 'username'@'host' = PASSWORD('new_password');
    

    例如:

    SET PASSWORD FOR 'root'@'localhost' = PASSWORD('new_password');
    
  2. 使用 UPDATE 命令直接更新 mysql.user 表:

    UPDATE mysql.user SET Password = PASSWORD('new_password') WHERE User = 'username' AND Host = 'host';
    FLUSH PRIVILEGES;
    

    例如:

    UPDATE mysql.user SET Password = PASSWORD('new_password') WHERE User = 'root' AND Host = 'localhost';
    FLUSH PRIVILEGES;
    

MySQL 8.0 及以后

从 MySQL 8.0 开始,推荐使用 ALTER USER 语句来修改用户密码。mysql.user 表中的密码字段也改名为 authentication_string

  1. 使用 ALTER USER 命令:

    ALTER USER 'username'@'host' IDENTIFIED BY 'new_password';
    

    例如:

    ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
    
  2. 不再需要使用 FLUSH PRIVILEGES
    在 MySQL 8.0 及以后,使用 ALTER USER 修改密码后,不需要再执行 FLUSH PRIVILEGES 命令。

其他说明

  • 在 MySQL 8.0 之前,PASSWORD() 函数用于生成加密后的密码值;在 MySQL 8.0 中则不再使用该函数。
  • 从 MySQL 5.7 开始,MySQL 默认使用 mysql_native_password 插件进行密码验证,而在 MySQL 8.0 中则默认使用 caching_sha2_password 插件。

五、权限管理

1. 授予权限

GRANT 权限 ON 数据库.TO '用户名'@'主机';

示例:

GRANT SELECT, INSERT, UPDATE ON mydatabase.* TO 'testuser'@'localhost';

说明:

  • 权限:可以是单个权限,如 SELECT,也可以是多个权限,用逗号分隔,或者使用 ALL PRIVILEGES 授予所有权限。
  • 数据库.表:指定权限适用的数据库和表,*.* 表示所有数据库的所有表。

2. 撤销权限

REVOKE 权限 ON 数据库.FROM '用户名'@'主机';

示例:

REVOKE SELECT, INSERT ON mydatabase.* FROM 'testuser'@'localhost';

3. 刷新权限

在修改权限后,执行以下命令使权限生效:

FLUSH PRIVILEGES;

4. 查看用户权限

SHOW GRANTS FOR '用户名'@'主机';

示例:

SHOW GRANTS FOR 'testuser'@'localhost';

六、查看当前连接和会话

1. 查看当前连接的会话

SHOW PROCESSLIST;

说明:
该命令显示当前正在运行的线程信息,包括线程 ID、用户、主机、数据库、命令、执行时间、状态和信息。

2. 查看当前连接数

SHOW STATUS LIKE 'Threads_connected';

七、启动和停止 MySQL 服务

在 Windows 下

启动 MySQL 服务:

net start mysql

停止 MySQL 服务:

net stop mysql

八、配置 MySQL 服务器设置

MySQL 的配置文件通常位于 /etc/my.cnf(Linux)或 C:\ProgramData\MySQL\MySQL Server X.X\my.ini(Windows)。

常见配置选项:

[mysqld]
port=3306
bind-address=0.0.0.0
max_connections=200
default_storage_engine=InnoDB
character-set-server=utf8mb4
collation-server=utf8mb4_general_ci

说明:

  • port:设置 MySQL 服务的端口号。
  • bind-address:设置 MySQL 监听的 IP 地址,0.0.0.0 表示监听所有地址。
  • max_connections:设置最大连接数。
  • default_storage_engine:设置默认存储引擎。
  • character-set-servercollation-server:设置默认字符集和校对规则。

修改配置文件后,需要重启 MySQL 服务使配置生效。

九、备份和恢复数据库

1. 备份数据库

mysqldump -u 用户名 -p 数据库名 > backup.sql

示例:

mysqldump -u root -p mydatabase > mydatabase_backup.sql

2. 恢复数据库

mysql -u 用户名 -p 数据库名 < backup.sql

示例:

mysql -u root -p mydatabase < mydatabase_backup.sql

相关文章:

常用Mysql命令

前言 本文列举了一些常见的mysql操作 正文 一、连接和登录 MySQL 1. 使用命令行登录 MySQL 注意&#xff1a;需要将mysql的bin目录导入到环境变量中 mysql -u 用户名 -p示例&#xff1a; mysql -u root -p执行上述命令后&#xff0c;系统会提示输入密码&#xff0c;输入…...

IDEA Debug工具

一、Debug工具栏 自定义debug工具栏&#xff1a;先把debug程序运行起来->右击->配置 常用的工具&#xff1a; 二、DeBug常用图标详解 三、DeBug实践操作 常规Debug&#xff1a;略。 Stream Chain&#xff1a;处理流式语句 Reset Frame&#xff1a;重置方法入栈 …...

ARM64的汇编资源

最近在写一本ARM64的教材&#xff0c;所以在晚上查找了一下相关资源&#xff0c;都是免费开源的&#xff0c;不包括盗版书籍。 Exploring AArch64 assembler Roger Ferrer Ibez的博客文章&#xff0c;写在2016-2017年&#xff0c;内容简单充实&#xff0c;适合入门。 《ARM6…...

实验室安全分级分类管理系统在高校中的具体应用

盛元广通高校实验室安全分级分类管理系统的构建&#xff0c;旨在通过科学合理的管理手段&#xff0c;提高实验室的安全水平&#xff0c;保障师生的人身安全&#xff0c;防止实验事故的发生。这一系统通常包括实验室安全等级评估、分类管理、风险控制、安全教育与培训、应急响应…...

使用 prerenderRoutes 进行预渲染路由

title: 使用 prerenderRoutes 进行预渲染路由 date: 2024/8/20 updated: 2024/8/20 author: cmdragon excerpt: prerenderRoutes 函数是 Nuxt 3 中一个强大的工具,它能够帮助开发者优化页面加载速度和改善用户体验。通过使用 prerenderRoutes,你能够灵活地指定需要预渲染的…...

【深度解析】WRF-LES与PALM微尺度气象大涡模拟

查看原文>>>【深度解析】WRF-LES与PALM微尺度气象大涡模拟 针对微尺度气象的复杂性&#xff0c;大涡模拟&#xff08;LES&#xff09;提供了一种无可比拟的解决方案。微尺度气象学涉及对小范围内的大气过程进行精确模拟&#xff0c;这些过程往往与天气模式、地形影响和…...

redis事件机制

redis服务器是一个由事件驱动(死循环)的程序&#xff0c;它总共就干两件事&#xff1a; 文件事件&#xff1a;利用I/O复用机制&#xff0c;监听Socket等文件描述符发生的事件&#xff0c;如网络请求时间事件&#xff1a;定时触发的事件&#xff0c;负责完成redis内部定时任务&…...

【C++】模拟实现vector

可以把vector看作升级版的数组&#xff0c;可采用下标进行访问&#xff0c;非常高效&#xff0c;大小可动态改变&#xff0c;会自动扩容&#xff0c;数据存储在堆空间上。 VECROR 成员变量、函数及模板总览构造函数和析构函数无参构造函数构造n个元素大小的空间并初始化通过某个…...

【CAN-IDPS】汽车网关信息安全要求以及实验方法

《汽车网关信息安全技术要求及试验方法》是中国的一项国家标准,编号为GB/T 40857-2021,于2021年10月11日发布,并从2022年5月1日起开始实施 。这项标准由全国汽车标准化技术委员会(TC114)归口,智能网联汽车分会(TC114SC34)执行,主管部门为工业和信息化部。 该标准主要…...

EASE-Grid是啥东西?

EASE-Grid&#xff08;Equal-Area Scalable Earth Grid&#xff0c;等面积可扩展地球网格&#xff09;是NASA设计的网格系统&#xff0c;主要用于存储和处理全球范围内的地球科学数据。可以被理解为一种特殊的投影方式&#xff0c;使得在全球范围内进行数据分析和可视化时&…...

前端用户管理模块方法及api分析

用户管理 方法及对应api 搜索 searchSysUser / GetSysUserListByPage 重置 resetData 添加用户 addShow &#xff1a;点击按钮后出现对话框&#xff0c;含有提交 submit / SaveSysUser、取消按钮 修改 editSysUser / UpdateSysUser 删除 deleteById / DeleteSysUser 分配角色…...

microsoft edge怎么关闭安全搜索

microsoft edge浏览器为用户提供了安全搜索功能&#xff0c;旨在帮助用户过滤掉搜索结果中出现的不当信息。然而&#xff0c;有些用户可能觉得安全搜索功能限制了他们的浏览体验或工作需求。下面就给大家带来关闭microsoft edge安全搜索的相关内容&#xff0c;一起来看看吧。&a…...

Qt | QSQLite内存数据库增删改查

点击上方"蓝字"关注我们 01、演示 参数随便设置 查询 修改 右键菜单是重点 手动提交,点击Submit All...

【论文阅读】SegNeXt:重新思考卷积注意力设计

《SegNeXt: Rethinking Convolutional Attention Design for Semantic Segmentation》 原文&#xff1a;https://github.com/Visual-Attention-Network/SegNeXt/blob/main/resources/paper.pdf 源码&#xff1a;https://github.com/Visual-Attention-Network/SegNeXt 1、简介 …...

【C++】String类:标准库介绍

目录 一.预备知识 1.auto关键字 2.范围for 3.迭代器 二.标准库里的string 1.string类的基本介绍 2.构造函数 ​编辑 3.访问及遍历操作 3.1 operator [] 3.2 基于范围for 3.3 使用迭代器 4.迭代器 5.容量操作 5.1 size和length 5.2 capacity 5.3 reserve和resiz…...

MS523非接触式读卡器 IC

MS523 是一款应用于 13.56MHz 非接触式通信中的高集成 度读写卡芯片&#xff0c;它集成了在 13.56MHz 下所有类型的被动非接 触式通信方式和协议&#xff0c;支持 ISO14443A/B 的多层应用。 主要特点  高度集成的解调和解码模拟电路  采用少量外部器件&#…...

仓颉编程语言入门 -- Socket 编程与HTTP 编程概述

仓颉的 Socket 编程概述 在网络通信的广阔天地中&#xff0c;仓颉的Socket编程如同一座桥梁&#xff0c;连接着不同的计算设备&#xff0c;实现了基于传输层协议的数据传输。无论是追求稳定可靠的TCP&#xff0c;还是偏好轻量级、无连接的UDP&#xff0c;Socket都扮演着不可或…...

Oracle基本SQL操作-用户角色权限管理

一、用户权限管理 -- 创建锁定用户&#xff0c;此时用户不可用 create USER zhucl IDENTIFIED BY 123456 account lock; 会提示用户被锁定&#xff1a; -- 删除用户 drop user zhucl;-- 重新创建用户&#xff0c;不锁定 create user zhucl IDENTIFIED BY 123456 account unlo…...

Qt-信号和槽(8)

目录 信号的概念 Qt中的信号三要素 connect函数 connect的原型 connect的使用 信号函数和槽函数 参数匹配 close关闭槽函数 运行结果 第一个问题&#xff1a;怎么知道 手册使用 第二个问题&#xff0c;为什么可以直接传递函数指针 自定义槽函数 第一种自定义槽函…...

80.游戏的分辨率修改思路与分析

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a;易道云信息技术研究院 上一个内容&#xff1a;79.游戏分析工具闪屏问题优化与数据被修改高亮 GAMEHACKER2.exe 工具下载地址&#xff…...

conda相比python好处

Conda 作为 Python 的环境和包管理工具&#xff0c;相比原生 Python 生态&#xff08;如 pip 虚拟环境&#xff09;有许多独特优势&#xff0c;尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处&#xff1a; 一、一站式环境管理&#xff1a…...

Java 语言特性(面试系列2)

一、SQL 基础 1. 复杂查询 &#xff08;1&#xff09;连接查询&#xff08;JOIN&#xff09; 内连接&#xff08;INNER JOIN&#xff09;&#xff1a;返回两表匹配的记录。 SELECT e.name, d.dept_name FROM employees e INNER JOIN departments d ON e.dept_id d.dept_id; 左…...

条件运算符

C中的三目运算符&#xff08;也称条件运算符&#xff0c;英文&#xff1a;ternary operator&#xff09;是一种简洁的条件选择语句&#xff0c;语法如下&#xff1a; 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true&#xff0c;则整个表达式的结果为“表达式1”…...

深入理解JavaScript设计模式之单例模式

目录 什么是单例模式为什么需要单例模式常见应用场景包括 单例模式实现透明单例模式实现不透明单例模式用代理实现单例模式javaScript中的单例模式使用命名空间使用闭包封装私有变量 惰性单例通用的惰性单例 结语 什么是单例模式 单例模式&#xff08;Singleton Pattern&#…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败&#xff0c;具体原因是客户端发送了密码认证请求&#xff0c;但Redis服务器未设置密码 1.为Redis设置密码&#xff08;匹配客户端配置&#xff09; 步骤&#xff1a; 1&#xff09;.修…...

return this;返回的是谁

一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请&#xff0c;不同级别的经理有不同的审批权限&#xff1a; // 抽象处理者&#xff1a;审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...

基于Java+MySQL实现(GUI)客户管理系统

客户资料管理系统的设计与实现 第一章 需求分析 1.1 需求总体介绍 本项目为了方便维护客户信息为了方便维护客户信息&#xff0c;对客户进行统一管理&#xff0c;可以把所有客户信息录入系统&#xff0c;进行维护和统计功能。可通过文件的方式保存相关录入数据&#xff0c;对…...

RSS 2025|从说明书学习复杂机器人操作任务:NUS邵林团队提出全新机器人装配技能学习框架Manual2Skill

视觉语言模型&#xff08;Vision-Language Models, VLMs&#xff09;&#xff0c;为真实环境中的机器人操作任务提供了极具潜力的解决方案。 尽管 VLMs 取得了显著进展&#xff0c;机器人仍难以胜任复杂的长时程任务&#xff08;如家具装配&#xff09;&#xff0c;主要受限于人…...