MySQL数据库
数据库简介
数据存储
- 结绳记事——>甲骨文——>图书
- 传统数据记录方式的缺点:不易保存;备份困难;查找不便
- 现代化手段:文件
(1)使用简单,例如python中的open可以打开文件,用read/write进行读写,close关闭文件;
(2)对于数据容量比较大的数据,增删查找比较困难,且性能较差;
(3)不易扩展。 - 现代化手段:数据库
(1)持久化存储(一种特殊文件,存储在硬盘上);
(2)读写速度极高;
(3)保证数据的有效性;
(4)对程序支持性比较好,容易扩展。
数据库
数据库就是一种特殊的文件,其中存储着需要的数据(需要特数软件进行操作)。
关系型数据库核心元素(表之间存在关系):
- 数据库中,每行称为一个记录;
- 每列称为一个字段(能够唯一标记记录的字段称为主键,如id);
- 数据表是数据行的集合,数据库是数据表的集合。
类比Excel,每个数据库中可以有多个数据表:
RDBMS
- 全称:Relational Database Management System(关系型数据库管理系统)
- 当前主要使用两种类型的数据库:关系型数据库和非关系型数据库。所谓的关系型数据库RDBMS,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。
- 关系型数据库的主要产品:oracle、mysql、ms sql server、sqlite
- RDBMS和数据库的关系:
C/S架构
SQL
SQL是结构化查询语言(Structured Query Language),是一种来操作RDBMS的数据库语言,当前的关系型数据库都支持使用SQL语言进行操作,SQL语言不区分大小写。
MySQL简介
- MySQL是一个关系型数据库管理系统。
- 使用C和C++编写,并使用了多种编译语言进行测试,保证源代码的可移植性;
- 支持多种操作系统,如linux、windows等;
- 支持多线程,充分利用CPU资源;
- 开源免费。
MySQL安装
- 安装服务器端
sudo apt-get install mysql-server - 启动服务
sudo service mysql start - 停止服务
sudo service mysql stop - 重启服务
sudo service mysql restart - 配置文件目录为/tec/mysql/mysql.cnf
- 图形化界面客户端navicat
数据完整性
一个数据库就是一个完整的业务单元,可以包含多张表,数据被存储在表中;在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候,为表增加一些强制性的验证,包括数据字段的类型、约束。
数据类型
使用数据类型的原则:够用就行,尽量使用取值范围小的,而不用大的,这样可以更多的节省存储空间。
常用的数据类型如下:
- 整数:int、bit(二进制)
- 小数:decimal
- 字符串:varchar、char
- 日期时间:date、time、datetime
- 枚举类型:enum
约束
数据库操作
- 链接数据库
mysql -uroot -p
mysql -uroot -pmysql # -u后是用户名,-p后是密码
- 退出数据库
exit
quit
ctrl+d
sql语句最后需要以分号结尾
3. 显示数据库版本
select version(); # 以分号结尾!
- 显示时间
select now();
- 查看所有数据库
show databases;
- 创建数据库
create database python01; # 默认拉丁文
create database python02 charset=utf8; # 支持中文
- 查看创建数据库
show create database python05;
- 查看当前使用的数据库
select database();
- 使用数据库
use python01;
- 删除数据库
drop database python01;
数据表的基本操作
- 查看当前数据库中所有表
show tables;
- 创建数据表
create table 数据表名字 (字段 类型 约束[, 字段 类型 约束]);
# 常用约束:
# auto_increment 表示自动增长
# not null 表示不能为空
# primary key 表示主键
# default 默认值
use python01;
create table students(
id int unsigned not null auto_increment primary key,
name varchar(30),
age tinyint unsigned default 0,
high decimal(5,2),
gender enum("男", "女", "中性", "保密") default "保密",
cls_id int unsigned
);
- 修改表–添加字段
alter table students add birthday datetime;
- 修改表–修改字段
alter table students modify birthday date; # 不重命名
alter table students change birthday birth date default "2020-01-01" ; # 重命名
- 修改表–删除字段
alter table students drop high;
- 删除表
drop table students;
- 查看表结构信息
desc students;
数据表中数据的增删改查(curd)
curd解释:创建(Create)、更新(Update)、读取(Retrieve)、删除(Delete)
1. 增加数据
说明:
(1)主键列自动增长,但是在一个记录(一整行,即全部列)插入时需要占位,通常使用0或者default或者null来占位,插入成功后以实际数据为准;
(2)全记录插入:值的顺序与表中字段的顺序对应;
(3)部分字段插入:值的顺序与给出的列顺序对应;
(4)枚举中的内容可以用数字代替,从1开始。
insert into students values(0, "xiaoming", 18, "女", 1, "1995-01-01");
insert into students values(default, "xiaoming", 18, "女", 1, "1995-01-01");
insert into students values(null, "xiaoming", 18, "女", 1, "1995-01-01");
insert into students values(0, "xiaoming", 18, 1, 1, "1995-01-01");
insert into students (name, gender) values( "xiaoming", "女");
insert into students (name, gender) values( "xiaoming", "女"),("xiaohong", "男");
2. 修改数据
update students set gender=1;
update students set gender=1 where name="xiaoming";
update students set age=2, gender=1 where id=3;
3. 查询数据
(1)查询所有列
select * from students;
select * from students where id>3;
(2)查询指定列
select name,gender from students;
可以使用as为列或者表指定别名
select name as 姓名,gender as 性别 from students;
还可改变字段的顺序
select id as 序号,gender as 性别,name as 姓名 from students;
4. 删除数据
(1)物理删除
delete from students;
delete from students where id=3;
(2)逻辑删除(用一个字段来表示是否删除)
alter table students add is_delete bit default 0;