什么是数据库?

数据库是专门用于存放计算机数据的软件仓库,这个仓库安装一定的数据结构对数据进行组织和存储

数据库的分类

1、关系型数据库

遵循ACID理论
常见的有:Oracle、MySQL、MariaDB、Microsoft SQL Server

2、非关系型数据库

也称为NoSQL数据库,是作为关系型数据库的一个有效补充
常见的有:Memcached、Redis、MongoDB

关系型数据库与非关系型数据库的优缺点

数据库 优点 缺点
关系型数据库 易于维护、使用方便、支持复杂sql操作 读写性能较差,灵活性欠缺,存在硬盘I/O瓶颈
非关系型数据库 存储格式灵活,速度快,成本低 不支持sql语句,复杂查询欠缺

SQL(Structured Query Language)结构化查询语言

SQL分类

DQL:数据查询语言:查询操作的SQL
DCL:数据控制语言,设定用户及权限的SQL
DDL:数据定义语言:表、序列、视图、索引的创建和销毁的SQL
DML:数据操作语言:CRUD
TCL:事务控制语言:控制事务的SQL

MySQL安装

MySQL安装步骤

MySQL安装步骤

1.清理环境

yum erase mariadb mariadb-server mariadb-libs mariadb-devel -y

2.创建用户

useradd -r sql -M -s /sbin/nologin

3.下载源码

wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.26.tar.gz

二进制安装使用下面的命令(可选),如使用二进制安装,跳过第4,7步

wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz

4.安装编译工具

yum -y install ncurses ncurses-devel openssl-devel bison gcc gcc-c++ make cmake

5.创建MySQL目录

mkdir -p /opt/vv/{data,mysql,log}

6.解压

tar xzvf mysql-5.7.26.tar.gz -C /opt/vv/

二进制方式安装使用下面的命令解压并移动

tar xzvf mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz 
mv mysql-5.7.26-linux-glibc2.12-x86_64/* /opt/vv/mysql

7.编译安装

cd /opt/vv/mysql-5.7.26/
cmake . \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=boost/boost_1_59_0/ \
-DCMAKE_INSTALL_PREFIX=/opt/vv/mysql \
-DSYSCONFDIR=/etc \
-DMYSQL_DATADIR=/opt/vv/data \
-DINSTALL_MANDIR=/usr/share/man \
-DMYSQL_TCP_PORT=3306 \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_READLINE=1 \
-DWITH_SSL=system \
-DWITH_EMBEDDED_SERVER=1 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1

参数解释:
-DCMAKE_INSTALL_PREFIX=/opt/liuyh/mysql \ 安装目录
-DSYSCONFDIR=/etc \ 配置文件存放 (默认可以不安装配置文件)
-DMYSQL_DATADIR=/opt/liuyh/data \ 数据目录 错误日志文件也会在这个目录
-DINSTALL_MANDIR=/usr/share/man \ 帮助文档
-DMYSQL_TCP_PORT=3306 \ 默认端口
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ sock文件位置,用来做网络通信的,客户端连接服务器的时候用
-DDEFAULT_CHARSET=utf8 \ 默认字符集。字符集的支持,可以调
-DEXTRA_CHARSETS=all \ 扩展的字符集支持所有的
-DDEFAULT_COLLATION=utf8_general_ci \ 支持的
-DWITH_READLINE=1 \ 上下翻历史命令
-DWITH_SSL=system \ 使用私钥和证书登陆(公钥) 可以加密。 适用与长连接。坏处:速度慢
-DWITH_EMBEDDED_SERVER=1 \ 嵌入式数据库
-DENABLED_LOCAL_INFILE=1 \ 从本地倒入数据,不是备份和恢复。
-DWITH_INNOBASE_STORAGE_ENGINE=1 默认的存储引擎,支持外键

如因网络问题boost库无法自动下载,可手动下载后将压缩包移动到 -DWITH_BOOST 参数所指定的目录下。
删除 -DDOWNLOAD_BOOST 和 -DWITH_BOOST参数
不用解压!!!

make && make install

8.创建软连接

ln -s /opt/vv/mysql/bin/mysql /usr/bin

9.更改创建的文件夹所属用户和所属组

chown -R sql:sql /opt/vv/{mysql,data,log}

10.配置参数

vi /etc/my.cnf

填写以下内容

[mysqld]
bind-address=0.0.0.0 
port=3306
user=sql 
basedir=/opt/vv/mysql
datadir=/opt/vv/data/mysql 
socket=/tmp/mysql.sock 
log-error=/opt/vv/data/mysql/mysql.err
pid-file=/opt/vv/data/mysql/mysql.pid
#character config
character_set_server=utf8mb4
symbolic-links=0
plugin-load=validate_password.so
validate-password=ON

11.初始化MySQL

进入MySQL的bin目录

./mysqld --defaults-file=/etc/my.cnf --basedir=/opt/vv/mysql/ --datadir=/opt/vv/data/mysql/ --user=sql --initialize

12.查看临时密码

cat /opt/vv/data/mysql/mysql.err

13.启动MySQL前先开放权限

cp /opt/vv/mysql/support-files/mysql.server /etc/init.d/mysqld
chown 777 /etc/my.cnf
chmod +x /etc/init.d/mysqld

14.启动MySQL

service mysqld start

关闭:service mysqld stop
15.登录MySQL修改密码

set password = password('AGLAREvv.1');

16.开启远程连接

use mysql
update user set Host='%' where user = "root";
flush privileges;

17.设置MySQL开机自启

chkconfig --add mysqld

至此完成

数据备份

使用select into命令备份

使用select into命令备份

select into是sql中的一个基础命令,可以完成数据备份,但是由于十分简陋,只能适用于临时的数据备份

1、查看权限

show variables like '%secure%';

secure_file_priv为NULL表示当前不可用select into进行备份

2、进入进入/etc/my.cnf,添加配置

secure-file-priv=/tmp

3、重启MySQL,重新查看权限,value值为/tmp/表示只能备份在此目录下。
4、执行select into命令

select * from t_user into outfile '/tmp/user.txt'

语法:select 语句 into outfile '目标文件'
将select的查询结果数据储存到/tmp/user.txt

5、恢复数据

load data infile '/tmp/user.txt' into table t_user;

至此完成

使用xtrabackup工具备份

使用xtrabackup工具备份

1.下载

wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.9/binary/redhat/6/x86_64/Percona-XtraBackup-2.4.9-ra467167cdd4-el6-x86_64-bundle.tar

2.解压

tar xvf Percona-XtraBackup-2.4.9-ra467167cdd4-el6-x86_64-bundle.tar

3.安装

yum install  percona-xtrabackup-24-2.4.9-1.el6.x86\_64.rpm -y

安装至此完成

三种备份方式

1-1.完整备份

创建备份
  1. 创建备份目录
mkdir /xtrabackup/full -p
  1. 执行备份命令
innobackupex --user=root --password='AGLAREvv.1' -S /tmp/mysql.sock  /xtrabackup/full

--user: 数据库登陆用户名
--password: 密码
-S :数据库套接文件地址,在/etc/my.cnf的socket中获取

恢复备份
  1. 关闭数据库
  2. 删除数据库所有数据
  3. 重演数据
innobackupex --apply-log /xtrabackup/full/2021-11-17_00-37-48
  1. 恢复数据
innobackupex --copy-back /xtrabackup/full/2021-11-17_00-37-48
  1. 查看数据库储存位置是否有数据文件
  2. 设置权限,将恢复后的文件权限设置为MySQL数据的拥有者可执行权限
chown -R sql:sql /opt/vv/data/mysql/*
  1. 启动数据库

1-2.增量备份

创建备份
  1. 先创建完整备份
  2. 修改数据库数据
  3. 创建增量备份
innobackupex --user=root --password='AGLAREvv.1' -S /tmp/mysql.sock --incremental /xtrabackup/full --incremental-basedir=/xtrabackup/full/2023-11-17_15-57-12

--incremental:指定增量备份生成位置
--incremental-basedir:指定以哪个备份为基础做增量备份,注意:所选备份应为一个完整备份或增量备份

恢复备份
  1. 关闭数据库
  2. 删除数据库所有数据
  3. 重演数据
innobackupex --apply-log --redo-only /xtrabackup/full/2021-11-17_15-57-12
  1. 整合数据
innobackupex --apply-log --redo-only /xtrabackup/full/2021-11-17_15-57-12 --incremental-dir=/xtrabackup/full/2021-11-17_16-01-25

前面的是完整备份,后面的是增量备份

  1. 恢复数据,所有数据都在完整备份中,恢复完整备份即可
innobackupex --copy-back /xtrabackup/full/2021-11-17_15-57-12
  1. 设置权限
chown -R sql:sql /opt/vv/data/mysql/*
  1. 启动数据库,查看数据

1-3.逻辑备份

使用mysqldump工具,是MySQL自带的逻辑备份工具

本身为客户端工具:
远程备份语法: # mysqldump -h 服务器 -u用户名 -p密码 数据库名 > 备份文件.sql
本地备份语法: # mysqldump -u用户名 -p密码 数据库名 > 备份文件.sql

  1. 创建备份目录
mkdir /mysql_backup
  1. 备份当前数据库所有数据

执行MySQL安装目录下bin目录中的mysqldump

mysqldump -u root -p -A > /mysql_backup/all.sql

参数解释:
-A, --all-databases #备份所有库
-B, --databases #备份多个数据库
--tables:指定表
-F, --flush-logs #备份之前刷新binlog日志
--default-character-set #指定导出数据时采用何种字符集,如果数据表不是采用默认的latin1字符集的话,那么导出时必须指定该选项,否则再次导入数据后将产生乱码问题。
--no-data,-d #不导出任何数据,只导出数据库表结构。
--lock-tables #备份前,锁定所有数据库表
--single-transaction #保证数据的一致性和服务的可用性
-f, --force #即使在一个表导出期间得到一个SQL错误,继续。
着重强调:
使用 mysqldump 备份数据库时避免锁表:
对一个正在运行的数据库进行备份请慎重,尽量不要在数据库开放服务时备份,如果一定要在服务运行期间备份,可以选择添加 --single-transaction选项,
类似执行: mysqldump --single-transaction -u root -p dbname > mysql.sql
3. 查看是否生成文件

至此完成

备份脚本

备份脚本
#!/bin/bash

# 配置项
BACKUP_DIR="/backup/mysql"   # 备份文件存放路径
MYSQL_USER="backup_user"     # MySQL 备份用户
MYSQL_PASSWORD="your_password"  # MySQL 备份用户的密码
MYSQL_HOST="localhost"       # MySQL 主机地址
MYSQL_PORT="3306"            # MySQL 端口
RETENTION_DAYS=30             # 备份保留天数,自动删除超过保留天数的备份

# 获取当前日期
DATE=$(date +"%Y-%m-%d")

# 创建备份目录(如果不存在)
mkdir -p "$BACKUP_DIR/$DATE"

# 备份所有数据库
echo "开始备份MySQL: $DATE"

databases=$(mysql -u$MYSQL_USER -p$MYSQL_PASSWORD -h$MYSQL_HOST -P$MYSQL_PORT -e "SHOW DATABASES;" | grep -Ev "(Database|information_schema|performance_schema|mysql|sys)")

for db in $databases; do
    echo "备份数据库: $db"
    mysqldump -u$MYSQL_USER -p$MYSQL_PASSWORD -h$MYSQL_HOST -P$MYSQL_PORT --databases "$db" > "$BACKUP_DIR/$DATE/$db.sql"
    if [ $? -eq 0 ]; then
        echo "备份数据库 $db 完成."
    else
        echo "Error: 备份数据库 $db 失败!"
    fi
done

# 压缩备份目录
tar -czf "$BACKUP_DIR/$DATE.tar.gz" -C "$BACKUP_DIR" "$DATE"
rm -rf "$BACKUP_DIR/$DATE"

echo "备份数据完成压缩"

# 删除过期备份
find "$BACKUP_DIR" -name "*.tar.gz" -type f -mtime +$RETENTION_DAYS -exec rm {} \;
echo "旧备份已保留超过 $RETENTION_DAYS 天,将被删除."

echo "MySQL备份完成: $DATE"

主从复制

基于log-bin的主从复制
  1. 主库创建用户并赋予权限
grant replication  slave,reload,super on *.*  to 'testslave'@'192.168.209.%' identified by 'AGLAREvv.1';

replication slave:拥有此权限可以查看从服务器,从主服务器读取二进制日志。
super权限:允许用户使用修改全局变量的SET语句以及CHANGE MASTER语句
reload权限:必须拥有reload权限,才可以执行flush [tables | logs | privileges]

  1. 主库修改配置文件/etc/my.cnf,添加配置
log-bin=/opt/vv/log/master.log
server-id=124
  1. 重启数据库
  2. 进入数据库查看状态
show master status\G;

关注file和position两条信息,从库配置时使用

  1. 从库配置文件添加
server-id=126

server-id 要唯一

  1. 重启数据库
  2. 进入数据库,执行命令

可先执行 show slave status\G 命令查看监听状态(默认未开启监听)

CHANGE MASTER TO
MASTER_HOST='192.168.209.124',   #主库ip
MASTER_USER='testSlave',         #主库用户名
MASTER_PASSWORD='AGLAREvv.1',        #主库密码
MASTER_LOG_FILE='master.000002',    #主库配置文件
MASTER_LOG_POS=154;              #主库日志偏移量
  1. 开启监听
start slave;
  1. 查看监听状态
show slave status\G;

Slave_IO_Running 和 Slave_SQL_Running 参数都为yes表示配置成功,如果失败 Last_Error 参数会显示错误信息

至此完成

基础操作语句

基础操作
数据库的创建和销毁-语法
create database [if not exists] 数据库名 [default charset 字符集]
drop database [if exists] 数据库名;
表的创建和销毁-语法
create table [if not exists] 表名( 字段名 数据类型  [约束],  ... );
drop table [if exists] 表名;
添加数据-语法
insert into 表名(列名,列名,列名,...) values(值,值,值,...);
删除数据-语法
delete from 表名 [where 条件];

表截断:truncate table 表名;//删除表中所有数据
表截断:直接在物理空间中,将保存数据的空间截断,效率更高
delete from 表:一行一行的删除,效率比较低。

更改数据-语法
update 表名 set 列名 = 新值,列名=新值, ... [where 条件];

事务

开启:begin
成功:commit
失败:rollback

事务的特点

英文名 中文名 特点
Atomicity 原子性 保证多条SQL要么同时成功,要么同时失败。
Consistency 一致性 事务执行前后,数据的状态是一致的。
Isolation 隔离性 并发访问相同数据时,不同用户是否可以看到另外一个用户未提交的数据。oracle默认只能看到提交后的。
Durability 持久性 一个事务一旦提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响 。

视图的创建、使用和销毁-语法

create view 视图名  as  查询SQL;
select 列,列,... from 视图名 [where 条件] ...
drop view 视图名;

视图本=本质上是一个复杂的查询SQL
视图只能提升开发效率,不能提升查询效率
视图本身不是表,不存储数据
视图本身可用于屏蔽底层表的机密列

索引的创建和销毁-语法

普通索引
创建:
ALTER TABLE student3 ADD INDEX nameIndex(name(50));
alter table 表名 add index 索引名(字段名)
删除:
ALTER TABLE student2 DROP INDEX nameIndex;
alter table 表名 DROP  index 索引名
唯一索引
创建:
ALTER TABLE student3 ADD UNIQUE INDEX nameIndex(name(50));
alter table 表名 add unique index 索引名(字段名)
删除同普通索引
主键索引
创建:
ALTER TABLE student7 ADD PRIMARY KEY (id);
alter table 表名 add PRIMARY KEY (字段名)
删除:
ALTER TABLE student7 DROP PRIMARY KEY;
alter table 表名 drop primary key
查看索引
show index from tab_name;

慢查询

命令开启(数据库重启失效)

查询是否开启

show variables like "%slow%";

查询慢查询阈值时间

show variables like "%long%";

修改阈值时间

set global long_query_time=2;

开启慢查询

set global slow_query_log='ON';

配置文件开启(永久生效)

打开配置文件/etc/my.cnf,添加配置
slow_query_log=1  #设置开启慢查询 值可以为1也可以为ON
slow_query_log_file=/opt/vv/log/mysql/mysql-slow.log  #设置慢查询日志位置,保证数据库所在用户拥有该位置权限
long_query_time=2  #设置慢查询阈值时间,单位s

权限管理

赋予权限

grant 权限名 on 库名.表名 to 用户名@'登录地址限制' identified by '新的密码';

grant select on test.user to gsc@'%' identfied by '111111';
将对test库中的user表的查询权限授予gsc,并设置gsc可在任意主机登录,并且密码改为111111
回收权限
revoke 权限名 on 库名.表明 from 用户名;

被回收的权限必须存在,否则会出错
整个数据库,使用 ON datebase.*;
特定的表:使用 ON datebase.table;

❤️ 转载文章请注明出处,谢谢!❤️