目录
- 数据存取演变史
- 数据库软件应用史
- 数据库的本质
- 数据库的分类
- MySQL简介
数据存取演变史
一、文本文件
 文件路径可能不一致:C:/aaa.txt D:/aaa/a.txt
 数据格式也可能不一致:jason|123 sd$123
二、软件开发目录
 规定了数据文件的大致存储位置:db文件夹
 针对数据格式还是没有完全统一:比如统一json文件但是内部键值对不同
三、数据库服务
 统一了存取位置,也统一了数据格式(完全统一)
数据库软件应用史
一、单机游戏
 不同的计算机上的相同程,数据无法共享
 数据库服务全部在本地完成
二、网络游戏
 不同的计算机上的相同程序,数据可以共享
 数据库服务单独在网络架设(远程数据库服务)
数据库的本质
一、底层原理角度
 数据库是指:专门用于操作数据的进程
 eg:运行在内存中的代码
二、站在现实应用角度
 数据库是指:拥有操作界面的应用程序
 eg:用于操作进程的界面
三、在不做特殊说明的情况下
 数据库是指:数据库软件
 数据库软件:本质上是一款cs架构的应用程序
 也就是说理论上,每个程序员都可以编写数据库软件
数据库的分类
一、关系型数据库
1.数据的组织方式有明确的表结构
 ID name password
 ps:关系型数据库存取数据的方式可以看成是表格
2.表与表之间可以建立数据库层面的关系
 eg:用户表 房屋表
 ps:只要获取到用户表的一条数据,就可以获取到与之相关的其他表的数据
3.对应的软件
 MySQL、PostgreSQL、MariaDB、Oracle、sqlite、db2、sqlsever
| 软件 | 特点 | 
|---|---|
| MySQL | 开源、使用最广泛、数据库学习必学 | 
| PostgreSQL | 开源、支持二次开发 | 
| MariaDB | 开源、与MySQL是同一个作者,用法也极其相似 | 
| Oracle | 收费,安全性极高、主要用于银行及各大重要机关 | 
| sqlite | 小型数据库,主要用于本地测试(Django框架自带带该数据库) | 
二、非关系型数据库
1.数据的组织方式没有明确的表结构,是以k:v键值对的形式组织的
 {‘name’:’jason’}
 {‘username’:’kevin’,’pwd’:123}
2.数据之间无法直接建立数据库层面的关系
3.对应的软件
 redis、mongoDB、memcache
| 软件 | 特点 | 
|---|---|
| redis | 目前最火、使用频率最高的缓存型数据库 | 
| MongoDB | 稳定性数据库、最像关系型的非关系型、主要用于爬虫、大数据 | 
| memcache | 已经被redis淘汰了 | 
MySQL简介
一、前提
 虽然数据库软件各式各样,但是底层操作几乎都是一样的,学会一个其他的都可以快速上手
 学习了MySQL基本上就可以快速上手所有的关系型数据库,甚至是非关系型数据库
二、MySQL版本问题
虽然版本有区别,但是在操作上区别不大,主要体现在底层运作
| 版本 | 特点 | 
|---|---|
| 5.6X | 前几年使用频率最高的版本 | 
| 5.7X | 最近尝试迁移的版本(频率↑) | 
| 8.0X | 最新版,功能强大,但是线上环境几乎不用(本地用非常好用) | 
三、下载与安装
1.下载步骤
 1.1.访问官网https://www.mysql.com/
 1.2.点击DOWNLOADS

 1.3.点击GPL

 1.4.点击community server

 1.5.点击archives


 1.6.点击download

2.解压安装
 上述方式下载的压缩包里含有服务端和客户端,支持本地操作
3.主要文件介绍
| 文件 | 内容 | 
|---|---|
| bin文件夹 | mysqld.exe服务端 mysql.exe客户端 | 
| data文件夹 | 存取数据 | 
| my-default.ini | 默认配置文件 | 
四、基本使用
1.先启动服务器
 可能会报错:拷贝关键信息去百度
2.查找mysqld文件位置
 启动mysql
 cmd窗口就是服务端,不要关闭
3.再次开启新的cmd窗口
 输入mysql运行
 直接回车进入游客模式,功能很少
4.用户名密码登录
 myaql -u 用户名 -p 密码
 mysql默认管理员账户:
 用户名:root 密码:空
5.退出
 exit()
 quit
五、系统服务制作
1.如何解决每次都需要切换路径查找文件的缺陷
 添加环境变量

2.将mysql服务端制作成系统服务(随着计算机的开启而启动,关闭而关闭)
1.以管理员身份打开cmd窗口
2.执行系统服务命令
	mysql --install
3.启动服务端两种方式
	在服务里直接启动
    命令启动:net start mysql
'''
1.查看系统服务
	service.msc
2.关闭mysql服务端
	net stop mysql
3.移除系统服务
	先确保服务已经关闭
	执行移除命令:mysqld --remove
'''

六、密码相关操作
1.修改密码mysqladmin命令
通用方式:直接在cmd里写
mysqladmin -u用户名 -p原密码 password 新密码
# 第一次修改(初始用户名:root 初始密码:空)
mysqladmin -uroot -p password 123
偏门方法(有些版本无法使用):需要先登录
set password=PASSWORD(新密码);
2.忘记密码
直接重装/拷贝对应文件
先关闭服务端,然后以不需要校验用户身份的方式欺负,再修改,最后再安装正常方式启动
1.net stop mysql
2.mysqld --skip-grant-tables
3.mysql -uroot -p
4.updata mysql.user set password=password(123) where Host='localhost' and User='root';
5.net stop mysql
6.net start mysql
七、SQL与NoSQL
1.SQL:操作关系型数据库的语法
2.NoSQL:操作非关系型数据库的语法
ps:SQL有时候也用来表示关系型数据库,NoSQL也用来表示非关系型数据库
3.相关知识
3.1.数据库的服务端支持各种语言充当客户端
 eg:以MySQL服务端为例
 MySQL客户端、python代码编写的客户端、Java代码编写的客户端
3.2.为了能够兼容所有类型的客户端,有两种策略
 服务端兼容:不合理,消耗数据库服务端资源!!
 制定统一标准:SQL语句、NoSQL语句
八、数据库重要概念
 为了更好地理解,以类比来形容
 库 ==== 文件夹
 表 ==== 文件夹里的文件
 记录 ==== 文件里的一行行的数据
九、针对库的基本SQL语句
1.常识
SQL结束符:; 取消SQL语句的执行:/c
| 语句 | 功能 | 
|---|---|
| create database 库名; | 增库 | 
| show databases; show create database 库名; | 查库 | 
| alter database 库名 charset=’gbk’; | 改库 | 
| drop database 库名; | 删库 | 
| create table 表名(字段名 字段类型,字段名 字段类型) | 新建表 | 
| select * from mysql.user; | 查看user表里面的所有记录 | 
| show tables; | 查看所有表 | 
| show creat table 表名; describe 表名; desc 表名; | 查指定表 | 
| after table 旧表名 rename 新表名; | 改表名 | 
| drop table 表名; | 删表 | 
| insert into 表名 values(数据,数据); | 添加一条数据 | 
| insert into 表名 values(数据,数据),(数据,数据),(数据,数据); | 在同一个表添加多条数据 | 
| select * from 表名; | 查看所有字段 | 
| select 字段1,字段2 from 表名; ps:如果表中字段较多出现了错乱,结尾可以写/G | 查找指定字段 | 
| updata 表名 set 字段名=新数据 where 筛选条件; | 该记录数据 | 
| delete from 表名; | 删除表中所有数据 | 
| delete from 表名 where 筛选条件 | 按照条件删除数据 | 
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/bigdata/280515.html
