Mysql数据库(一)

文章目录

  • 前言
  • 一、数据库
    • [1.1 回顾web服务流程](#1.1 回顾web服务流程)
    • [1.2 数据库的概念](#1.2 数据库的概念)
    • [1.3 数据库管理系统(DBMS)](#1.3 数据库管理系统(DBMS))
    • [1.4 数据库系统](#1.4 数据库系统)
  • 二、数据库的分类
    • [2.1 按时间分类](#2.1 按时间分类)
    • [2.2 按存储方式分](#2.2 按存储方式分)
  • 三、安装mysql
    • [3.1 关闭防火墙和网络增强服务](#3.1 关闭防火墙和网络增强服务)
    • [3.2 解压mysql安装包与对应的依赖库boost安装包](#3.2 解压mysql安装包与对应的依赖库boost安装包)
    • [3.3 安装编译安装的依赖包](#3.3 安装编译安装的依赖包)
    • [3.4 创建mysql系统用户](#3.4 创建mysql系统用户)
    • [3.5 mysql编译安装](#3.5 mysql编译安装)
    • [3.6 配置mysql权限](#3.6 配置mysql权限)
    • [3.7 修改配置文件](#3.7 修改配置文件)
    • [3.8 设置环境变量](#3.8 设置环境变量)
    • [3.9 数据库初始化](#3.9 数据库初始化)
    • [3.10 启动mysql服务](#3.10 启动mysql服务)
    • [3.11 账号密码管理](#3.11 账号密码管理)
  • 总结

前言

本文讲述了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以及安装操作,希望本文能对您有所帮助,谢谢观看😜

相关推荐
_院长大人_42 分钟前
在 CentOS 系统上使用安装并用alternatives切换 JDK17(与 JDK8 共存指南)
java·linux·运维·centos
|晴 天|43 分钟前
前端安全入门:XSS 与 CSRF 的攻与防
前端·安全·xss
黛色正浓44 分钟前
【React】ReactRouter记账本案例实现
前端·react.js·前端框架
数新网络1 小时前
CyberAI多模态数据平台焕新升级!七大核心功能解锁高效管理新体验
java·网络·人工智能
Aerelin1 小时前
爬虫图片采集(自动化)
开发语言·前端·javascript·爬虫·python·html
Highcharts.js1 小时前
Renko Charts|金融图表之“砖形图”
java·前端·javascript·金融·highcharts·砖型图·砖形图
zhaodiandiandian1 小时前
工业智能化:从自动化到自主化的升级之路
运维·人工智能·自动化
含若飞1 小时前
列表弹窗实现方案整理
前端·javascript·vue.js