详解MySQL中ALTER命令的使用
作者:goldensun 发布时间:2024-01-26 12:27:25
MySQL的ALTER命令是非常有用的,当想改变表的名称,表的字段,或者如果要添加或删除一个现有的表中的列。
让我们开始创建一个表名为testalter_tbl的用例:
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> create table testalter_tbl
-> (
-> i INT,
-> c CHAR(1)
-> );
Query OK, 0 rows affected (0.05 sec)
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| i | int(11) | YES | | NULL | |
| c | char(1) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
丢弃,添加或重新定位字段:
假设要删除一个现有的第i列从上面的MySQL表,那么使用DROP子句一起使用ALTER命令如下
mysql> ALTER TABLE testalter_tbl DROP i;
如果该表中剩下唯一的一个字段,DROP命令是不起作用的。
要添加一列,使用“添加”ADD“指定的列定义。下面的语句恢复?列的testalter_tbl
mysql> ALTER TABLE testalter_tbl ADD i INT;
testalter将包含相同的两列,当第一次创建表不会有相同的结构。这是因为新列添加到默认情况下,该表结束。即使ioriginally是第一列MYTBL,现在是最后一条:
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
想指定的表中的一列位置,可以使用第一个它的第一列,,或ALTER COL_NAME到指示新列应该放在后COL_NAME。请尝试以下ALTER TABLE语句中,使用SHOW COLUMNS后,每个人都有不同的影响:
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT FIRST;
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT AFTER c;
第一和AFTER符只能与ADD子句。这意味着,如果要重新定位现有的列在一个表中,必须先删除它,然后将它添加在新的位置。
更改列定义或名称:
要更改列的定义,修改或变更条款,连同ALTER命令。例如,要更改列c从CHAR(1)为CHAR(10),这样做:
mysql> ALTER TABLE testalter_tbl MODIFY c CHAR(10);
CHANGE语法是有点不同。变更后的关键字,要更改的列的名字,然后指定新的定义,其中包括新的名称。试试下面的例子:
mysql> ALTER TABLE testalter_tbl CHANGE i j BIGINT;
如果现在使用转换j字段的BIGINT为int而不改变列名,该声明应该是:
mysql> ALTER TABLE testalter_tbl CHANGE j j INT;
ALTER TABLE的影响,NULL和默认值属性:
当修改或更改列,也可以指定是否该列可以包含NULL值,它的默认值是什么。事实上,如果不这样做,MySQL会自动分配给这些属性的值。
下面是示例默认情况下,NOT NULL列的值将是100。
mysql> ALTER TABLE testalter_tbl
-> MODIFY j BIGINT NOT NULL DEFAULT 100;
如果不使用上面的命令,那么MySQL将填补所有的列中的NULL值。
更改列的默认值:
可以使用ALTER命令更改任何列的默认值。试试下面的例子。
mysql> ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | 1000 | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
可以从任何一列中删除默认约束通过使用DROP子句一起使用ALTER命令。
mysql> ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
更改表类型:
可以使用ALTER命令及TYPE子句一起使用的修改表类型。试试下面的示例中,改变testalter_tbl 为InnoDB类型。
要找出一个表的当前类型,使用SHOW TABLE STATUS语句。
mysql> ALTER TABLE testalter_tbl TYPE = InnoDB;
mysql> SHOW TABLE STATUS LIKE 'testalter_tbl'\G
*************************** 1. row ****************
Name: testalter_tbl
Type: InnoDB
Row_format: Fixed
Rows: 0
Avg_row_length: 0
Data_length: 0
Max_data_length: 25769803775
Index_length: 1024
Data_free: 0
Auto_increment: NULL
Create_time: 2007-06-03 08:04:36
Update_time: 2007-06-03 08:04:36
Check_time: NULL
Create_options:
Comment:
1 row in set (0.00 sec)
重命名表:
要重命名表,使用ALTER TABLE语句中RENAME选项。试试下面的例子,重命名testalter_tbl为alter_tbl
mysql> ALTER TABLE testalter_tbl RENAME TO alter_tbl;
可以使用ALTER命令来创建和删除索引在MySQL文件。在下一章中,我们将看到此功能。


猜你喜欢
- 拼接字符串使用“+”可以对多个字符串进行拼接语法格式: str1 + str2>>> str1 = "aaa&q
- 大家知道,在js里encodeURIComponent 方法是一个比较常用的编码方法,但因工作需要,在asp里需用到此方法,查了好多资料,没
- 配置生产环境#setting.py 文件中DEBUG = False # 生产环境# 允许访问的域名,域名前加一个点表示允许访问
- 由于不同的浏览器,比如Internet Explorer 6,Internet Explorer 7,Mozilla Firefox等,对C
- 一般与页面有关的系统都会有大量的静态文件,包括js、css以及图标图片等,这些文件一般是项目的相对路径,在加载的时候会从本地读取再转发出去。
- 需求背景:用户希望他登录之后,浏览器就帮他记住登录状态,这样他就不用每次进入的时候,都需要登录一次。session过期时间:如果我们没有设置
- 0.摘要本文介绍了生成连续和随机字母表的方法,用于快速生成大量字母数据。主要使用chr()函数,将数字通过ASCII表转换为相应字母。1.c
- 在编程时你一定碰到过时间触发的事件,在VB中有timer控件,而ASP中没有,假如你要不停地查询数据库来等待一个返回结果的话,我想你一定知道
- 我们前面介绍的Selenium的WebDriver测试方法是基于网页来进行的。之前的例子都是用简单的网页来操作,可能体会不到网页的加载过程,
- 在爬一个网站的时候,端点包含中文浏览器是可以自动解决这个转换的,在代码中就需要处理一下了。请求过程的异常如下:self._output(re
- 我们都知道有很多的非常著名的注册服务器,例如: Consul、ZooKeeper、etcd,甚至借助于redis完成服务注册发现。但是本篇文
- pytorch retain_graph==True的作用说明总的来说进行一次backward之后,各个节点的值会清除,这样进行第二次bac
- 现在大家都在讨论Web2.0 ,大家都在搞用户行为前端设计,现在注册一个ID一般只需要几秒钟,站长期望其产生高价值的UGC,形成一个只需要审
- 暂时是一个手动设置无向图中的边,用一个二维数组表示,后面会改进为用户自己定义无向图的边。学习python的新手,若大佬有解决的办法,希望不吝
- 1、开头:#!/usr/bin/python和# -*- coding: utf-8 -*-的作用 – 指定#!/usr/bin/pytho
- 在之前一篇文章中我介绍了通过定义Response宏的方式来实现动态改变模板文件路径以实现主题功能: laravel实现模板主题功能,但后来我
- 一、元素偏移量 offset 系列offset 翻译过来就是偏移量, 我们使用 offset 系列相关属性可以动态的得到该元素的位置(偏移)
- 好不容易有个周末,不能闲着,趁着这个时间安装sql server2016正式版,下载那个安装包都用了一个星期安装包可以从这里下载:http:
- 进行深度学习时,对图像进行预处理的过程是非常重要的,使用pytorch或者TensorFlow时需要对图像进行预处理以及展示来观看处理效果,
- 暴力的重启服务方案一般服务器重启可以直接通过 kill 命令杀死进程,然后重新启动一个新的进程即可。但这种方法比较粗暴,有可能导致某些正在处