博客园

1、数据库的基本知识

1、mysql数据库的安装配置

2、存储引擎及库相关操作

3、创建表的完整语法

4、基本的数据类型

5、约束条件

6、表之间的关系

🔧🔧1、mysql安装配置🔧🔧

https://www.cnblogs.com/linhaifeng/articles/7126847.html#_label6

💎💎数据库基本概念💎💎

数据库管理软件: 本质就是个C/S架构的套接字程序

关系型数据库管理软件:mysql、oracle

非关系型数据库管理软件:k:v----redis\mecache\mongodb

sql语句: 套接字管理软件的作者为使用者规定的命令规范

数据库核心概念

记录----文件中的一条信息、一行内容
表----一个文件库----文件夹
数据库管理软件DBMS----套接字程序:mysqld、mysql
数据库服务器----安装有DBMS服务器的计算机

🚂🚂2、存储引擎🚂🚂

相当于表的类型----详:日常生活中文件格式有很多种,并且针对不同的文件格式会有不同存储方式和处理机制针对不同的数据应该有对应的不同的处理机制来存储

#存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。
#因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)

mysql主要存储引擎

innodb 安全 常用 支持---事物、行级锁、外键

是5.5版本后默认的存储引擎

    myisam 速度快
        是5.5版本之前的
    memory
        内存引擎(数据全部存放在内存中)断电数据丢失
    blackhole
        无论存什么都立刻消失(黑洞)
查看所有数据库的存储引擎用:show engines
修改表的存储引擎用:reate table t1(id int)engine=myisam
存数据:insert into 表名 values(1)
3、创建表的完整语法
create table 表名(
    字段名1 类型(宽度) 约束条件,
    字段名2 类型(宽度) 约束条件,
    字段名3 类型(宽度) 约束条件,
)

# 注意 在同一张表中字段名不能重复
宽度和约束条件是可选的(可写可不写)而字段名和字段类是必须的
约束条件写的话 也支持写多个
字段名1 类型(宽度)约束条件1 约束条件2,,
create table t3(id int);  没有int 会报错 
# 查看 desc t3
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | YES  |     | NULL    |       |

create table t4(
    id int,
    name char,  最后一行不能有 , 否则会报错 
);

desc t4;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | YES  |     | NULL    |       |
| name  | char(1) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+

 宽度 
    一般情况下是对存储数据的限制
    create table t5(name char);  默认宽度 1
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| naem  | char(1) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
若 insert into t5 values('json')  非要存5个
5.6 会只存一个人 j  5.7 会报错 默认开启了严格模式
可插入关键字null
insert into t5 values(null); 相当于python中的None

# 约束条件
create table t6(id int,name char not null);  不允许插空
# 宽度和约束条件的关系
    宽度是用来限制数据的存储
    约束条件是在宽度的基础上增加额外的约束  
4、数据库的基本数据类型
基本数据类型
    整型
        TINYINT SMALLINT MEDUIMINT INT BIGINT
    作用
        年龄 等级 班级 号码

    TINYINT
        是否有符号
        超出会如何
        create table t7(id tinyint);
        desc t7;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| id    | tinyint(4) | YES  |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
    insert into t7 values(-129),(256); 5.7报错
    最大可接受值 -128,127
    # 约束条件之 unsigned 无符号
create table t8(id tinyint unsigned);
+-------+---------------------+------+-----+---------+-------+
| Field | Type                | Null | Key | Default | Extra |
+-------+---------------------+------+-----+---------+-------+
| id    | tinyint(3) unsigned | YES  |     | NULL    |       |
+-------+---------------------+------+-----+---------+-------+
            无符号 0 - 255

int 默认也有符号
# 针对整型 括号内的宽度是干嘛的
create table t9(id int(8));

#  整型int(8) 里面的数字8 不是标识限制位数 而是显示长度
id int(8)
    如果数字没有超出8位 那么默认用 空格 填充到8位
    如果超出了8 位 那么有几位存几位 但是仍遵守最大值
+-----------+
| id        |
+-----------+
| 123456789 |
|         9 |
+-----------+

create table t10(id int(8) unsigned zerofill)
#  用 0 填充
insert into t10 values(7);
select * from t10;
+----------+
| id       |
+----------+
| 00000007 |
+----------+
'''

# 总结 针对整型,括号内无需指定宽度,默认足够指定

# 查看严格模式命令
#  show variables like "%mode";  模糊匹配 关键字like
#  % 匹配任意多个字符   _ 匹配任意单个字符
'''
5.6 版本修改严格模式
    set session  只在当前窗口有效
    set global 全局有效
    
    set global sql_mode = 'STRICT_TRANS_TABLES';
'''

'''
浮点型
    FLOAT DOUBLE DECIMAL
# 存储限制
    float(255,30) 总共255位 小数部分30位
    double(255,30)
    decimal(65,30)
    
精确度不一样
    create table c1(id float(255,30);
    create table c2(id double(255,30);
    create table c3(id decimal(65,30);
    精确度 float<double<decimal
'''

'''
字符类型
    char
        定长
        char(4) 存储数据超过4个直接报错,不够四个字符 空格 补全
    varchar
        变长
        varchar(4) 超出报错  不够有几个存几个
create table a1(name char(4));
create table a2(name,varchar(4));
insert into a1 values('a');
# 小方法 char_length 统计字段长度
select char_length(name) from a1;

首先可以肯定的是 char 硬盘上 存的绝对是真正的数据 带空格的
但是在显示的时候MySql会自动将多余的空格删除

char 与 varchar对比
char
    缺点:浪费空间
    优点:存取都很监简单,直接按照固定的字符存取数据即可
varchar
    缺点: 存取麻烦
    优点:节省空间
    存的时候要制作报头
    取的时候也需要先读取报头 之后才可读取真实数据
    
以前基本都有char  现在用varchar也很多

'''

# 时间类型
'''
date : 年月日
datetime: 年月日时分秒
time: 时分秒

create table student(
    id int,
    name varchar(16),
    born_year yrar,
    birth date,
    study_time time.
    reg_time datetime
);
insert into student values(1,'egon','1800','1880-11-11','11:11:11','2020-11-11 11:11:11');
了解即可 
'''

# 枚举和集合类型
'''
枚举(enum)
    多选一
集合(set)
    多选多
使用
create table user(
    id int,
    name char(16),
    gender enum('male','female','others'),
    hobby set('read','shop','sing')
    );
insert into user values(1,'json','male','read');

insert into user values(2,'liu','male','生蚝');
# 枚举字段在存数据的时候只能 从枚举里面选择一个存储
# 集合可以值写一个 但是不能写没有的 

⛓⛓5、约束条件⛓⛓

# unique 唯一
'''
单列唯一
create table t3(`
    id int unique    # id 唯一不能重复
    name char(16)
    );

联合唯一
    ip 和 port
    id  ip  port
    1   1   2
    2   2   1
单个可以重复 但是加载一起必须是唯一的
create table t4(
    id int,
    ip char(16)
    port int,
    unique(ip,port)
    );
insert into t4 values(1,'127.0.0.1'.8080)
'''

# primary key主键
'''
1、单单从约束效果上来看primary key 等价于not null + unique
非空且唯一

create table t5(id int primary key);
insert into t5 values(null);  报错 不能为空
insert into t5 values(1),(2);
insert into t5 values(1),(1); 报错 不唯一

2、它除了有约束效果之外,它还是innodb 存储引擎组织数据的依据
innodb存储引擎在创建表的时候 必须要有primary key
因为类似书的目录 能够帮助提示查询效率并且也是建表的依据

# 1)一张表中有且只有一个主键,如果你没有设置主键 那么会从上往下搜索直到遇到一个非空且唯一的字段将它自动升级为主键
create table t2(
    id int,
    name char(16),
    age int not null unique,
    addr char(32) not null unique
    );
# 2)如果表中没有主键也没有其他任何的非空且唯一字段 那么innodb会
,隐藏意味着无法使用 无法提示查询速度 
# 3) 一张表中通常都应该有一个主键字段 并且通常将id 字段作为主键
# 单个字段主键
create table t3(
    id int primary key,
    name char(16)
    );
# 联合主键(多个字段联合起来作为表的主键,本质没有变化 还是一个主键
    以后我们在创建表的时候id字段一定要加primary key
    
'''
# auto_increment 自增
# 当编号特别多的时候 人为的去维护太麻烦
'''
create table t4(
    id int primary key auto_increment,
    name char(16)
    );
    insert into t4(name) values('json'),('egon'),('lili');

# 注意 auto_increment 通常都是加载主键上的 不能给普通字段加
    
'''
# 以后在创建表的id(数据的唯一标识id uis sid)字段的时候
# id int primary key auto_increment
# 补充
# delete from 在删除表中数据的时候 主键的自增不会停止
#  可用 truncate t1 清空表数据并 重置主键 id

🌴🌴6、表的关系🌴🌴

表的关系建立需要用到外键: foreign key

1)一对多--外键字在多的一方
级联更新 级联删除
create table dep(
    id int primary key auto_increment,
    dep_name char(16),
    dep_desc char(32)
    );

create table emp(
    id int primary key auto_increment,
    name char(16),
    gender enum('male','female','others') default 'male',
    dep_id int,
    foreign key(dep_id) references dep(id) 
    on update cascade   同步更新 
    on delete cascade   同步删除
    );
2)多对多--自己开设第三张存储
create table book(
    id int primary key auto_increment,
    title varchar(32),
    price int
    );
create table author(
    id int primary key auto_increment,
    name varchar(16),
    age int
    );

create table book2author(
    id int primary key auth_increment,
    author_id int,
    book_id int,
    foreign key(author_id) references author(id) 
    on update cascade   同步更新 
    on delete cascade,   同步删除
    foreign key(book_id) references book(id) 
    on update cascade   同步更新 
    on delete cascade   同步删除
    );
3)一对一--`外键字段建在任意一方都可以 但是推荐建在查询频率比较高的表中`
create table authordetail(
    id int primary key auto_increment,
    phone int,
    addr varchar(64)
    );

create table author(
    id int primary key auth_increment,
    name varchar(32),
    age int,
    authordetail_id int unique
    foreign key(authordetail_id) references authordetail(id) 
    on update cascade   同步更新 
    on delete cascade   同步删除
    ); 
posted @ 2021-02-22 15:36  小刘学python  阅读(301)  评论(0编辑  收藏  举报