改动表是指改动数据库中已经存在的表的定义。改动表比又一次定义表简单。不须要又一次载入数据。也不会影响正在进行的服务。

MySQL中通过ALTER TABLE语句来改动表。改动表包含改动表名。改动字段数据类型,改动字段名。添加字段,删除字段,改动字段的排列位置。更改默认存储引擎和删除表的外键约束等。

OK,这篇博客会具体的整理到上面的几种改动表的方式。如今我们開始。

  • 1,改动表名

表名能够在一个数据库中唯一的确定一张表。

数据库系统通过表名来区分不同的表。

注意的是。数据库中的表是唯一的,数据库中不可能存在两张同样的表。

MySQL中通过sql语句ALTER TABLE来实现表名的改动,语法形式例如以下:

ALTER TABLE 旧表名 RENAME [TO] 新表名;

当中。‘旧表名’參数表示改动前的表名,‘新表名’參数表示改动后的新表名,TO參数是可选參数,这个属性是否在语句中出现不会影响语句的运行。rename的意思就是重命名,所以这个挺好记的。

OK,如今我们来实际操作下数据库。我们如今数据库中创建一张表,建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们改动下上面user表的表名:

ALTER TABLE linkinframe.user RENAME linkinframe.usr;

OK,改动成功,我们查看下新的表。表结构和之前的表结构一致,里面的数据与之前的数据也一致。

  • 2,改动字段的数据类型

字段的数据类型包含整数型。浮点数型,字符串型。二进制类型,日期和时间类型等。

数据类型决定了数据的存储格式,约束条件和有效范围。表中的每一个字段都有数据类型。

MySQL中,ALTER TABLE语句也能够改动字段的数据类型。基本的语法例如以下:

ALTER TABLE 表名 MODIFY 属性名 数据类型;

当中,‘表名’參数指所要改动的表的名称,‘属性名’參数指须要改动的字段的名称。‘数据类型’參数值改动后的新的数据类型。

OK。如今我们来实际操作下MySQL。首先我们建一张user表,建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们改动name字段的长度为varhcar(10)。运行例如以下的sql语句来改动:

ALTER TABLE linkinframe.`user` MODIFY name varchar(10) NOT NULL;





改动后我们查看下数据库如今表结构,成功改动了name属性的长度了。

  • 3,改动字段名

字段名是一张表中唯一的一个字段。

数据库系统通过字段名来区分表中的不同字段。MySQL中,ALTER TABLE语句也能够改动表的字段名,基本的语法例如以下:

ALTER TABLE 表名 CHANGE 旧属性名 新属性名 新数据类型;

当中,‘旧属性名’參数指改动前的字段名。‘新属性名’參数指改动后的字段名,‘新数据类型’參数指改动后的数据类型。如不须要改动,则将新数据类型设置成与原来的一样。





详细有2种情况:

  • 1),仅仅改动字段名

使用ALTER TABLE 语句直接改动字段名。不改变字段的数据类型。

建表语句:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(10) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们改动name字段为username字段,运行例如以下语句来改动:

ALTER TABLE linkinframe.`user` CHANGE name username varchar(10) NOT NULL;

改动后的表结构例如以下:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

当然当中的数据也没有变化:



  • 2)。改动字段名和字段数据类型

使用ALTER TABLE语句直接改动字段名和该字段的数据类型。建表语句:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们改动name字段为username字段。然后我们将name原来的长度改动成为10,运行例如以下语句来改动:

ALTER TABLE linkinframe.`user` CHANGE name username varchar(10) NOT NULL;

改动后的表结构例如以下:



  • 3),总结

MODIFY和CHANGE都能够改变字段的数据类型。不同的是:

1,CHANGE能够在改变字段数据类型的同一时候,改变字段名。MODIFY仅仅能用来改变字段的数据类型,不能改动字段名。

2,CHANGE假设不改变字段名,仅仅改动字段类型。CHAGE后面必须跟两个相同的字段名。

3,养成良好的习惯,假设是指改动字段的数据结构就使用MODIFY,假设要改动字段名+数据结构就使用CHANGE。

4,在改动表的字段过程中,假设表中已经有记录。改动数据类型时应该特别小心。由于,改动数据类型时可能会影响表中的数据。

5,特别注意的是。字符类型的字段最好不要改成整数类型,浮点数类型。





  • 4,添加字段

在创建表时,表中的字段就已经定义完毕。假设要添加新的字段。能够通过ALTER TABLE语句进行添加,在MySQL中,ALTER TBALE语句添加字段的基本的语法例如以下:

ALTER TABLE 表名 ADD 属性名1 数据类型 [完整性约束条件] [FIRST | AFTER 属性名2];

当中,‘属性名1’參数指须要添加的字段的名称,‘数据类型’參数指新添加字段的数据类型。‘完整性约束条件’是可选參数。用来设置新增字段的完整性约束条件;‘FIRST’參数也是可选參数,其作用是将新增字段设置为表的第一个字段,‘AFTER 属性名

2’參数也是可选參数,其作用是将新增字段加入到‘属性名2’所指的字段后。假设运行的sql语句中没有‘FIRST’,‘AFTER 属性名2’參数指定新增字段的位置,新增的字段默觉得表的最后一个字段。



详细有例如以下4种情况:

  • 1),添加无完整性约束条件的字段

一个完整的字段包含字段名。数据类型和完整性约束条件,添加字段一般都是包含上述内容。

当然,依据实际情况,一些字段也能够不用完整性约束条件进行约束。

如今我们来实际操作下,数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中加入一个phone字段:

ALTER TABLE linkinframe.`user` ADD phone varchar(11);



OK,加入字段成功。这里没有设置‘FRIST’和‘AFTER 属性名2’參数来指定插入位置,所以新增字段默觉得表的最后一个字段。

  • 2)。添加有完整性约束条件的字段

添加字段时能够设置该字段的完整性约束条件。如设置字段是否为空。是否为主键。是否为外键,默认值和是否为自增类型等约束条件。

如今我们来实际操作下,数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中加入一个phone字段:

ALTER TABLE linkinframe.`user` ADD phone varchar(11) NOT NULL;

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

OK。加入字段成功,这里没有设置‘FRIST’和‘AFTER 属性名2’參数来指定插入位置,所以新增字段默觉得表的最后一个字段。

  • 3),表的第一个位置添加字段

默认情况下。新增字段为表的最后一个字段。假设加上FIRST參数,则能够将新增字段设置为表的第一个字段。

如今我们来实际操作下。数据库建表语句例如以下:

CREATE TABLE linkinframe.`user` (
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中加入一个id字段。然后设置id为user表的主键,并且放到表中的第一个位置上。

ALTER TABLE linkinframe.`user` ADD `id` int(11) primary KEY AUTO_INCREMENT first;

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">



OK,加入成功,并且成功的放到了表中的第一个字段上面了。

  • 4),表的指定位置之后添加字段

在添加字段时,因为特殊原因须要在表的指定位置添加字段。假设加上‘AFTER 属性名2’參数,那么新增的字段插入在‘属性名2’后面。

如今我们来实际操作下。数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中name字段之后加入一个phone字段:

ALTER TABLE linkinframe.`user` ADD phone varchar(11) after name;

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">



OK,加入字段成功,表中phone字段成功的放到了name字段之后。

  • 总结:

1,添加字段时,假设能够加上完整性约束条件,一定要加上。这样能够保证此字段的安全性。甚至能够提高整个表的数据的安全性。

2,对于一个数据库来说。字段的排列顺序对表不会有什么影响。

可是对于创建表的人来说。将有某种直接或者间接关系的字段放在一起,会更加好的理解这个表的结构,这事实上也是一种习惯。我们以后也要尽量将有关系的字段放在一起。方便我们查看。





  • 5,删除字段

删除字段是指删除已经定义好的表中的某个字段,在表创建完毕之后,假设发现某个字段须要删除。能够採用将整个表都删除,然后又一次创建一张表的做法。这样做是能够达到目的的,但必定会影响到表中的数据。并且操作比較麻烦。

MySQL中,ALTER TABLE语句也能够删除表中的字段,语法例如以下:

ALTER TABLE 表名 DROP 属性名;

当中,‘属性名’參数指须要从表中删除的字段的名称。

如今我们来实际操作下,数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中删除掉name字段:

ALTER TABLE linkinframe.`user` DROP name;





OK,成功删除了。

  • 6。改动字段的排列位置

创建表的时候,字段在表中的排列位置都已经确定了。假设要改变字段在表中的排列位置。也能够通过ALTER TABLE来处理。

MySQL中。改动字段排列位置的ALTER TABLE语句的基本的语法例如以下:

ALTER TABLE 表名 MODIFY 属性名1 数据类型 FIRST|AFTER 属性名2;

当中,‘属性名1’參数指须要改动位置的字段的名称,‘数据类型’參数指‘属性名1’的数据类型,‘FIRST’參数指定位置为表的第一个位置。‘AFTER 属性名2’參数指定‘属性名1’插入到‘属性名2’之后。

详细的分2种情况:

  • 1)。字段改动到第一个位置

FIRST參数能够指定字段为表的第一个字段。

如今我们来实际操作下。数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中的name字段改动到数据库的第一个位置上去:

ALTER TABLE linkinframe.`user` modify name varchar(5) first;



OK,显示name字段已经到了user表的第一个位置上了。



  • 2),字段改动到指定位置

‘AFTER’參数能够将字段排在表中指定的字段之后。

如今我们来实际操作下,数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中的name字段改动到age之后去:

ALTER TABLE linkinframe.`user` modify name varchar(5) after age;



OK,显示name字段已经到了user表中age之后了。

  • 总结:

改动字段的排列位置事实上也就是改动表的字段,这里因为没有改动字段名。所以我们能够使用MODIFY来操作字段的位置。当然我们也能够使用CHANGE来操作字段的位置。仅仅只是这个时候属性名要写2遍而已。

比方说我如今不自己写sql,然后使用MySQL的client来调整下表中的2字段的位置使用的就是CHANGE。

ALTER TABLE `linkinframe`.`user`
CHANGE COLUMN `name` `name` VARCHAR(5) CHARACTER SET 'utf8' NULL DEFAULT NULL AFTER `id`;

  • 7。更改表的存储引擎

MySQL存储引擎是指MySQL数据库中表的存储类型。

MySQL存储引擎包含InnoDB,MyISAM。Memory等。不同的表类型有着不同的优缺点,在前面的博客中我也已经整理到了。

在创建表时。存储引擎就已经设定好了。假设要改变,能够通过又一次创建一张表来实现。这么做是能够达到目的的,但必定会影响到表中的数据。并且操作比較麻烦。

MySQL中,ALTER TABLE语句也能够更改表的存储引擎的类型,其基本的语法例如以下:

ALTER TABLE 表名 ENGINE=存储引擎名

当中。‘存储引擎名’參数指设置的新的存储引擎的名称。

如今我们来实际操作下,数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们user表中的存储引擎设置为MyISAM:

ALTER TABLE linkinframe.`user` ENGINE = MyISAM;





OK。如今我们SHOW CREATE TABLE看下user的表结构,如今user表的存储引擎成功的变成了MyISAM。

注意:使用Alter语句能够改变表的存储引擎,这能够避免又一次创建表。可是,假设表中已经有非常多的数据。改变存储引擎可能会造成一些意料之外的影响。假设一个表中已经存在了非常多数据,最好不要轻易更改其存储引擎。





  • 8,删除表的外键约束

外键是一个特殊字段,其将某一表与其父表建立关联关系。

在创建表的时。外键约束就已经设定好了。

因为特殊须要,与父表之间的关联关系须要去除,要求删除外键约束。

MySQL中。ALTER TABLE语句也能够删除表的外键约束。其基本的语法例如以下:

ALTER TABLE 表名 DROP FOREIGN KEY 外键别名:

当中。‘外键别名’參数指创建表时设置的外键的代号。

如今我们来实际操作下,数据库建表语句例如以下:

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(5) COLLATE utf8_bin NOT NULL,
`card_id` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`age` int(11) DEFAULT '25',
PRIMARY KEY (`id`),
UNIQUE KEY `age_UNIQUE` (`card_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
CREATE TABLE `address` (
`id` int(11) NOT NULL,
`user_id` int(11) DEFAULT NULL,
`name` varchar(45) COLLATE utf8_bin DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `user_id_idx` (`user_id`),
CONSTRAINT `user_id` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

如今我们删除掉从表address的外键关联。运行例如以下sql:

ALTER TABLE linkinframe.address DROP foreign key user_id;



OK,查询结果显示从表address的外键已经不存在了。

最新文章

  1. BZOJ 4723: [POI2017]Flappy Bird
  2. 【XLL 框架库函数】 debugPrintf
  3. C++引用与指针
  4. QEMU/KVM功能测试
  5. 【转载】关于Embedded Linux启动的经典问题
  6. 电视直播用的.m3u8 PC端和移动端地址 【流媒体播放测试专用】
  7. Qt之图形视图框架
  8. 启动BPM的5个步骤
  9. 单元测试利器JUnit4
  10. JS时间的计算,当前日期加一天或者几天的计算
  11. Swift语言指南(七)--语言基础之布尔值和类型别名
  12. 转化成maven dependencis
  13. Oracle:解锁scott用户及设置密码
  14. Linux 虚拟网络设备 veth-pair 详解,看这一篇就够了
  15. 【单调队列优化dp】 分组
  16. leetcode — permutations-ii
  17. 1.Spring框架入门案例
  18. [development][http][libhtp] suricata的http库--libhtp
  19. python2核心类库:urllib、urllib2的区别和使用
  20. 2668: [cqoi2012]交换棋子

热门文章

  1. BZOJ 2888 资源运输(启发式合并LCT)
  2. BZOJ 4802 欧拉函数(Pollard_Rho)
  3. svn出现Authorization failed
  4. [bzoj1011](HNOI2008)遥远的行星(近似运算)
  5. 20172333 2017-2018-2 《Java程序设计》第3周学习总结
  6. CentOS 6.9下KVM虚拟机快照创建、删除、恢复(转)
  7. file结构体中private_data指针的疑惑
  8. android基础知识复习——RelativeLayout布局属性、背景、半透明设置(XML设置)
  9. 【Todo】Boost安装与学习
  10. Android应用程序访问linux驱动第一步:实现并测试Linux驱动