ALTER语句重命名,重新定义和重新排序列
该CHANGE,MODIFY和 ALTER子句可以改变现有列的名称和定义。他们有这些比较特征:
CHANGE:
可以重命名列并更改其定义,或两者都可以。
具有更多的能力MODIFY,但是以某些操作的便利为代价。 CHANGE如果不重命名,则需要命名该列两次。
使用FIRSTor AFTER,可以重新排列列。
MODIFY:
可以更改列定义,但不能更改其名称。
比CHANGE改变列定义而不重命名更方便。
使用FIRSTor AFTER,可以重新排列列。
ALTER:仅用于更改列默认值。
CHANGE是标准SQL的MySQL扩展。 MODIFY是Oracle兼容性的MySQL扩展。
要更改列以更改其名称和定义,请使用 CHANGE指定新名称和新定义的名称。例如,要将INT NOT NULL列重命名a为 b并更改其定义以BIGINT在保留NOT NULL属性的同时使用 数据类型 ,请执行以下操作:
ALTER TABLE t1 CHANGE a b BIGINT NOT NULL;
要更改列定义但不更改其名称,请使用 CHANGE或MODIFY。使用时 CHANGE,语法需要两个列名,所以您必须指定两次相同的名称才能保持名称不变。例如,要更改列的定义 b,请执行以下操作:
ALTER TABLE t1 CHANGE b b INT NOT NULL;
MODIFY 更改定义而不更改名称更方便,因为它仅需要一次列名称:
ALTER TABLE t1 MODIFY b INT NOT NULL;
要更改列名称而不是其定义,请使用 CHANGE。该语法需要列定义,因此要保持定义不变,您必须重新指定列当前具有的定义。例如,要将INT NOT NULL列 重命名b为a,请执行以下操作:
ALTER TABLE t1 CHANGE b a INT NOT NULL;
对于使用CHANGEor的 列定义更改MODIFY,定义必须包括数据类型以及应用于新列的所有属性,而不是索引属性(如PRIMARY KEYor) UNIQUE。原始定义中存在但未为新定义指定的属性不会继续执行。假设列col1被定义为,INT UNSIGNED DEFAULT 1 COMMENT 'my column'并且您按如下方式修改该列,意图仅更改INT为 BIGINT:
ALTER TABLE t1 MODIFY col1 BIGINT;
这种说法从改变数据类型INT 来BIGINT,但它也下降了 UNSIGNED,DEFAULT和 COMMENT属性。要保留它们,声明必须明确地包含它们:
ALTER TABLE t1 MODIFY col1 BIGINT UNSIGNED DEFAULT 1 COMMENT 'my column';
对于使用CHANGEor的 数据类型更改MODIFY,MySQL会尝试尽可能将现有列值转换为新类型。
警告
此转换可能会导致数据更改。例如,如果缩短字符串列,则值可能会被截断。如果转换为新数据类型会导致数据丢失,要防止操作成功,ALTER TABLE请在使用前启> 用严格SQL模式(请参见 第5.1.8节“服务器SQL模式”)。
如果使用CHANGE或MODIFY 缩短列上存在索引的列,并且结果列长度小于索引长度,则MySQL会自动缩短索引。
对于CHANGE重命名的列,MySQL会自动将这些引用重命名为已重命名的列:
引用旧列的索引,包括索引和禁用MyISAM索引。
指向旧列的外键。
对于重命名的列CHANGE,MySQL不会自动将这些引用重命名为重命名列:
生成引用重命名列的列和分区表达式。您必须使用CHANGE重新定义与ALTER TABLE重命名该列的语句相同的 语句。
视图和存储的程序引用了重命名的列。您必须手动更改这些对象的定义以引用新的列名称。
要对表格中的列重新排序,请使用FIRST 和AFTER输入CHANGE或 MODIFY操作。
ALTER ... SET DEFAULT
或ALTER ... DROP DEFAULT
为列指定新的默认值或分别删除旧的默认值。如果删除旧的默认值并且该列可以NULL,则新的默认值为NULL。如果该列不可用 NULL,MySQL将按照第11.7节“数据类型默认值”中所述分配默认值。
ALTER语句重命名,重新定义和重新排序列的更多相关文章
- ylb:sql语句重命名表名和列名
ylbtech-SQL Server:SQL Server-sql语句重命名表名和列名 sql语句重命名表名和列名 ylb:sql语句重命名表名和列名 返回顶部 一.更改数据库名 sp_rena ...
- sqlServer 2008修改字段类型和重命名字段名称的sql语句
sqlServer 2008修改字段类型和重命名字段名称的sql语句 //修改字段的类型 alter table fdi_news alter column c_author nvarchar(50) ...
- MySql语句中select可以嵌套么,字段的重命名可以用中文么
今天文档中看到的查询语句,SELECT后面又跟了一个SELECT嵌套,而且把字段重命名为中文,请问可以这样做么 MySql语句中select可以嵌套么,字段的重命名可以用中文么 >> my ...
- MySQL之alter语句用法总结
MySQL之alter语句用法总结 1:删除列 ALTER TABLE [表名字] DROP [列名称] 2:增加列 ALTER TABLE [表名字] ADD [列名称] INT NOT NULL ...
- SQL Server 2008数据库重命名方法
假设SQL Server 2008中有个数据库test,现在要将其改名为zhy步骤:(1) 分离数据库:打开management studio,找到test数据库-->右键-->任务--& ...
- MYSQL:alter语句中change和modify的区别
您可以使用CHANGE old_col_namecolumn_definition子句对列进行重命名.重命名时,需给定旧的和新的列名称和列当前的类型.例如:要把一个INTEGER列的名称从a变更到b, ...
- SQL语法基础之ALTER语句
SQL语法基础之ALTER语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查看ALTER的帮助信息 mysql> ? ALTER Many help items fo ...
- Oracle 11gR2 用户重命名(rename user)
Oracle 11.2.0.2里新增了一个新特性——用户重命名(Rename User),在这个版本之前要想重命名用户,需要按用户导出,再fromuser touser(imp)或remap_sc ...
- 【SqlServer】SqlServer中Alter语句的使用
在修改Sql Server表结构时,常用到Alter语句,把一些常用的alter语句列举如下. 1:向表中添加字段 Alter table [表名] add [列名] 类型 2: 删除字段 Alte ...
随机推荐
- ModelViewSet 视图集 实现接口
一.创建项目 1.创建 项目 : django-admin startprojet drf 2. 创建 两个app ------ app1 ,book python manage.py start ...
- python:字典嵌套列表
Python的字典{ }以键值对的形式保存数据,可以以键来访问字典中保存的值而不能用下标访问.字典中几乎可以包含任意的变量,字典,数列,元组.数列也一样. python的列表[ ]与字典不同,列表通过 ...
- MI04 盘点单数据录入
*&---------------------------------------------------------------------* *& Report ZRHSSD002 ...
- lua 函数基础
函数定义在前,调用在后 如果函数只有一个实参,并且此参数是一个字面字符串或者table构造式,那么可以省略() 例如 print "hello" unpack{1,2} print ...
- Redis+Twemproxy+HAProxy集群(转) 干货
原文地址:Redis+Twemproxy+HAProxy集群 干货 Redis主从模式 Redis数据库与传统数据库属于并行关系,也就是说传统的关系型数据库保存的是结构化数据,而Redis保存的是一 ...
- 在div中放一个相同大小的svg,实际显示的位置svg偏下
svg默认display为inline,改成block即可与div完全重合.
- Linux -- 基于zookeeper的java api(一)
Linux -- 基于zookeeper的java api 首先启动你所有的 zkService.sh 查看状态:检查是否启动正确 [root@hu-hadoop2 ~]# zkServer.sh s ...
- Linux中环境变量文件
一.环境变量文件介绍 转自:http://blog.csdn.net/cscmaker/article/details/7261921 Linux中环境变量包括系统级和用户级,系统级的环境变量是每个登 ...
- ActiveMQ 的线程池
ActiveMQ 的线程池实质上也是 ThreadPoolExecutor,不过它的任务模型有自己的特点,我们先看一个例子: public static void main(String[] args ...
- linux下uptime命令详解
uptime uptime 另外还有一个参数 -V(大写),是用来查询版本的 procps是一个实用程序包,主要包括ps top kill等程序主要用来显示与控制一些系统信息,进程状态之类的内容. 以 ...