当前位置:主页 > mysql教程 > MySQL学习笔记5:修改表(alter table)

MySQL修改表(alter table)实例方法

发布:2019-08-29 21:33:47 141


本站收集了一篇相关的编程文章,网友姜琳淼根据主题投稿了本篇教程内容,涉及到修改表、alter、table、MySQL学习笔记5:修改表(alter table)相关内容,已被602网友关注,相关难点技巧可以阅读下方的电子资料。

MySQL学习笔记5:修改表(alter table)

我们在创建表的过程中难免会考虑不周,因此后期会修改表修改表需要用到alter table语句
修改表名
 

mysql> alter table student rename person;
Query OK, 0 rows affected (0.03 sec)

这里的student是原名,person是修改过后的名字
用rename来重命名,也可以使用rename to
修改字段的数据类型
 

mysql> alter table person modify name varchar(20);
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

此处modify后面的name为字段名,我们将原来的varchar(25)改为varchar(20)
修改字段名
 

mysql> alter table person change stu_name name varchar(25);
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

这里stu_name是原名,name是新名
需要注意的是不管改不改数据类型,后面的数据类型都要写
如果不修改数据类型只需写成原来的数据类型即可
tips:我们同样可以使用change来达到modify的效果,只需在其后写一样的字段名
增加无完整性约束条件的字段
 

mysql> alter table person add sex boolean;
Query OK, 0 rows affected (0.21 sec)
Records: 0 Duplicates: 0 Warnings: 0

此处的sex后面只跟了数据类型,而没有完整性约束条件
增加有完整性约束条件的字段
 

mysql> alter table person add age int not null;
Query OK, 0 rows affected (0.17 sec)
Records: 0 Duplicates: 0 Warnings: 0

地处增加了一条age字段,接着在后面加上了not null完整性约束条件
在表头添加字段
 

mysql> alter table person add num int primary key first;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

默认情况下添加字段都是添加到表尾,在添加语句后面加上first就能添加到表头
在指定位置添加字段
 

mysql> alter table person add birth date after name;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

这里添加一条新字段放在name字段后面
tps:表中字段的排序对表不会有什么影响,不过更合理的排序能便于理解表
删除字段
 

mysql> alter table person drop sex;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

和前面删除表或数据库一样,这里也需要用drop
不同的是,删除字段还要用alter table跟着表名
修改字段到第一个位置
 

mysql> alter table person modify id int first;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

first在前面已经讲过,此处要注意的是字段后面要写数据类型
修改字段到指定位置
 

mysql> alter table person modify name varchar(25) after id;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

我们把name字段放到了id后面,此处的varchar(25)要写全,varchar不行
建议操作以上步骤之前都先desc table
修改表的存储引擎
 

mysql> alter table user rename person;
Query OK, 0 rows affected (0.05 sec)

这里先不具体讲各个存储引擎的特点,内容比较多
修改完之后别忘了使用show create table语句查看,第三节有写用法
tips:如果表中已存在很多数据,不要轻易修改存储引擎
增加表的外键

mysql> alter table score add constraint fk foreign key(stu_id) references student(id);
Query OK, 10 rows affected (0.18 sec)
Records: 10 Duplicates: 0 Warnings: 0

这里只需使用add增加即可,后面的语法参见第四节中的外键设置
删除表的外键约束
mysql> alter table student3 drop foreign key fk;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

由于基本的表结构描述无法显示外键,所以在进行此操作前最好使用show create table查看表

这里的fk就是刚刚设置的外键
需要注意的是:如果想要删除有关联的表,那么必先删除外键
删除外键后,原先的key变成普通键
至于删除表的操作,在第三节有写,设置外键在第四节也有写如果创建表的时候没有设置外键,可使用上面的方法


参考资料

相关文章

  • mysql将表名改成大写的实例

    发布:2019-12-31

    这篇文章主要为大家详细介绍了MYSQL将表名称修改成大写的存储过程,感兴趣的小伙伴们可以参考一下


  • java CompletableFuture实现异步编排详解

    发布:2023-04-20

    这篇文章主要为大家介绍了java CompletableFuture实现异步编排详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • 如何实现python PrettyTable模块的安装与简单应用

    发布:2020-01-11

    prettyTable 是一款很简洁但是功能强大的第三方模块,主要是将输入的数据转化为格式化的形式来输出,这篇文章主要介绍了python PrettyTable模块的安装与简单应用,感兴趣的小伙伴们可以参考一下


  • spring boot executable jar/war 原理解析

    发布:2023-04-13

    spring boot里其实不仅可以直接以 java -jar demo.jar的方式启动,还可以把jar/war变为一个可以执行的脚本来启动,比如./demo.jar,这篇文章主要介绍了spring boot executable jar/war 原理,需要的朋友可以参考下


  • 实例总结mysql修改表结构方法

    发布:2020-03-10

    这篇文章主要介绍了mysql修改表结构方法,以实例形式较为详细的分析了mysql修改表结构的具体方法与相关注意事项,具有一定参考借鉴价值,需要的朋友可以参考下


  • Qt实现导出QTableWidget/QTableView数据

    Qt实现导出QTableWidget/QTableView数据

    发布:2022-09-07

    为网友们分享了关于Qt的教程,这篇文章主要介绍了在Qt中实现将QTableWidget或者QTableView中的数据直接导出的示例代码,文中的示例代码讲解详细,感兴趣的可以了解一下


  • MySQL修改表的实现方法

    发布:2020-03-26

    我们在创建表的过程中难免会考虑不周,因此后期会修改表。本篇文章就介绍了在mysql中修改表的实现方法。需要的朋友参考下


  • bootstrap table用法详解

    发布:2020-07-08

    这篇文章主要为大家详细介绍了JS表格组件神器bootstrap table使用指南,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


网友讨论