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

相关推荐
合作小小程序员小小店9 小时前
桌面开发,超市管理系统开发,基于C#,winform,sql server数据库
开发语言·数据库·sql·microsoft·sqlserver·c#
quweiie9 小时前
thinkphp8.0链接SQL SERVER2022数据库
数据库·sqlserver·thinkphp
8***84829 小时前
如何在Linux中找到MySQL的安装目录
linux·运维·mysql
Databend10 小时前
如何打造AI时代的数据基石 | Databend Meetup 上海站
数据库
W***832010 小时前
如何在 Ubuntu 22.04 上安装 MySQL
linux·mysql·ubuntu
老华带你飞10 小时前
海产品销售系统|海鲜商城购物|基于SprinBoot+vue的海鲜商城系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·海鲜商城购物系统
合作小小程序员小小店10 小时前
桌面开发,在线%超市销售管理%系统,基于vs2022,c#,winform,sql server数据
开发语言·数据库·microsoft·c#
SelectDB10 小时前
字节跳动:Apache Doris + AI 一站式融合数据引擎的探索与实践
数据库·apache
7***q60811 小时前
在linux(Centos)中Mysql的端口修改保姆级教程
linux·mysql·centos
IvorySQL11 小时前
PostgreSQL 18 - 时间约束 (Temporal Constraints)
数据库·postgresql·开源