mysql表结构修改、约束(二)

知识要点:

  1. 表结构操作
  2. 非空约束
  3. 唯一约束
  4. 主键约束
  5. 自增长
  6. 默认约束

表结构操作 ( alter table)

create table tb1(
    id int,
    name char(4)
);
#修改表名 
alter table `tb1` rename `tb2` #将表tb1修改为tb2

#修改列名(字段名)change 改列名和数据类型
alter table `tb1` change `age` `sex` char(4); #将age字段修改为sex;

#修改数据类型 modify 改列的数据类型 (属性)
alter table tb1 modify `age` varchar(20); #修改age数据类型为varchar(20)

#修改已经存在字段的类型
alter table tb1 modify age char(4)  #把age字段修改成char类型;


#修改表结构,增加字段 年龄
alter table tb1 add age int first; #增加年级字段到第一列;
alter table tb1 add age int after id;#在id后面增加一个字段age;
#添加多列
alter table `tb1`
add `aa` int,
add `bb` int,
add `cc` int;


#删除数据表中的列
alter table tb1 drop age ; #删除年龄字段;
#删除多列
alter table `tb1`
drop `bb`,
drop `cc`;
                        
#修改字段的相对位置
ALTER TABLE  test MODIFY name1 int first|after name2;

约束条件

约束类型: 默认 非空 唯一 自增长 主键 外键
关键字: default not null unique key auto_increment primary key foreign

默认约束 (default)

初始值设置,插入记录时,如果没有明确为字段赋值,则自动赋予默认值。

#例:
mysql> create table tb6(
    -> id int primary key auto_increment,
    -> name varchar(20) not null,
    -> age int not null default 18
    -> );
mysql> desc tb6;
mysql> insert into tb6(name) values('张三'),('李四'),('王五');
mysql> select * from tb6;
删除default
mysql> alter table tb6
    -> modify age int [not null]; --这种方法会将非空约束也删除了,因为modify是整体修改数据类型,以及其他特性;
mysql> desc tb6;

第二种方法

mysql> alter table tb6 
    -> alter age drop default; ----指定干掉default,不会删除非空约束;
增加default
mysql> alter table tb6 
    -> modify age int default 20;
mysql> desc tb6;
#(2)
mysql> alter table tb6
    -> alter age set default 21;

非空约束

NULL 字段值可以为空;
NOT NULL 字段值不能为空;

create table tb1(
    id int,     
    name varchar(20) not null  #非空约束字段,insert的时候,必须添加字段,不能省略
);
insert into tb1 (id) value(1);      #报错,name设置了非空约束,一定要添加值
insert into tb1 (id, name) value(1, '');    #可以插入空字符, 空字符不等于null

注意: 在mysql 里面,空字符'' 不等于null

添加非空约束 (必须这个字段,没有NULL值)
mysql> alter table tb1
    -> modify id int not null;--记得类型别丢了,否则报错,modify本身就有修改数据类型之意;
取消非空约束
mysql> alter table tb1
    -> modify id int ;

唯一约束 (unique key)

确保字段中的值的唯一unique key

例:
mysql> create table tb2(
    -> id int not null unique key,--如果表里面没有定义主键,则第一个出现不为空且唯一性的当做主键;  
    -> name varchar(20) not null
    -> );
    
mysql> insert into tb2 value(1,'张三');

mysql> insert into tb2 value(1,'张三');  # 报错,违反唯一约束
    
#添加唯一约束
mysql> ALTER TABLE `tb2`
    -> ADD unique key(`name`)
    -> ;

#删除唯一约束
mysql> desc tb2;
mysql> alter table tb2
    -> drop key name;

#联合唯一
mysql> alter table tb2
    -> add aa int,
    -> add bb int;

mysql> alter table tb2
    -> add unique key (aa,bb);

mysql> insert into tb2 value(4,'佳能',1,2);
mysql> insert into tb2 value(5,'哈哈',1,2);
ERROR 1062 (23000): Duplicate entry '1-2' for key 'aa'--联合唯一,只要其中一个不一样就可以插入

# 删除联合唯一  (show create table tb2;)
mysql> show create table student2;  ----首先查看表的详情;
| student2 | CREATE TABLE `student2` (
  `id` int(11) NOT NULL,
  `name` varchar(20) NOT NULL,
  `aa` int(11) DEFAULT NULL,
  `bb` int(11) DEFAULT NULL,
  UNIQUE KEY `id` (`id`),
  UNIQUE KEY `aa` (`aa`,`bb`)  --通过查看是前面那个aa,所以只需要把前面那个删除就行了;
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
mysql> alter table student2
    -> drop key aa;

主键约束 (primary key)

  • 主键作用:可以唯一标识一条数据,每张表里只能有一个主键
  • 主键特性:非空且唯一,表没有主键时,第一个出现的非空且唯一的字段为主键

主键保证记录的唯一性, 唯一标识每一条数据,主键自动为NOT NULL,每张数据表只能存在一个主键,NOT NULL + UNIQUE KEY --唯一且不为空;
一个UNIQUE KEY 又是一个NOT NULL的时候,那么它被当做PRIMARY KEY主键
当一张表里没有一个主键的时候,第一个出现的非空且为唯一的列被视为有主键。

#主键,就是可以数据表中,可以唯一标识,一条数据。就好像身份证一样。
mysql> create table tb3( 
    -> id int primary key,
    -> name varchar(20) not null
    -> );  
mysql> desc tb3;


mysql> insert into tb3 value(1,'张三');
Query OK, 1 row affected (0.27 sec)
mysql> insert into tb3 value(1,'张三');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

#删除主键约束
mysql> alter table tb3
    -> drop primary key;    # 一个表里面,只有一个主键
mysql> desc tb3;

#添加主键约束
mysql> alter table tb3
    -> add primary key(id);
    
#联合主键
mysql> create table tb4(
    -> id_a int ,
    -> id_b int,
    -> content varchar(20),
    -> primary key(id_a,id_b)
    -> );
mysql> desc tb4;

#删除主键约束
mysql> alter table tb4
    -> drop primary key;--不需要指定字段,因为主键唯一性,会自动删除联合的每一个约束;
#添加联合主键
mysql> alter table tb4
    -> add primary key(id_a,id_b);

自增长auto_increment

例:
mysql> create table tb5( 
    -> id int primary key auto_increment,
    -> name varchar(20)
    -> )auto_increment =100;    # 如果不写,默认从1开始
mysql> desc tb5;

mysql> insert into tb5(name) values('张三'),('李四');
mysql> select * from tb5;

#auto_increment值,可以调大
insert into tb5(id,name) values(110,'王五');
mysql> select * from tb5;
#不可以调小
insert into tb5(id,name) values(108,'王八');
insert into tb5(name) values('田七');--是指自增长那个不能调小而已;
mysql> select * from tb5;
#删除自动增长
mysql> alter table tb5
    -> modify id int;
#增加自动增长auto_increment
mysql> alter table tb5
    -> modify id int auto_increment;
~~~
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351

推荐阅读更多精彩内容