目录
- 数据存取演变史
- 数据库软件应用史
- 数据库的本质
- 数据库的分类
- 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 筛选条件 | 按照条件删除数据 |