数据库的基本概念
数据
- 描述事物的符号记录
- 包括数字,文字、图形、图像、声音、档案记录等
- 以“记录”的形式按统一的格式进行存储
表
- 将不同的记录组织在一起
- 用来存储具体数据
数据库
- 表的集合,是存储数据的仓库
- 以一定的组织方式存储的相互有关的数据集合
数据库管理系统(DBMS)
- 是实现对数据库资源的有效组织、管理和存取的系统软件
数据库系统
- 是一个人机系统,由硬件、OS、数据库、DBMS、应用软件和数据库用户组成
- 用户可以通过DBMS或应用程序操作数据库
数据库系统发展史
第一代数据库
- 自20世纪60年代起,第一代数据库系统问世
- 是层次模型与网状模型的数据库系统
- 为统一管理和共享数据提供了有力的支持
第二代数据库
- 20世纪70年代初,第二代数据库——关系型数据库开始出现
- 20世纪80年代初,IBM公司的关系数据库系统DB2问世,开始逐步取代层次与网状模型的数据库,成为行业主流
- 到目前为止,关系数据库系统仍占领数据库
第三代数据库
- 从20世纪80年代开始,适应不同领域的新型数据库系统不断涌现
- 面向对象的数据库系统,实用性强、适应面广
- 20世纪90年代后期,西南刚才了多种数据库系统共同支持应用的局面
- 一些新的元素被添加到主流数据库系统中
- 例如Oracle支持的“关系-对象“数据库模型
- 主流数据库介绍
- SQL Server(微软公司产品)
- 向Windows操作系统
- 简单、易用
- Oracle(甲骨文公司产品)
- 面向所有主流平台
- 安全、完善,操作复杂
- DB2(IBM公司产品)
- 向所有主流平台
- 大型、安全、完善
- MySQL (甲骨文公司收购)
- 免费、开源、体积小
- SQL Server(微软公司产品)
数据库分类
关系型数据库
- 关系型数据库系统是基于关系模型的数据库系统
- 关系模型的数据结构使用简单易懂的二维数据表
- 关系模型可可用简单的”实体-关系“(ER)图来表示
- E-R图中包含了实体(数据对象)、关系和属性三要素
非关系型数据库
- 也被称为NoSQL(Not Only SQL)
- 存储数据不以关系模型为依据,不需要固定的表格式
- 优点
- 数据库高并发读写
- 对海量数据高效率存储和访问
- 数据库具有高扩展性与高可用性
- 常用的非关系数据库
- Redis、MongoDB
MySQL数据库介绍
- 一款深受欢迎的开源关系型数据库
- Oracle旗下的产品
- 遵守GPL协议,可以免费使用和修改
- 特点
- 性能卓越、服务稳定
- 开源、无版本限制、成本低
- 多线程、多用户
- 基于C/S(客户端/服务器)架构
- 安全可靠
MySQL编译安装
基础环境准备
[root@www ~]# yum -y install gcc libaio
创建程序用户
[root@www ~]# useradd -M -s /sbin/nologin mysql
关闭防火墙
[root@www ~]# setenforce 0
[root@www ~]# systemctl disable firewalld
[root@www ~]# systemctl stop firewalld
二进制安装
[root@www ~]# tar zxvf mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz
[root@www ~]# mv mysql-5.7.28-linux-glibc2.12-x86_64 /usr/local/mysql
[root@www ~]# mkdir /usr/local/mysql/data
[root@www ~]# chown -R mysql.mysql /usr/local/mysql/data
[root@www ~]# cd /usr/local/mysql/bin
[root@www ~]# ./mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --initialize
标红的字段需要先保存,后面要用(字段内容是随机生成的)
设定配置文件
[root@www ~]# vim /etc/my.cnf
[client]
socket=/usr/local/mysql/data/mysql.sock
[mysqld]
socket=/usr/local/mysql/data/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
port = 3306
max_connections=2048
character-set-server=utf8
default-storage-engine=INNODB
lower_case_table_names=1
[mysqld_safe]
log-error=/usr/local/mysql/data/error.log
配置 systemctl 方式启动
[root@www ~]# cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld
[root@www ~]# chmod +x /etc/rc.d/init.d/mysqld
[root@www ~]# vim /lib/systemd/system/mysqld.service
[Unit]
Description=mysqld
After=network.target
[Service]
Type=forking
ExecStart=/etc/rc.d/init.d/mysqld start
ExecReload=/etc/rc.d/init.d/mysqld restart
ExecStop=/etc/rc.d/init.d/mysqld stop
PrivateTmp=true
[Install]
WantedBy=multi-user.target
测试
[root@www ~]# systemctl daemon-reload
[root@www ~]# systemctl enable mysqld
[root@www ~]# systemctl start mysqld
[root@www~]# netstat -tunlp|grep 3306
访问 MySQL 数据库
[root@www ~]# mysql -u root -p //登录需要输入密码,密码就是之前保存的字段内容
mysql>set password =password('pwd123');
标签:www,初体验,数据库,MySQL,mysqld,mysql,数据库系统,root
From: https://blog.csdn.net/anbesrt/article/details/139864747