数据库基本概念

一、数据库的基本概念

1.1 数据库的组成

数据:描述事物的符号记录
包括数字,文字、图形、图像、声音、档案记录等
以“记录”形式按统一格式进行存储

表:将不同的记录组织在一起,用来存储具体数据

数据库: 表的集合,是存储数据的仓库
以一定的组织方式存储的相互有关的数据集合
在这里插入图片描述

1.2 数据库的管理系统(DBMS)

是实现对数据库资源有效组织、管理和存取的系统软件
功能:数据库的建立和维护功能、数据定义功能、数据操控功能、数据库的运行管理功能、通信功能

1.3 数据库系统(DBS)

是一个人机系统,由硬件、OS、数据库、DBMS、应用软件和数据库用户组成
用户可以通过DBMS或应用程序操作数据库
在这里插入图片描述

1.3.1 数据库的发展史

第一代数据库
1、自20世纪60年代起,第一代数据库系统问世
2、是层次模型与网状模型的数据库系统
3、为统一管理和共享数据提供了有力的支撑

第二代数据库
1、20世纪70年代初,第二代数据库——关系数据库开始出现
2、20世纪80年代初,IBM公司的关系数据库系统DB2问世,开始逐步取代层次与网状模型的数据库,成为行业主流
3、到目前为止,关系数据库系统仍占领数据库应用的主要地位
第三代数据库
1、自20世纪80年代开始,适应不同领域的新型数据库系统不断涌现
2、面向对象的数据库系统,实用性强、适应面广
3、20世纪90年代后期,形成了多种数据库系统共同支撑应用的局面一些新的元素被添加进主流数据库系统中
例如,Oracle支持的“关系-对象”数据库模型

1.3.2 当今主流数据库

SQL Server (微软公司产品)
面向Windows操作系统
简单、易用

Oracle (甲骨文公司产品)
面向所有主流平台
安全、完善、操作复杂

DB2 (IBM公司产品)
面向所有主流平台
大型、安全、完善

MySQL (甲骨文公司收购)
免费、开源、体积小

1.4 关系型数据库介绍

1、关系数据库系统是基于关系模型的数据库系统

2、关系模型的数据结构使用简单易懂的二维数据表
  每一行称为一条记录,用来描述一个对象的信息
  每一行称为一个字段,用来描述对象的一个属性
在这里插入图片描述
 3、关系模型可用简单的"实体-关系-属性"来表示
 1、实体
 也称为实例,对应现实世界中可区别与其他对象的“事件”或“事物”
 如银行客户、银行账户等
 2、关系
 实体集之间的对应关系称为联系,也称为关系
 如银行客户和银行账户之间存在“储蓄”的关系
 3、属性
 实体所具有的某一特性,一个实体可以有多个属性
 如“银行客户”实体集中的每个实体均具有姓名、住址、电话等属性
 在这里插入图片描述

1.5 关系库应用

关系型数据库
Oracle,MySQL
SQLServer、Sybase
Informix、access
DB2、foxPRO

应用举例
12306用户信息系统
淘宝账号系统
联通手机号信息系统
银行用户账户系统
网站用户信息系统

1.6 非关系型数据库介绍

非关系数据库也称为NoSQL (Not Only SQL)
 存储数据不以关系模型为依据,不需要固定的表格式

非关系型数据库的优点
 1、数据库可高并发读写
 2、对海量数据高效率存储与访问
 3、数据库具有高扩展性与高可用性

1.7 MySQL数据库介绍

一款深受欢迎的开源关系型数据库
Oracle旗下的产品
遵守GPL协议,可以免费使用与修改

特点
 性能卓越、服务稳定
 开源、无版权限制、成本低
 多线程、多用户
 基于C/S(客户端/服务器)架构
 安全可靠

1.8 MySQL产品阵营

■第一阵营: 5.0-5.1阵营,可说是早期产品的延续
■第二阵营: 5.4-5.7阵营,整合了MySQL AB公司、社区和第3三方公司开发的存储引擎,从而提高性能
■第三阵营: 6.0-7.1阵营,就是MySQL Cluster版本,为适应新时代对数据库的集群需求而开发
■下载网址
●http://www.dev.mysql.com/downloads

二、编译安装MySQL

方法一:手动安装MySQL

1、把MySQL安装包拉到/opt目录下
2.安装环境依赖包

yum -y install \
gcc \
gcc-c++ \
ncurses \				#字符终端下图形互动功能的动态库
ncurses-devel \			#ncurses开发包
bison \					#语法分析器
cmake					#mysql需要用cmake编译安装
--------------------------------------------------------------------------------------
yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake

3.配置软件模块

解压下面两个压缩包
tar zxvf mysql-5.7.17.tar.gz
tar zxvf boost_1_59_0.tar.gz

cd /opt
mv boost_1_59_0 /usr/local/boost		#重命名

cd /opt/mysql-5.7.17/
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \		           #指定mysql的安装路径
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \        	   #指定mysql进程监听套接字文件(数据库连接文件)的存储路径
-DSYSCONFDIR=/etc \                                        #指定配置文件的存储路径
-DSYSTEMD_PID_DIR=/usr/local/mysql \                       #指定进程文件的存储路径
-DDEFAULT_CHARSET=utf8  \                                  #指定默认使用的字符集编码,如 utf8
-DDEFAULT_COLLATION=utf8_general_ci \	   		 		   #指定默认使用的字符集校对规则
-DWITH_EXTRA_CHARSETS=all \				  				   #指定支持其他字符集编码
-DWITH_INNOBASE_STORAGE_ENGINE=1 \            			   #安装INNOBASE存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \               		   #安装ARCHIVE存储引擎 
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \          			   #安装BLACKHOLE存储引擎 
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \       			       #安装FEDERATED存储引擎 
-DMYSQL_DATADIR=/usr/local/mysql/data \        		       #指定数据库文件的存储路径
-DWITH_BOOST=/usr/local/boost \        				       #指定boost的路径,若使用mysql-boost集成包安装则-DWITH_BOOST=boost
-DWITH_SYSTEMD=1									   	   #生成便于systemctl管理的文件

存储引擎选项:
MYISAM,MERGE,MEMORY,和CSV引擎是默认编译到服务器中,并不需要明确地安装。
静态编译一个存储引擎到服务器,使用-DWITH_engine_STORAGE_ENGINE= 1
可用的存储引擎值有:ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE (InnoDB), PARTITION (partitioning support), 和PERFSCHEMA (Performance Schema)

4.编译及安装

make && make install

5.创建mysql用户

useradd -M -s /sbin/nologin  mysql

6.修改mysql 配置文件

vim /etc/my.cnf								#删除原配置项,再重新添加下面内容
[client]									#客户端设置
port = 3306
socket=/usr/local/mysql/mysql.sock			

[mysqld]									#服务全局设置
user = mysql       							#设置管理用户
basedir=/usr/local/mysql					#指定数据库的安装目录
datadir=/usr/local/mysql/data				#指定数据库文件的存储路径
port = 3306									#指定端口
character-set-server=utf8					#设置服务器字符集编码格式为utf8
pid-file = /usr/local/mysql/mysqld.pid		#指定pid 进程文件路径
socket=/usr/local/mysql/mysql.sock			#指定数据库连接文件
bind-address = 0.0.0.0						#设置监听地址,0.0.0.0代表允许所有,如允许多个IP需空格隔开
skip-name-resolve							#禁用DNS解析
max_connections=2048						#设置mysql的最大连接数
default-storage-engine=INNODB				#指定默认存储引擎
max_allowed_packet=16M						#设置数据库接收的数据包大小的最大值
server-id = 1								#指定服务ID号

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

----------------------------------------------------------------------------------------------------------
sql_mode常用值如下:
NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常

STRICT_TRANS_TABLES
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制

NO_AUTO_CREATE_USER
禁止GRANT创建密码为空的用户

NO_AUTO_VALUE_ON_ZERO
mysql中的自增长列可以从0开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错

NO_ZERO_IN_DATE
不允许日期和月份为零

NO_ZERO_DATE
mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告

ERROR_FOR_DIVISION_BY_ZERO
在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MySQL返回NULL

PIPES_AS_CONCAT
将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似

ANSI_QUOTES
启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

7.更改mysql安装目录和配置文件的属主属组

chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf

8.设置路径环境变量

echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile	#把路径环境变量追加到/etc/profile中
source /etc/profile            #把/etc/profile激活

9.初始化数据库

cd /usr/local/mysql/bin/
./mysqld \
--initialize-insecure \				#生成初始化密码为空
--user=mysql \                      #指定管理用户
--basedir=/usr/local/mysql \        #指定数据库的安装目录
--datadir=/usr/local/mysql/data		#指定数据库文件的存储路径

10.添加mysqld系统服务

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/		
#用于systemctl服务管理
systemctl daemon-reload         #刷新识别     
systemctl start mysqld.service  #开启服务
systemctl enable mysqld         #开机自启动
netstat -anpt | grep 3306       #查看端口

11.修改mysql 的登录密码

mysqladmin -u root -p password "123456" 	#给root账号设置密码为abc123,提示输入的是原始密码(为空)

12.授权远程登录

mysql -u root -p
grant all privileges on *.* to 'root'@'%' identified by '123456';
#授予root用户可以在所有终端远程登录,使用的密码是123456,并对所有数据库和所有表有操作权限

show databases;			#查看当前已有的数据库
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值