Mysql数据库(一)

前言

本文讲述了myql以及安装操作

一、数据库

1.1 回顾web服务流程

在这里插入图片描述
1、用户在浏览器输入域名
2、DNS解析将域名解析成为IP地址
3、浏览器与web服务器建立连接(通过三次握手)
4、浏览器向web服务器发起http请求连接
5、若为静态页面,web服务器直接处理请求并回给客户端,形成静态页面
6、若为动态页面,web服务器则要发送给应用服务器,应用服务器在数据库中找数据,最后回给用户,形成动态页面

1.2 数据库的概念

在上述流程讲解中,本文提到了数据库这一名词,那么数据库的概念就好理解了,数据库就相当与一个图书馆,存放着很多书,这些书以书架的形式存放,那么,数据存放在数据库中则以表的形式。
MySQL 服务 → 数据库 → 表 → 行(记录) + 列(字段)

表结构= 行(记录) + 列(字段)
特点:
1、记录由字段组成,字段由字符或数字组成
2、可供不同用户共享
3、具有较小的冗余度和较高的数据独立性

数据库就是表的集合,是按照一定组织方式存储的相关数据集合

1.3 数据库管理系统(DBMS)

定义:操作和管理数据库的软件。
主要功能:
1.建库与维护(建表、转储与恢复、重组、性能监视)
2.数据定义(数据结构、存储结构、保密模式)
3.数据操作(查询、统计、更新)
4.运行管理(并发控制、存取控制、维护)
5.通信(与其他软件交互,如 Access 和 Office 组件)

1.4 数据库系统

组成:操作系统(如Windows、linux)、硬件、应用软件、用户、数据库、DBMS
DBA(数据库管理员):负责备份恢复、维护、用户管理。
数据库应用软件:Navicat、人事管理系统、财务系统、图书管理等。
DBMS 工作模式:
1.接收请求
2.转换为底层指令
3.执行数据库操作
4.获取结果
5.格式化结果
6.返回给用户

二、数据库的分类

2.1 按时间分类

第一阶段(层次型/网状型)
IMS(IBM,1969)

第二阶段(关系型)
关系模型(1970)
一位叫 E.F. Codd的 IBM 研究员提出了“关系模型(Relational Model)”。
核心思想:
把数据放在 二维表(行、列)里,而不是像层次型或网状型那样用复杂的指针去连接。
用数学集合和关系代数来描述和操作数据(比如选择、投影、连接)。
这样数据就更直观、更容易查询和维护。
代表产品
System R(IBM 开发):第一个真正实现关系模型的实验性数据库系统。
Ingres(加州大学伯克利):另一个早期的关系型数据库系统,后来衍生出了 PostgreSQL。
意义
关系型数据库的出现,让 SQL(结构化查询语言)成为主流。
现在常见的 MySQL、Oracle、SQL Server 都是关系型数据库的后代。

2.3 第三阶段(新型数据库)
特点:面向对象、开放性、多平台
SQL + NoSQL 混合使用
新兴数据库:MariaDB、PostgreSQL、时序数据库

2.2 按存储方式分

关系型数据库
数据模型:E-R 模型(实体-关系)
行(记录) = 实体
列(字段) = 属性
特点 关系型数据库 非关系型数据库
数据结构 表(二维表) KV、文档、列式、图形
优点 结构清晰,SQL通用,支持复杂查询 格式灵活,速度快,高并发
缺点 表结构固定,I/O 瓶颈 无SQL、事务差、复杂查询弱
代表产品 MySQL、Oracle、PostgreSQL Redis、MongoDB、HBase
表与表之间存在关系(1对1,1对多,多对多)
主键:唯一、非空,类比学号/身份证号。
常见产品:MySQL、Oracle、SQL Server、DB2、PostgreSQL 等。

非关系型数据库(NoSQL)
定义:Not Only SQL,存储方式不限于表,可存储键值对、文档、列式数据等。
典型产品:Redis、Memcached、MongoDB、HBase。
应用场景:高并发、缓存、大数据实时计算。
优点
1.格式灵活(Key-Value、文档、图片等)
2.速度快(基于内存存储)
3.高扩展性
4.成本低(开源,部署简单)
缺点
1.不支持 SQL
2.缺少事务处理
3.复杂查询支持不足
4.大部分数据在内存,成本较高
对比 Redis 和 Memcached
相同点:都存储热点数据,内存运行,速度快。
不同点:Redis 支持持久化,数据可落盘;Memcached 纯内存,断电丢失。

三、安装mysql

3.1 关闭防火墙和网络增强服务

systemctl disable firewalld --now ————————关闭防火墙
vim /etc/selinux/config ————————编辑网络增强服务
在这里插入图片描述

3.2 解压mysql安装包与对应的依赖库boost安装包

tar zxvf mysql-5.7.17.tar.gz -C /opt——————————解压mysql安装包到opt下
tar zxvf boost_1_59_0.tar.gz -C /usr/local ————————解压boost安装包到/usr/lcoal下
在这里插入图片描述
在这里插入图片描述

3.3 安装编译安装的依赖包

yum install -y gcc gcc-c++ ncurses ncurses-devel bison cmake
在这里插入图片描述

3.4 创建mysql系统用户

useradd -s /sbin/nologin ————————创建系统用户mysql
在这里插入图片描述

3.5 mysql编译安装

cd /opt/mysqll-5.7.17 ————————切换目录

cmake
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock
-DSYSCONFDIR=/etc
-DSYSTEMD_PID_DIR=/usr/local/mysql
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_EXTRA_CHARSETS=all
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
-DMYSQL_DATADIR=/usr/local/mysql/data
-DWITH_BOOST=/usr/local/boost
-DWITH_SYSTEMD=1

make -j 4 && make install ————————用4个内核进行编译安装
在这里插入图片描述

3.6 配置mysql权限

chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf ———————更改mysql配置文件的属主属组
在这里插入图片描述

3.7 修改配置文件

vim /etc/my.cnf ————————编辑mysql配置文件
在这里插入图片描述

3.8 设置环境变量

echo “PATH=$PATH:/usr/local/mysql/bin” >> /etc/profile ——————追加
source /etc/profile ————————刷新/etc/profile文件

3.9 数据库初始化

cd /usr/local/mysql/bin/
./mysqld
–initialize-insecure
–user=mysql
–basedir=/usr/local/mysql
–datadir=/usr/local/mysql/data
在这里插入图片描述

3.10 启动mysql服务

cp /usr/local/mysql/usr/lib/systmed/system/mysql.service /usr/lib/systemd/system ————————————将mysql服务移到system下
systemctl deamon-reload ——————————加载systemctl
systemctl enable mysql.server --now ————————启动mysql服务
在这里插入图片描述

3.11 账号密码管理

mysqladmin -u root -p password 123321 ——————创建登录用户,用户名为root,密码为123321
mysql -u root -p ————————登录mysql数据库(密码需要输入)
在这里插入图片描述
输入 show Databases; 尝试进入数据库
在这里插入图片描述

总结

本文讲述了myql以及安装操作,希望本文能对您有所帮助,谢谢观看😜

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值