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 文件,以此类推。

相关推荐
好奇的菜鸟6 分钟前
Ubuntu 18.04 启用root账户图形界面登录指南
数据库·ubuntu·postgresql
天桥下的卖艺者7 分钟前
使用R语言编写一个生成金字塔图形的函数
开发语言·数据库·r语言
Facechat19 分钟前
鸿蒙开发入坑篇(九):本地数据库 (RDB) 深度解析
数据库·华为·harmonyos
Dxy123931021620 分钟前
MySQL删除表语句详解
数据库·mysql
uoKent29 分钟前
MySQL常见命令梳理大纲
数据库·mysql
予枫的编程笔记34 分钟前
【MySQL筑基篇】从排名统计到非结构化存储:MySQL窗口函数与JSON实战教程
mysql·数据处理·窗口函数·后端开发·json数据类型·数据库进阶·mysql高级特性
晚霞的不甘41 分钟前
Flutter for OpenHarmony专注与习惯的完美融合: 打造你的高效生活助手
前端·数据库·经验分享·flutter·前端框架·生活
2301_7657031443 分钟前
工具、测试与部署
jvm·数据库·python
山岚的运维笔记1 小时前
SQL Server笔记 -- 第13章:IF...ELSE
数据库·笔记·sql·microsoft·sqlserver
创客小邓1 小时前
Qt对SQLite数据库的操作
数据库·qt·sqlite