1、数据库初识
现在的世界,是大数据时代,得数据库者得天下,像很多岗位也是需要精通数据库,数据库是所有软件体系中最核心的存在:DBA
1.1、什么是数据库
数据库(DB,DataBase)
概念:是一个数据仓库,也就是一个软件,安装在操作系统(windows、Linux、mac...)之上!可以存储大量的数据(500万以下);
作用:存储数据,管理数据;
1.2、数据库分类
- 关系型数据库:(SQL)
- MySQL、Oracle、SQL server、DB2、SQLlite
- 通过表和表之间,行行和列之间的关系进行数据的存储。比如:学院信息表、考勤表...
- 非关系型数据库:(NoSQL)Not Only
- Redis、MongDB
- 对象存储,通过对象的自身的属性来决定
- DBMS(数据库管理系统)
- 数据库的管理软件,科学有效的管理我们的数据,维护和获取数据;
- MySQL就是一个数据库管理系统!
1.4、MySQL简介
MySQL是一个关系型数据库管理系统;
由瑞典MySQLAB公司出品,现属于Oracle公司旗下产品;
MySQL是最好的RDMS(Relational Database Management System,关系数据库管理系统)应用软件之一。开源的数据库软件!
体积小、速度快、总体拥有成本低,适用于中小型网站或者大型网站,集群!
官网:https://www.mysql.com
官网下载地址:https://dev.mysql.com/downloads/mysql/
安装建议:
1、尽量不要使用exe
2、尽可能使用压缩包安装;
安装MySQL,安装SQLyog并连接数据库!
2、操作数据库
操作数据库-->操作数据库中的表-->操作数据库中表的数据
MySQL关键字不区分大小写
2.1、操作数据库
1、创建数据库
CREATE DATABASE IF NOT EXISTS westos;
2、删除数据库
DROP DATABASE IF EXISTS westos;
3、使用数据库
sql -- tab键的上面,如果你的表名或者字段名是一个特殊字符,就需要`` USE `school` 4、查看数据库
sql
SHOW DATABSES --查看所有的数据库
```
2.2、数据库的列类型
数值
数值名称 | 数据说明 | 字节数 |
---|---|---|
tinyint | 十分小的数据 | 1个字节 |
smallint | 较小的数据 | 2个字节 |
mediumint | 中等大小的数据 | 3个字节 |
int | 标准的数据 | 4个字节 (常用int) |
bight | 较大的整数 | 4个字节 |
float | 浮点数 | 4个字节 |
double | 浮点数 | 8个字节(精度问题) |
decimal | 字符串形式的浮点数 | 金融计数的时候,一般都是使用decimal |
字符串
名称 | 数据说明 | 大小 |
---|---|---|
char | 字符串固定大小 | 0-255 |
varchar | 可变字符串 | 0-65535(常用) |
tinytext | 微型文本 | 2^8-1 |
text | 文本串 | 2^16-1 保存文本大小 |
时间日期
名称 | 格式 | 说明 |
---|---|---|
date | YYYY-MM-DD | 日期格式 |
time | HH:mm:ss | 时间格式 |
datetime | YYYY-MM-DD HH:mm:ss | 最常用的时间格式 |
timestamp | 时间戳 | 1970.1.1到现在的毫秒数! |
year | 年份表示 |
null
- 没有值
注意:不要使用null进行运算,结果为NULL
2.3、数据库的字段属性
unsigned:
- 无符号的整数
- 声明了该列不能声明为负数
zerofill:
- 0填充的
- 不足的位数,使用0填充;比如int(3):5->005
自增:
- 通常理解为自增,自动在上一条记录的基础上+1
- 通常用来设计唯一的主键,必须是整数类型
- 可以自定义设计主键自增的起始值和步长
默认
- 设置默认的值
- 比如设置一个sex,默认值为男,如果不指定列的值,则会有默认的值!
/* 每一个表,都必须存在以下五个字段!表示一个记录存在意义!
id 主键
`version` 乐观锁
is_delete 伪删除
gmt_create 创建时间
gmt_update 修改时间
*/
2.4、创建数据库表
-- 目标 : 创建一个school数据库
-- 创建学生表(列,字段) 使用SQL 创建
-- 学号int ,登录密码varchar(20) ,姓名VARCHAR(30) ,性别varchar(2),出生日期(datatime),家庭住 址,email
-- 注意点,使用英文 () , 表的名称 和 字段 尽量使用 `` 括起来
-- AUTO_INCREMENT 自增 -- 字符串使用 单引号括起来!
-- 所有的语句后面加 , (英文的),后一个不用加
-- PRIMARY KEY 主键,一般一个表只有一个唯一的主键!
CREATE TABLE IF NOT EXISTS `student` (
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT'匿名' COMMENT '名字',
`pwd` VARCHAR(20) NOT NULL DEFAULT'123456' COMMENT '密码',
`sex` VARCHAR(2) NOT NULL DEFAULT'男' COMMENT '性别',
`birthdate` DATETIME DEFAULT NULL COMMENT '出生日期',
`address` VARBINARY(20) DEFAULT NULL COMMENT '地址',
`email` VARBINARY(20) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
格式
CREATE TABLE [IF NOT EXISTS] `表名`(
'字段名' 列类型 [属性] [索引] [注释],
'字段名' 列类型 [属性] [索引] [注释],
...... ,
'字段名' 列类型 [属性] [索引] [注释]
)[表类型][字符集设置][注释]
常用命令
SHOW CREATE DATABASE school -- 查看创建数据库的语句
SHOW CREATE TABLE student -- 查看student数据表的定义语句
DESC student -- 显示表的结构
2.5、数据表的类型
-- 关于数据库引擎
/*
INNODB 默认使用
MYISAM 早些年使用的
*/
- | MYSIAM | INNODB |
---|---|---|
事务支持 | 不支持 | 支持 |
数据行锁定 | 不支持 | 支持 |
外键约束 | 不支持 | 支持 |
全文索引 | 支持 | 不支持 |
表空间的大小 | 较小 | 较大,约为2倍 |
常规使用操作:
- MYISAM 节约空间,速度较快
- INNODB 安全性高,事务的处理,对标对用户操作
在物理空间存在的位置
所有的数据库文件都存在data目录下,一个文件夹就对应一个数据库
本质上还是文件的存储!
MySQL引擎在物理文件上的区别
- INNODB在数据表中只有一个*.frm文件,以及上级目录下的ibdata1文件
- MYISAM对应文件
- *.frm 表结构的定义文件
- *.MYD 数据文件(data)
- *.MYI 所有文件(index)
设置数据库表字符集编码
CHARSET = =utf8
不设置的画,会是MySQL默认的字符集编码(不支持中文)
MySQL的默认编码是Latin1,不支持中文
在MySQL文件夹中的my.ini文件中配置默认的编码
character-set-server=utf8
2.6、修改删除表
修改
-- 修改表名:alter rable 旧表名 rename as 新表名
ALTER TABLE student RENAME AS person;
-- 增加表的字段:ALTER TABLE person ADD 字段名 类属性
ALTER TABLE person ADD age INT(3);
-- 修改表的字段
-- ALTER TABLE person CHANGE 旧名 新名 列属性[]
ALTER TABLE person CHANGE age age1 INT(1);
-- 删除表的字段 ALTER TABLE 表名 DROP 字段名
ALTER TABLE person DROP age1
删除
-- 删除表(如果表存在)
DROP TABLE IF EXISTS student
注意点:
字段名
,要这样写- 注释 单行-- 多行/**/
- sql关键字大小写不敏感,建议大写小写
- 所有的符号全部由英文符号!