包括表属性改变,列属性改变,完整性约束改变。
1.表属性改变
1.1重命名表名
mysql> alter table student rename to s;
Query OK, 0 rows affected (0.03 sec)
也可以直接使用rename命令改名:
mysql> rename table s to student;
Query OK, 0 rows affected (0.13 sec)
1.2表排序改变
mysql> alter table student order by stu_id desc;
mysql> select * from student;
+--------+----------+---------+-----------+
| stu_id | stu_name | stu_tel | stu_score |
+--------+----------+---------+-----------+
| 4 | d | 154 | 63 |
| 3 | c | 153 | 62 |
| 2 | b | 152 | 61 |
| 1 | a | 151 | 60 |
+--------+----------+---------+-----------+
2列属性改变
2.1 添加列
mysql> alter table student
-> add sex char(1) after stu_name;
Query OK, 4 rows affected (0.34 sec)
Records: 4 Duplicates: 0 Warnings: 0
mysql> select * from student;
+--------+----------+------+---------+-----------+
| stu_id | stu_name | sex | stu_tel | stu_score |
+--------+----------+------+---------+-----------+
| 1 | a | NULL | 151 | 60 |
| 2 | b | NULL | 152 | 61 |
| 3 | c | NULL | 153 | 62 |
| 4 | d | NULL | 154 | 63 |
+--------+----------+------+---------+-----------+
4 rows in set (0.02 sec)
新添加的列默认放在最后一列,且默认填充空值。这里使用after指定了新增列sex放在stu_name后面。如果新增列设置不能为空,那么mysql将根据列的数据类型填入实际的值:对于数值填入0,对于字符串填入空字符串,对于日期填入0000-00-00,对于时间填入00:00:00.
2.2删除列
mysql> alter table student
-> drop sex;
Query OK, 4 rows affected (0.33 sec)
Records: 4 Duplicates: 0 Warnings: 0
2.3修改列属性
初始列属性:
+-------------+-----------+
| column_name | data_type |
+-------------+-----------+
| stu_id | int |
| stu_name | varchar |
| stu_tel | int |
| stu_score | int |
+-------------+-----------+
将stu_tel列修改为tel char型,并放在stu_score后面。
mysql> alter table student
-> change stu_tel tel char(3) after stu_score;;
Query OK, 4 rows affected (0.23 sec)
+-------------+-----------+
| column_name | data_type |
+-------------+-----------+
| stu_id | int |
| stu_name | varchar |
| stu_score | int |
| tel | char |
+-------------+-----------+
[1] [2]
声明: 本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
千万级数据并发解决方案(理论+实战): 点击学习
Mysql单表千万级数据量的查询优化与性能分析
Mysql主从原理及其在高并发系统中的应用
相关课程推荐 javascript是运行在浏览器上的脚本语言,连续多年,被评为全球最受欢迎的编程语言。是前端开发必备三大法器中,最具杀伤力。如果前端开发是降龙十八掌,好么javascript就是第18掌:亢龙有悔。没有它,你的前端生涯是不完整的。《php.cn独孤九贱(3)-JavaScript视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了javascript知识。
JavaScript教程 139626次播放
jQuery是一个快速、简洁的JavaScript框架。设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。
核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等,是全球最流行的前端开发框架之一。PHP中文网根据最新版本,独家录制jQuery最新视频教程,回馈PHP中文网的新老用户。
jQuery教程 114720次播放
jQuery是最流行的JS函数库,封装了许多实用的功能,其中最引人入胜的就是Ajax。
jQuery中的Ajax操作,语法简单,操作方便,使Ajax从未如此轻松,前端人员从此不再为与服务器异步交互而发愁,本套课程,精选了最常用的几个方法,从基本的语法到每个参数,再到具体实例进行了全面的讲解。
AJAX教程 14393次播放
Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。
Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持
JavaScript教程 12388次播放
1/1
三个月PHP直播课