文件路径可能不一致:C:\aaa.txt D:\aaa\a.txt
数据格式也可能不一致:jason|123 sd$123
规定了数据文件的大致存储位置:db文件夹
针对数据格式还是没有完全统一:比如统一json文件但是内部键值对不同
统一了存取位置,也统一了数据格式(完全统一)
不同的计算机上的相同程,数据无法共享
数据库服务全部在本地完成
不同的计算机上的相同程序,数据可以共享
数据库服务单独在网络架设(远程数据库服务)
数据库是指:专门用于操作数据的进程
eg:运行在内存中的代码
数据库是指:拥有操作界面的应用程序
eg:用于操作进程的界面
数据库是指:数据库软件
数据库软件:本质上是一款cs架构的应用程序
也就是说理论上,每个程序员都可以编写数据库软件
ID name password
ps:关系型数据库存取数据的方式可以看成是表格
eg:用户表 房屋表
ps:只要获取到用户表的一条数据,就可以获取到与之相关的其他表的数据
MySQL、PostgreSQL、MariaDB、Oracle、sqlite、db2、sqlsever
软件 | 特点 |
---|---|
MySQL | 开源、使用最广泛、数据库学习必学 |
PostgreSQL | 开源、支持二次开发 |
MariaDB | 开源、与MySQL是同一个作者,用法也极其相似 |
Oracle | 收费,安全性极高、主要用于银行及各大重要机关 |
sqlite | 小型数据库,主要用于本地测试(Django框架自带带该数据库) |
{'name':'jason'}
{'username':'kevin','pwd':123}
redis、mongoDB、memcache
软件 | 特点 |
---|---|
redis | 目前最火、使用频率最高的缓存型数据库 |
MongoDB | 稳定性数据库、最像关系型的非关系型、主要用于爬虫、大数据 |
memcache | 已经被redis淘汰了 |
虽然数据库软件各式各样,但是底层操作几乎都是一样的,学会一个其他的都可以快速上手
学习了MySQL基本上就可以快速上手所有的关系型数据库,甚至是非关系型数据库
虽然版本有区别,但是在操作上区别不大,主要体现在底层运作
版本 | 特点 |
---|---|
5.6X | 前几年使用频率最高的版本 |
5.7X | 最近尝试迁移的版本(频率↑) |
8.0X | 最新版,功能强大,但是线上环境几乎不用(本地用非常好用) |
1.1.访问官网https://www.mysql.com/
1.2.点击DOWNLOADS
1.3.点击GPL
1.4.点击community server
1.5.点击archives
1.6.点击download
上述方式下载的压缩包里含有服务端和客户端,支持本地操作
文件 | 内容 |
---|---|
bin文件夹 | mysqld.exe服务端 mysql.exe客户端 |
data文件夹 | 存取数据 |
my-default.ini | 默认配置文件 |
可能会报错:拷贝关键信息去百度
启动mysql
cmd窗口就是服务端,不要关闭
输入mysql运行
直接回车进入游客模式,功能很少
myaql -u 用户名 -p 密码
mysql默认管理员账户:
用户名:root 密码:空
exit()
quit
添加环境变量
1.以管理员身份打开cmd窗口 2.执行系统服务命令 mysql --install 3.启动服务端两种方式 在服务里直接启动 命令启动:net start mysql ''' 1.查看系统服务 service.msc 2.关闭mysql服务端 net stop mysql 3.移除系统服务 先确保服务已经关闭 执行移除命令:mysqld --remove '''
mysqladmin -u用户名 -p原密码 password 新密码 # 第一次修改(初始用户名:root 初始密码:空) mysqladmin -uroot -p password 123
set password=PASSWORD(新密码);
直接重装/拷贝对应文件
先关闭服务端,然后以不需要校验用户身份的方式欺负,再修改,最后再安装正常方式启动
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
ps:SQL有时候也用来表示关系型数据库,NoSQL也用来表示非关系型数据库
eg:以MySQL服务端为例
MySQL客户端、python代码编写的客户端、Java代码编写的客户端
服务端兼容:不合理,消耗数据库服务端资源!!
制定统一标准:SQL语句、NoSQL语句
为了更好地理解,以类比来形容
库 ==== 文件夹
表 ==== 文件夹里的文件
记录 ==== 文件里的一行行的数据
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 筛选条件 | 按照条件删除数据 |