Ubuntu快捷安装MySQL

更新包列表

bash 复制代码
sudo apt update

安装mysql

bash 复制代码
sudo apt install mysql-server

启动mysql

sql 复制代码
// 启动mysql
sudo service mysql start

// 关闭mysql
sudo service mysql stop

// 重启mysql
sudo service mysql restart

连接mysql

sql 复制代码
// 初始安装无密码,直接连接即可,端口号默认3306
mysql -uroot

设置密码

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

注:设置完密码后,后续如果使用 mysql -uroot -h127.0.0.1 -pkingsoft. -P3306(可使用 mysql -uroot -h localhost -pkingsoft. -P3306 命令代替)命令连接mysql时,可能会报错:

原因分析:

MySQL的 root 用户没有配置为允许从 127.0.0.1 这个地址连接。默认情况下,root 用户通常只能从 localhost 连接,而不是从 127.0.0.1。虽然 localhost 和 127.0.0.1 在很多情况下是等价的,但MySQL的权限系统会将它们视为不同的主机。

查看mysql root用户

sql 复制代码
SELECT User, Host FROM mysql.user WHERE User = 'root';

执行结果:

由上述查询结果可知,root 用户确实没有配置允许从 127.0.0.1 这个地址连接。

修改或创建用户权限

sql 复制代码
// 创建用户(如果尚未存在)
CREATE USER 'root'@'127.0.0.1' IDENTIFIED BY 'kingsoft.';

// 授予权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'127.0.0.1' WITH GRANT OPTION;

// 刷新权限,上述创建用户、授予权限操作只会被记录在mysql.user表中,需执行下述命令将其加载到缓存中方可生效
FLUSH PRIVILEGES;

// 查看mysql root用户
SELECT User, Host FROM mysql.user WHERE User = 'root';

执行结果:

注1:如果不加127.0.0.1,则本地proxy无法连接到mysql。

注2:在 MySQL 5.7 及更高版本中,GRANT 语句和 IDENTIFIED BY 子句是分开的。您需要先创建用户(如果尚未存在),然后再授予权限。

注3:localhost、127.0.0.1仅限本机连接,如果想让公网上别的机器也能连接到mysql,需要把root用户的host字段改为'%',修改命令如下:

sql 复制代码
// 更新root用户host权限
update mysql.user set host='%' where user='root';

查看mysql读取my.cnf的顺序

sql 复制代码
// 如果不知道mysql使用的哪个配置文件,可以使用该命令查看mysql读取配置文件的顺序
mysqld --verbose --help | grep -A 1 'Default options'

// 找到mysql使用的配置文件后,就可按自己需要对配置文件进行修改
// 修改后重启mysql即可
// 我的本地机器上没有 /etc/my.cnf 文件,所以修改 /etc/mysql/my.cnf
vim /etc/mysql/my.cnf

执行结果:

注:如果 /etc/my.cnf 文件存在,则优先使用该文件,如果 /etc/my.cnf 文件不存在,则使用 /etc/mysql/my.cnf 文件,以此类推。

相关推荐
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北1 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip