【MySQL_04】数据库基本操作(用户管理--配置文件--远程连接--数据库信息查看、创建、删除)

文章目录

  • 一、MySQL 用户管理
    • 1.1 用户管理
      • 1.11 mysql.user表详解
      • 1.12 添加用户
      • 1.13 修改用户权限
      • 1.14 删除用户
      • 1.15 密码问题
  • 二、MySQL 配置文件
    • 2.1 配置文件位置
    • 2.2 配置文件结构
    • 2.3 常用配置参数
  • 三、MySQL远程连接
  • 四、数据库的查看、创建、删除
    • 4.1 查看数据库
    • 4.2 创建、删除数据库

本文远程连接Ubuntu主机上安装的MySQL Server,有些内容前面也讲过,可以看历史文章。

MySQL版本:8.4.4 LTS。

软件使用Navicat

历史文章点击👉:SQL

🐈‍⬛github:https://github.com/mysql

💻官网: https://www.mysql.com

🌏维基百科:https://zh.wikipedia.org/wiki/MySQL

语法简述:SQL语句你看单次意思基本就能明白,语句不区分大小写,但运行时会字段转为大写,大小写看你公司规范。不过表名这种是有大小写的哦。你最好把相关语句的英语单词记住,去查查什么意思,怎么读。

一、MySQL 用户管理

1.1 用户管理

1.11 mysql.user表详解

MySQL的用户信息和权限配置存储在一个特殊的数据库中,这个数据库叫做 mysql 数据库。

mysql 数据库是MySQL系统的核心数据库之一,用于存储与MySQL服务器运行相关的系统信息,其中包括用户账户信息、权限设置、全局变量、插件信息等。

用户信息主要存储在mysql.user表中。
在这里插入图片描述

用户yun是我自己添加的(我创建的是一个特权用户,用于所有权限)。

其他几个是默认的,解释如下:

用户名用途描述权限范围
mysql.infoschema用于访问information_schema数据库,提供数据库元数据的只读视图。仅限访问information_schema,权限较低,主要用于查询元数据。
mysql.session供MySQL内部使用,用于插件和内部会话操作。用于服务器内部任务,如管理连接和会话,权限由MySQL内部控制。
mysql.sys用于sys数据库,提供性能监控和诊断工具。仅限访问sys数据库,权限较低,用于性能监控和优化。
root默认的超级用户,拥有最高权限,用于数据库管理和配置。拥有所有权限,可以执行任何数据库操作,包括创建、删除用户和数据库等。

user表共有51列,存储着每个用户的各种信息、权限等内容,本文分为6大类来解释:

(1)用户基本信息

字段名含义字段名含义
Host用户允许连接的主机地址(如localhost%表示任意主机)。User用户名,用于标识用户。
plugin认证插件类型(如caching_sha2_password)。authentication_string用户的认证凭据(密码哈希值)。

root用户最好只运行本机登录,即Host为localhost或者127.0.0.1这些。而特定的用户可以设置为允许登录的ip地址,或者允许任意主机连接。

authentication_string是用户密码哈希值,是由caching_sha2_password这种插件生成的,你无法查看真实密码,只能通过root用户修改密码。


(2)权限相关字段

这些是对用户的权限的比较精细的控制。这些权限默认基本全是拒绝的。

字段名含义字段名含义
Select_priv是否允许执行SELECT查询。Insert_priv是否允许执行INSERT插入操作。
Update_priv是否允许执行UPDATE更新操作。Delete_priv是否允许执行DELETE删除操作。
Create_priv是否允许创建数据库或表。Drop_priv是否允许删除数据库或表。
Reload_priv是否允许执行FLUSH操作(重新加载权限表)。Shutdown_priv是否允许关闭MySQL服务器。
Process_priv是否允许查看其他用户的进程(如SHOW PROCESSLIST)。File_priv是否允许读写文件(如LOAD DATA INFILE)。
Grant_priv是否允许授予其他用户权限。References_priv是否允许创建外键约束(已弃用)。
Index_priv是否允许创建或删除索引。Alter_priv是否允许修改表结构(如ALTER TABLE)。
Show_db_priv是否允许查看所有数据库(如SHOW DATABASES)。Super_priv是否拥有超级权限(如执行管理命令)。
Create_tmp_table_priv是否允许创建临时表。Lock_tables_priv是否允许锁定表。
Execute_priv是否允许执行存储过程或函数。Repl_slave_priv是否允许作为复制从服务器。
Repl_client_priv是否允许查询主服务器或从服务器的状态。Create_view_priv是否允许创建视图。
Show_view_priv是否允许查看视图定义。Create_routine_priv是否允许创建存储过程或函数。
Alter_routine_priv是否允许修改或删除存储过程或函数。Create_user_priv是否允许创建用户。
Event_priv是否允许创建、修改或删除事件。Trigger_priv是否允许创建或删除触发器。
Create_tablespace_priv是否允许创建表空间。Create_role_priv是否允许创建角色。
Drop_role_priv是否允许删除角色。

(3)SSL/TLS相关字段

主要用于加密连接。

字段名含义字段名含义
ssl_typeSSL连接类型(如ANYX509SPECIFIED)。ssl_cipher使用的SSL加密算法。
x509_issuerX509证书的颁发者信息。x509_subjectX509证书的主题信息。

(4)资源限制相关字段

字段名含义字段名含义
max_questions每小时允许的最大查询次数。max_updates每小时允许的最大更新次数。
max_connections每小时允许的最大连接次数。max_user_connections用户同时允许的最大连接数。

(5)密码管理相关字段

默认都是0,表示无限制。

字段名含义字段名含义
password_expired密码是否已过期(YN)。password_last_changed密码最后一次修改的时间。
password_lifetime密码的有效期(天数)。Password_reuse_history密码重用前需要更改的次数。
Password_reuse_time密码重用前需要等待的天数。Password_require_current修改密码时是否需要提供当前密码(YN)。

(6)其他字段

字段名含义字段名含义
account_locked账户是否被锁定(YN)。User_attributes用户的附加属性(以JSON格式存储)。

1.12 添加用户

执行添加、修改、删除用户等操作,你必须有相关权限才行,root用户有所有权限。权限是对mysql.user这张表的权限。有CREATE USER权限可以创建用户;有UPDATE和ALTER权限可以修改其它用户属性,以此类推。

使用 CREATE USER 语句创建新用户:

CREATE USER 'username'@'host' IDENTIFIED BY 'password';
  • username:用户名。
  • host:允许连接的主机(如 localhost 或 % 表示所有主机)。
  • password:你的用户密码。

创建无密码用户:危,不要这么做

CREATE USER 'newuser'@'localhost';

无密码用户,设置密码:

ALTER USER 'newuser'@'localhost' IDENTIFIED BY 'your_password';

1.13 修改用户权限

权限: 即前面讲的51个字段中的权限相关字段,不要_priv(privilege)后缀,不要下划线,全大写。

如:

  • 列名Select_priv对应的权限就是:SELECT
  • Create_view_priv就是CREATE VIEW

🔹使用 GRANT 语句授予用户权限:

GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';
  • 权限列表:可以是具体的权限(如 SELECT、INSERT、UPDATE 等,多个权限逗号分割),也可以是 ALL PRIVILEGES(表示所有权限)。
  • 数据库名.表名:指定权限作用的范围。可以使用 . 表示所有数据库和表,数据库名.* 表示某个数据库的所有表。
  • 用户名@主机名:指定用户和允许连接的主机(如 ‘test_user’@‘localhost’)。

例:
授予用户 test_user 对所有数据库的查询权限:

GRANT SELECT ON *.* TO 'test_user'@'localhost';

🔹使用 REVOKE 语句撤销权限:

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

🟢修改权限后需要刷新权限以生效:

FLUSH PRIVILEGES;

1.14 删除用户

使用 DROP USER 语句删除用户:

DROP USER 'username'@'host';

1.15 密码问题

注意1.12节说的权限问题。

🔹普通用户的密码:

修改密码:没密码就设置,有秘密就是修改

ALTER USER 'username'@'hostname' IDENTIFIED BY 'newpassword';

有密码的可以设置为空,即无密码:

ALTER USER 'username'@'hostname' IDENTIFIED BY '';

记得,修改密码后刷新权限(后面不再重复):

FLUSH PRIVILEGES;

🔹 root 用户的密码 :

(1)修改:跟前面一样

以root用户登录,然后修改即可

ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';

(2) 忘记密码: 这个才是常见情况

先停止mysql服务:

sudo systemctl stop mysql

使用 mysqladmin 工具修改密码:

mysqladmin -u root -p password '新密码'

刷新后启动mysql:

sudo systemctl start mysql

或者以跳过权限验证的方式启动mysql(先关闭):sudo mysqld_safe --skip-grant-tables &
登录root:mysql -u root
改密码:ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘new_password’;
刷新:FLUSH PRIVILEGES;
退出:EXIT;
停止(停止的是以跳过权限检查方式启动的mysql)和重启:sudo systemctl stop mysql
sudo systemctl start mysql


二、MySQL 配置文件

2.1 配置文件位置

☘️ (1)Windows

配置文件通常位于以下位置之一:

%basedir%\my.ini
%datadir%\my.ini
C:\ProgramData\MySQL\MySQL Server X.Y\my.ini(X.Y 是 MySQL 版本号)

获取:basedir和datadir路径:

登录mysql:此处 大写 -P 3360是我设置的mysql端口,默认是3306,如果是默认只值就不用指定这个参数。

mysql -u root -p -P 3360

执行语句:

SHOW VARIABLES LIKE 'basedir';
SHOW VARIABLES LIKE 'datadir';

在这里插入图片描述

如,我的配置文件在datadir下面:使用notepad++、记事本、vscode等软件即可打开查看
在这里插入图片描述

☘️ (2)Linux

命令:

mysql --help | grep 'my.cnf'

有3个位置的配置文件:
在这里插入图片描述

  • /etc/my.cnf:系统级别的全局配置文件,优先级最低。

  • /etc/mysql/my.cnf:特定 MySQL 安装的配置文件,优先级中等。

  • ~/.my.cnf:用户(Linux 用户)级别的配置文件,优先级最高。


🤭前面的第二个配置文件:在 Debian/Ubuntu 系统中,通常采用分片式配置,即将配置分散到多个文件中,方便管理和维护。主要包括:

  • /etc/mysql/my.cnf:主配置文件,通常会包含对其他配置文件的引用。
  • /etc/mysql/mysql.conf.d/:包含 MySQL 服务器的配置片段。
    • mysqld.cnf:MySQL 服务器的主要配置。
  • /etc/mysql/conf.d/:用户可以添加自定义配置片段。

在这里插入图片描述
上图最下面的: /etc/mysql/mysql.conf.d/mysqld.cnf 的作用

mysqld.cnf 文件专门用于配置 MySQL 服务器(mysqld)的行为。它通常包含以下内容:

  • 数据目录datadir
  • 绑定地址bind-address
  • 端口port
  • 日志文件路径(如 log_error
  • 字符集(如 character-set-server
  • 其他性能相关配置(如 innodb_buffer_pool_size

2.2 配置文件结构

MySQL 配置文件是一个文本文件,采用 key = value 的格式。

配置文件分为多个部分,每个部分用 [section] 标识。

常见的部分包括:

  • [mysqld]: MySQL 服务器的配置。
  • [client]: 客户端工具的默认配置(如 mysqlmysqladmin)。
  • [mysql]: mysql 命令行客户端的配置。
  • [mysqldump]: mysqldump 工具的配置。
  • [server]: 服务器相关的配置(较少使用)。

示例:

[mysqld]
datadir = /var/lib/mysql
socket = /var/lib/mysql/mysql.sock
port = 3306
user = mysql
max_connections = 200
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci[client]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set = utf8mb4[mysql]
default-character-set = utf8mb4

2.3 常用配置参数

☘️ 服务器配置 ([mysqld])

  • datadir: 数据目录,存储数据库文件的位置。

    datadir = /var/lib/mysql
    
  • port: MySQL 服务器监听的端口号,默认是 3306,你修改了这个,连接数据库的时候就要 -P 参数指定端口;或者在[client]里面吧端口也设置为相同的(指的是你用来连接的电脑的配置文件里面的[client])。

    port = 3306
    
  • bind-address: 服务器绑定的 IP 地址。0.0.0.0 表示监听所有网络接口。如果只允许几个ip,用逗号隔开。

    bind-address = 0.0.0.0
    
  • max_connections: 最大连接数。

    max_connections = 200
    
  • character-set-server: 服务器默认字符集。

    character-set-server = utf8mb4
    
  • collation-server: 服务器默认排序规则。

    collation-server = utf8mb4_unicode_ci
    
  • innodb_buffer_pool_size: InnoDB 缓冲池大小,建议设置为系统内存的 50%-70%。

    innodb_buffer_pool_size = 1G
    
  • log_error: 错误日志文件路径。

    log_error = /var/log/mysql/error.log
    
  • slow_query_log: 是否启用慢查询日志。

    slow_query_log = 1
    slow_query_log_file = /var/log/mysql/slow.log
    long_query_time = 2
    

☘️ 客户端配置 ([client])

  • port: 客户端连接时使用的默认端口。

    port = 3306
    
  • socket: 客户端连接时使用的 Unix 套接字文件路径。

    socket = /var/lib/mysql/mysql.sock
    
  • default-character-set: 客户端默认字符集。

    default-character-set = utf8mb4
    

☘️ 备份配置 ([mysqldump])

  • max_allowed_packet: 备份时允许的最大数据包大小。

    max_allowed_packet = 64M
    

🟢修改配置文件后,需要重启 MySQL 服务以使更改生效:

sudo systemctl restart mysql

如果配置文件有语法错误,MySQL 可能无法启动。可以通过以下命令检查配置文件的正确性:

mysqld --validate-config

某些参数可以在 MySQL 运行时动态调整,无需重启服务,仅限此次运行期间有效例如:

SET GLOBAL max_connections = 300;

三、MySQL远程连接

现在其实没啥好讲的了。

  1. 用户的Host要允许远程,如 %,而不是localhost;
  2. 配置文件里面的:bind-address = 0.0.0.0
  3. 服务器放行mysql使用的端口。

本系列的第二篇文章也有讲解。

四、数据库的查看、创建、删除

4.1 查看数据库

MySQL数据库连接成功之后,就可以使用SQL语句来查看当前所有存在的数据库,显示的一些默认的数据库是在 MySQL安装完成之后,在其目录 data 自动创建的几个必要的数据库,输入SQL语句如下:

 SHOW DATABASES;

输出:
在这里插入图片描述

这个命令起到一些小作用,可以帮助你查看创建的数据库是否创建成功,选择你创建的数据库等操作。

当然使用Navicat等软件直接就看到数据库了。
在这里插入图片描述

这些数据库我在第二篇讲过了:
在这里插入图片描述
切换到目标数据库:

USE 数据库名;

查看当前数据库的表:

SHOW TABLES;

🟢使用 SHOW TABLE STATUS 查看数据库中所有表的摘要信息:

SHOW TABLE STATUS FROM 数据库名;

在这里插入图片描述

4.2 创建、删除数据库

创建:

CREATE DATABASE test;

删除:

DROP DATABASE test;

创建或删除前可以先判断是否存在:

CREATE DATABASE if not  exists test;
DROP DATABASE IF EXISTS test;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/897498.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

配置 Thunderbird 以使用 outlook 邮箱

配置 Thunderbird 以使用 outlook 邮箱 thunder bird 作为邮件客户端非常好用,不用每次登录邮箱网页端查看邮件,直接打开配置好的 thunder bird 即可免登录查看邮件。 0. 什么是 Thunder Bird ? https://www.thunderbird.net/zh-CN/ Thunderbird 创立…

边缘计算的业务种类划分

Pcdn的业务可以根据不同的分类标准来划分 一、按线路类型划分 汇聚模式:一个地方有多条线路,业务种类较多。通常使用X86或X99主板组装的服务器,或各品牌的准系统服务器。收益通常比单线模式更高。 单线模式:一个地方只有一条线路&…

服务器数据恢复—raid5阵列中硬盘出现坏道的数据恢复流程

服务器故障情况: 某公司一台服务器中有一组多块硬盘组成的磁盘阵列。磁盘阵列中有2块硬盘出现故障离线,服务器崩溃,上层数据丢失。 硬件检测: 硬件工程师对客户服务器内的所有硬盘进行物理故障检测,最终确认这2块硬盘…

Linux:多线程(三.POSIX信号量、生产消费模型、线程池)

目录 1. 生产者消费者模型 1.1 阻塞队列(BlockingQueue) 1.2 一个实际应用的例子 2. POSIX信号量 2.1 引入 2.2 回顾加深理解信号量 2.3 信号量的操作接口 3. 基于循环队列的生产消费模型 3.1 循环队列 3.2 整个项目 4. 线程池 4.1 概念 4.2 线程池实现 1. 生产者…

关于前后端整合和打包成exe文件的个人的总结和思考

前言 感觉有很多东西,不知道写什么,随便写点吧。 正文 前后端合并 就不说怎么开发的,就说点个人感觉重要的东西。 前端用ReactViteaxios随便写一个demo,用于CRUD。 后端用Django REST Framework。 设置前端打包 import { …

Android15 Camera框架中的StatusTracker

StatusTracker介绍 StatusTracker是Android15 Camera框架中用来协调Camera3各组件之间状态转换的类。 StatusTracker线程名:std::string("C3Dev-") mId "-Status" Camera3 StatusTracker工作原理 StatusTracker实现批处理(状态…

利用OpenResty拦截SQL注入

需求 客户的一个老项目被相关部门检测不安全,报告为sql注入。不想改代码,改项目,所以想到利用nginx去做一些数据校验拦截。也就是前端传一些用于sql注入的非法字符或者数据库的关键字这些,都给拦截掉,从而实现拦截sql…

警惕AI神话破灭:深度解析大模型缺陷与禁用场景指南

摘要 当前AI大模型虽展现强大能力,但其本质缺陷可能引发系统性风险。本文从认知鸿沟、数据困境、伦理雷区、技术瓶颈四大维度剖析大模型局限性,揭示医疗诊断、法律决策等8类禁用场景,提出可信AI建设框架与用户防护策略。通过理论分析与实操案…

颠覆语言认知的革命!神经概率语言模型如何突破人类思维边界?

颠覆语言认知的革命!神经概率语言模型如何突破人类思维边界? 一、传统模型的世纪困境:当n-gram遇上"月光族难题" 令人震惊的案例:2012年Google语音识别系统将 用户说:“我要还信用卡” 系统识别&#xff…

【Linux】详谈 基础I/O

目录 一、理解文件 狭义的理解: 广义理解: 文件操作的归类认知 系统角度 二、系统文件I/O 2.1 标志位的传递 系统级接口open ​编辑 open返回值 写入文件 读文件 三、文件描述符 3.1(0 & 1 & 2) 3.2 文件描…

超分之DeSRA

Desra: detect and delete the artifacts of gan-based real-world super-resolution models.DeSRA:检测并消除基于GAN的真实世界超分辨率模型中的伪影Xie L, Wang X, Chen X, et al.arXiv preprint arXiv:2307.02457, 2023. 摘要 背景: GAN-SR模型虽然…

Vue3 Pinia 符合直觉的Vue.js状态管理库

Pinia 符合直觉的Vue.js状态管理库 什么时候使用Pinia 当两个关系非常远的组件,要传递参数时使用Pinia组件的公共参数使用Pinia

Web Worker如何在本地使用

首先了解一下什么是Web Worker Web Worker 是一种在后台线程中运行 JavaScript 的机制,允许你在不阻塞主线程的情况下执行耗时的任务。这对于保持网页的响应性和流畅性非常重要,特别是在需要进行复杂计算或大量数据处理时。 主要特点 多线程&#xff1…

Javaweb后端文件上传@value注解

文件本地存储磁盘 阿里云oss准备工作 阿里云oss入门程序 要重启一下idea,上面有cmd 阿里云oss案例集成 优化 用spring中的value注解

MAC-禁止百度网盘自动升级更新

通过终端禁用更新服务(推荐)​ 此方法直接移除百度网盘的自动更新组件,无需修改系统文件。 ​步骤: ​1.关闭百度网盘后台进程 按下 Command + Space → 输入「活动监视器」→ 搜索 BaiduNetdisk 或 UpdateAgent → 结束相关进程。 ​2.删除自动更新配置文件 打开终端…

数据结构:有序表的插入

本文是我编写的针对计算机专业考研复习《数据结构》所用资料内容选刊。主要目的在于向复习这门课程的同学说明,此类问题不仅仅使用顺序表,也可以使用链表。并且,在复习中,两种数据结构都要掌握。 若线性表中的数据元素相互之间可以…

DeepSeek大语言模型下几个常用术语

昨天刷B站看到复旦赵斌老师说的一句话“科幻电影里在人脑中植入芯片或许在当下无法实现,但当下可以借助AI人工智能实现人类第二脑”(大概是这个意思) 💞更多内容,可关注公众号“ 一名程序媛 ”,我们一起从 …

Html5学习教程,从入门到精通, HTML5超链接应用的详细语法知识点和案例代码(18)

HTML5超链接应用的详细语法知识点和案例代码 超链接(Hyperlink),也称为跃点链接,是互联网和文档编辑中的一种重要概念。 超链接的定义 超链接是指从一个网页指向一个目标的连接关系,这个目标可以是另一个网页&#…

MYSQL之创建数据库和表

创建数据库db_ck (下面的创建是最好的创建方法,如果数据库存在也不会报错,并且指定使用utf8mb4) show databases命令可以查看所有的数据库名,可以找到刚刚创建的db_ck数据库 使用该数据库时,发现里面没有…

[pytest] 配置

这里写目录标题 PytestInitRun3. 根据命令行选项将不同的值传递给测试函数 Report1. 向测试报告标题添加信息2. 分析测试持续时间 pytest --durations33. 增量测试 - 测试步骤--junitxml{report}.xml1. testsuite1.1 在测试套件级别添加属性节点 record_testsuite_property 2. …