一、安装YUM Repo
1、由于CentOS 的yum源中没有mysql,CentOS 7上把MySQL从默认软件列表中移除了,用MariaDB来代替需要到mysql的官网下载yum repo配置文件。下载命令:
wget https://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
2、然后进行repo的安装:
rpm -ivh mysql57-community-release-el7-9.noarch.rpm
执行完成后会在/etc/yum.repos.d/目录下生成两个repo文件mysql-community.repo mysql-community-source.repo
二、使用yum命令即可完成安装
注意:必须进入到 /etc/yum.repos.d/目录后再执行以下脚本
1、安装命令:
yum install mysql-server
2、启动msyql:
systemctl start mysqld #启动MySQL
systemctl restart mysqld #重启MySQL
systemctl stop mysqld #关闭MySQL
systemctl status mysqld #查看MySQL运行状态
systemctl enable mysqld #设置开机启动
systemctl disable mysqld #关闭开机启动
mysql_secure_installation #设置安全选项
(设置方法↓↓↓↓↓↓↓↓↓↓↓↓)
https://www.cnblogs.com/sunny18/p/8684861.html
3、密码配置:新版本的Mysql会为root用户创建一个初始密码,需要更改。
grep 'temporary password' /var/log/mysqld.log 查看默认密码
_k=WbIdsv2?k mysql -uroot -p(密码) 使用初始密码登陆mysql
mysql -h 127.0.0.1 -u root -p 能够登录得上mysql数据库
如果没有获取到临时密码则:
rm -rf /var/lib/mysql #删除原来安装过的mysql残留的数据
systemctl start mysqld #在启动MySQL
linux安装mysql初始密码错误,mysql无密码登录设置
linux安装mysql初始密码错误,mysql无密码登录设置_汤姆猫丶的博客-CSDN博客_linux mysql 初始密码
先把mysql设置为无密码登录,修改密码后再设置回来
vim /etc/my.cnf #编辑/etc目录下的my.cnf文件
在 [mysqld] 这个模块最后一行插入这一语句:
skip-grant-tables #忽略mysql权限问题,直接登录
systemctl restart mysqld #重启MySQL
mysql -u root -p #然后回车,直接登录上mysql
为了安全,修改完密码在把取消验证权先注释掉
4、修正密码强度校验规则(用于测试环境使用),高版本的mysql在修改密码时会限制简单密码的创建,如果单单是为了测试使用,可以将他的密码检测策略修改下:
修改:密码最小长度策略:当前密码长度为 8 ,如果不介意的话就不用修改了,按照通用的来讲,设置为 6 位的密码,设置 validate_password_length 的全局参数为 6 即可。
mysql> set global validate_password_length=0;
修改:密码强度检查等级策略,0/LOW、1/MEDIUM、2/STRONG
设置密码的验证强度等级,设置 validate_password_policy 的全局参数为 LOW 即可
mysql> set global validate_password_policy=0;
systemctl restart mysqld 重启数据库
修改密码为123456
mysql> set password for 'root'@'localhost' = password('123456'); 未验证密码修改
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456'; 已验证密码 和上选一即可
5、其他配置(开启远程控制)
MySQL默认是没有开启远程控制的,必须添加远程访问的用户,即默认是只能自己访问,别的机器是访问不了的。
开启mysql的root用户远程连接服务(%号即远程连接,IDENTIFIED BY后面跟的密码)
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root123' WITH GRANT OPTION;
刷新
mysql> flush privileges;
开启mysql端口服务
/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT service network restart
查看版本
select version();
6、Navicat 连接Mysql
select version();查看mysql版本
CentOS7下安装mysql5.7_不甘于平凡的溃败的博客-CSDN博客_centos安装mysql 精华帖
CentOs安装Mysql和配置初始密码 - 睡猪遇上狼 - 博客园 精华帖
7、常用数据库操作
1.更改root密码
mysqladmin -uroot password 'yourpassword'
2.远程登陆mysql服务器
mysql -uroot -p -h192.168.137.10 -P3306
3.查询数据库
show databases;
use databasename;
5.列出数据库中的表
show tables;
6.查看某个表全部字段
desc slow_log;
show create table slow_log\G; (不仅可以显示表信息,还可以显示建表语句)
7.查看当前用户
select user();
8.查看当前所在数据库
select database();
9.创建新数据库(可以指定字符集)
create database db1 charset utf8;
10.创建新表
create table t1 (`id` int(4), `name` char(40));
11.查看数据库版本
select version();
12.查看数据库状态
show status; 当前会话状态
show global status; 全局数据库状态
show slave status\G; 查看主从数据库状态信息
13.查询数据库参数
show variables;
14.修改数据库参数
show variables like 'max_connect%';
15.查看当前数据库队列
show processlist;
16.创建普通用户并授权给某个数据库
grant all on databasename.* to 'user1'@'localhost' identified by '123456';
20.清空表数据
mysql -uroot -p'yourpassword' mysql </tmp/mysql.sql
EOF
mysql语句
mysql -uuser -hhostname -ppasswd <<EOF
以下是执行大量mysql语句采用的方式
echo "show databases"|mysql -uuser -ppassword
mysql -uuser -ppasswd -e"show databases"
29.脚本中执行mysql命令
SHOW GRANTS FOR name;
28.查看name用户权限
SET PASSWORD FOR name=PASSWORD('fdddfd');
27.更改普通用户密码
CREATE USER name IDENTIFIED BY 'ssapdrow';
26.新建普通用户
25.数据库恢复
mysqldump -uroot -p'yourpassword' mysql >/tmp/mysql.sql
24.数据库备份
drop database db1;
23.删除数据库
mysql -N -s information_schema -e "SELECT CONCAT('TRUNCATE TABLE ',TABLE_NAME,';') FROM TABLES WHERE TABLE_SCHEMA='eab12'" | mysql -f eab12
22.清空数据库中的所有表(数据库名是eab12)
drop table db1.t1;
21.删除表
truncate table db1.t1;
update db1.t1 set name='aaa' where id=1;
19.更改表的某一行数据
insert into db1.t1 values (1, 'abc');
18.插入一行数据
select * from mysql.db where host like '10.0.%';在查询语句中可以使用万能匹配 “%”
select db,user from mysql.db; //查询表中的多个字段
select count(*) from mysql.user; //count(*)表示表中有多少行
select * from mysql.db; //查询该表中的所有字段
grant all on databasename.* to 'user1'@'localhost' identified by '123456';
20.清空表数据
mysql -uroot -p'yourpassword' mysql </tmp/mysql.sql