MySQL 数据类型和约束(外键是重点

2019-11-09 09:30 来源:未知

总结:

数据类型

     1,not null 不能插入空,不设置可空

1. 数字(默认都是由符号,宽度表示的是显示宽度,与存储无关).tinyint 括号里指定宽度

七位2进制数最大数就是2**7 -1=127 最小是-128

验证:

create tabel t1(id tinyint)

create tabe t2(id int)

浮点数

float

double

decimal

测试

create table t2(salary float)

float(6,2) 第一参数,代表宽度. 第二个参数代表小数点后面的位数.

      2,unique  单列唯一

2.字符串类型

char 与 varchar

    create table department(name char(10) unique);         创建方式一

char 类型:定长,浪费空间,存取速度快

    create table department( unique(name));                    创建方式二

不够就用空格补,
字符长度范围: 0 ~ 255

create table t6(name char(4));

insert into t6('aigen')#存不进去

insert into t6('能不能存')  #能存进去


####varchar:变长,精准,节省空间,存取速度慢
字符长度范围:0 ~ 65535



**char 和 varchar 区别:  char(5), 存不够5个,用空格补齐.     varhar(5), 你是几个它就存几个.**

char_length : 查看的是字符的长度
'abc'和'你好啊' 都是三个字符.

但是前面是3个字节,后面 char(5)的length话,是11个字节.

length : 查看字节.


一个英文字符算一个 bytes

一个中文字符算3个 bytes

insert into t7 values('abc','abc ')

select * from t6 where y= 'abc   '

 

3.日期类型

create table student(
id int,
name char(5),
born_date date,#'2017-09-06',
born_year year, #'2017',
res_time datetime, #'2017-09-06 10:53:23'
class_time time  #'10:53:23'
);


insert into student values(1,'ff',now(),now(),now(),now());

insert into student values(2,'ff2',,now(),now(),now());

    联合唯一: unique(name)    unique(id)  两个都不同才可插入

4.枚举和集合

enum 枚举: 规定一个范围,可有多个值,但是为该字段传值时,只能取规定范围内的一个值.

set 集合: 规定一个范围,但是为该字段传值时,能取规定范围中的一个值或多个值.

create table person(
id int primary key auto_increment,
name char(10),
sex enum('male','female'),
hobbies set('music','read','swimming','learning English')
);

insert into person (name,sex enum,hobbies set) values('ff','male','read,swimming');

              组合唯一:unique(name,id)   有一个不同即可插入

约束

   3,主键   primary key = not null unique

1.not null和 default...

create table student( id int primary key auto_increment, name char(5), sex enum('male','female') not null default 'femela' );

insert into student (name) values('egon');

    作用:唯一标识,查询优化.

2.unique 唯一

主键就是不为空且唯一.

     复合主键:  有一个不同即可.

2.1单列唯一

create table teacher( id int not null unique, name char(10));

insert into teacher values(1,'go');

insert table teacher values(1,'alex');

    注意    :   多列主键有问题

2.2多列唯一

create table service( id int primary key autoincrement, name char(10), host char(15), port int, /#constraint hostport unique(host,port) );

  4,auto_increment(自增长)

2.3偏移量: autoincremenoffset

create table dep( id int primary key autoincrement, name char(10) )autoincrement=10;

insert into dep(name) values ('it'),('hr');

**         # 步长auto_increment_increment,默认为1
         # 起始的偏移量auto_increment_offset, 默认是1

2.4步长 autoincrementincrement

create table dep( id int primary key auto_increment, name char(10) );

insert into dep(name) values ('it'),('hr');

set session autoincrementincrement=10;#会话级,只对当前回话有效.

set global autoincrementincrement=2;#全局,对所有的会话都有效.

autoincrementoffset#偏移量(也就是从几开始) + autoincrementincrement#步长

set session autoincrementoffset=5; set session autoincrementincrement=2;

!!!如果偏移量的值大于步长的值,则偏移量的值会被忽略!

set session autoincrementoffset=2;

set session autoincrementincrement=3;

         # 设置步长 为会话设置,只在本次连接中有效
          set session auto_increment_increment=5;

2.5show variables like '%auto_in%'; #查看变量

primary key字段的值不为空且唯一... 一个表中可以,一般都加在 id 字段上. ```

         #全局设置步长 都有效。
         set global auto_increment_increment=5;

3.foreign key(附练习) #外键

        # 设置起始偏移量
         set global  auto_increment_offset=3;**

关联

清空表区分delete和truncate的区别:

关联 自己的字段 references(关联) 要关联的地方(字段) dep(id);

foreign key (dep_id) references dep(id)

如果想指定名字 constraint fk_depid_id

先建被关联的表,先建被关联的表,要保证被关联的那个表示不为空且唯一的表. 关联: 多的关联那个1, 多本书关联一个出版社,那么被关联的就是出版社.

create table dep(

id int,

name varchar(50),

comment varchar(100)

);

然后建需要关联的表: create into emp_info(

id int primary key auto_increment,

name varchar(20),

dep_id int,

foreign key(dep_id) references dep(id)

on delete cascade

on update cascade

);

delete from dep where id=2;

update dep set id = 301 where id=3;

以上就是一条记录对应另一个表的多条记录.

先给被关联的表插入初始化记录

一个作者可以属于多个出版社

一本书只能属于一个出版社

书(两本书的信息)

出版社(1设,2设)

多本书属于一个出版社,那么就是多对1, 1就是需要被关联的那个表

书这张表 foreign key了出版社那张表的 id 字段.

delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

出版社是需要被关联的那个1.
create table press(
id int primary key auto_increment,
name varchar(20) not null
);


create table book(
id int primary key auto_increment,
name varchar(20),
press_id int not null,
foreign key(press_id) references press(id)
on delete cascade
on update cascade


insert into press(name) values('人出版社'),('民出版社');

insert into book(name,press_id) values ('pyjy',1),('ons',2),('go',2),('python',2),('java',3);



一个作者可以写多本书,一本书可以有多个作者,他俩相互对应

create table author(
id int primary key  auto_increment,
name varchar(20)
);


create table book2author(
id int not null unique auto_increment,
book_id int not null,
author_id int not null,
foreign key(book_id) references book(id)
on delete cascade
on update cascade,
foreign key(author_id) references author(id)
on delete cascade
on update cascade,

primary key (book_id,author_id)
);

insert into author(name) values('ff'),('jm'),('by');

insert into book2author(book_id,author_id) values(1,1),
(1,2),
(1,3),
(1,4),
(1,5),
(1,6),
(2,1),
(2,6),
(3,4),
(3,5),
(3,6),
(4,1);


每个作者与自己的代表作如下
1 ff: 
      1 九阳神功
      2 九阴真经
      3 九阴白骨爪
      4 独孤九剑
      5 降龙十巴掌
      6 葵花宝典

2 jm: 
      1 九阳神功
      6 葵花宝典

3 by:
      4 独孤6剑
      5 降龙7巴掌
      6 玫瑰花花宝典

truncate table t1;数据量大,删除速度比上一条快,且直接从零开始。

 

  5,foreign key:

TAG标签:
版权声明:本文由澳门新浦金网站发布于数据库,转载请注明出处:MySQL 数据类型和约束(外键是重点