DDL中drop-alter table
一、DROP TABLE语句:用于删除数据表
DROP TABLE removes one or more tables.
You must have the DROP privilege for each table.
All table data and the table definition are removed, so be careful with this statement!
基本格式:
drop table <table_name>
DROP [TEMPORARY] TABLE [IF EXISTS]
tbl_name [, tbl_name] ...
[RESTRICT | CASCADE]
TEMPORARY:用于删除临时表(推荐针对性使用),删除临时表不会结束当前的事务
IF EXISTS:用于在表不存在时,阻止错误消息的显示
[RESTRICT | CASCADE]:现在什么也不做
其实删表语法如上,还是挺简单的,但是当一个表被删除时,所有依赖于该表的对象也被删除(例如约束、索引、视图和权限等)
所以,删除表之前(注意):
①确认这个表没有人在使用,确实是一个废除的表
②看好确认是这个数据库的表
顺带提一下,如何重命名表:
RENAME TABLE tbl_name TO new_tbl_name
[, tbl_name2 TO new_tbl_name2] …
当然,可以使用ALTER TABLE语句替换该语句,如下……
二、ALTER TABLE语句:添加、修改和删除列
基本格式:
1.修改表名:alter table 原表名 rename to 新表名;
2.新增列:alter table 表名 add [column] 列名 varchar(20) ;
3.删除列:alter table 表名 drop [column] 列名;
4.修改列名: alter table 表名 change 原列名 新列名 varchar(20) ;
5.修改列属性:alter table 表名 modify 列名 varchar(20) ;
ALTER [IGNORE] TABLE tbl_name
ADD [COLUMN] col_name column_definition
[FIRST | AFTER col_name ]
|ADD [COLUMN] (col_name column_definition,...)
|MODIFY [COLUMN] col_name column_definition
[FIRST | AFTER col_name]
|DROP [COLUMN] col_name
|CHANGE [COLUMN] old_col_name new_col_name column_definition
[FIRST|AFTER col_name]
FIRST:表示表头行
AFTER col_name:表示在col_name的后面,即下一行(没有before选项)
##Copy一张TEAMS表用作示例
mysql> create table teams_copy
-> as
-> select * from TEAMS;
1、添加列
①新列自动成为表中的最后一个列,除非指定了FIRST或AFTER选项(表中已有的行在新列上自动得到NULL值或默认值)
例1:添加type列给teams_copy表中
mysql> alter table teams_copy
-> add type1 char(); #添加的新列归位最后一个列 mysql> alter table teams_copy
-> add type2 char() default''; #添加列的同时设置默认值 mysql> alter table teams_copy
-> add type3 char() after PLAYERNO; #指定新列的位置 mysql> select * from teams_copy;
+--------+----------+-------+----------+-------+-------+
| TEAMNO | PLAYERNO | type3 | DIVISION | type1 | type2 |
+--------+----------+-------+----------+-------+-------+
| | | NULL | first | NULL | |
| | | NULL | second | NULL | |
+--------+----------+-------+----------+-------+-------+
②如果添加新列时指定了NOT NULL约束
则:
字符串列自动得到空字符串;
数字列自动得到0;
日期类型自动得到0日期;
时间类型自动得到00:00:00
mysql> alter table teams_copy
-> add (
-> type4 char() NOT NULL,
-> type5 INTEGER NOT NULL,
-> type6 DATE NOT NULL,
-> tpye7 time not null );
mysql> select * from teams_copy; #截的一部分图
2、删除列
列值是否有数据都可以删除,依赖于该列的其它数据库对象,如索引、权限也将被删除
mysql> alter table teams_copy
-> drop type6; mysql> alter table teams_copy drop type2;
mysql> alter table teams_copy drop type4;
mysql> alter table teams_copy drop type5; #只能一列一列的删 mysql> select * from teams_copy;
+--------+----------+-------+----------+-------+----------+
| TEAMNO | PLAYERNO | type3 | DIVISION | type1 | tpye7 |
+--------+----------+-------+----------+-------+----------+
| | | NULL | first | NULL | :: |
| | | NULL | second | NULL | :: |
+--------+----------+-------+----------+-------+----------+
3、修改列---经常用到
基本格式:
alter table <表名> modify <列名> 数据类型(……) 选项;
1)修改列的宽度:
如果是增加列宽,都无所谓
如果是减少列宽,就必须保证原有的值要能放得下,否则出错
2)改变数据类型时,列中的值必须能转变为新的类型
mysql> desc student;
+-------+---------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| id | int() | NO | PRI | NULL | |
| name | varchar() | NO | | NULL | |
| sex | enum('M','F') | YES | | NULL | |
+-------+---------------+------+-----+---------+-------+
rows in set (0.00 sec) mysql> select * from student;
+----+--------+------+
| id | name | sex |
+----+--------+------+
| | 张三 | M |
| | 李四 | F |
| | 王五 | NULL |
+----+--------+------+
rows in set (0.00 sec) mysql> alter table student
-> modify id smallint not null;
Query OK, rows affected (0.29 sec)
Records: Duplicates: Warnings: mysql> alter table student
-> modify name int not null;
ERROR (HY000): Incorrect integer value: '张三' for column 'name' at row
解析:student表中id列值可转换为新的数据类型,但是name列的值无法转变,所以modify失败。
3)修改列名(不要加引号)
mysql> alter table student
-> change id 学号 int; mysql> select * from student;
+--------+--------+------+
| 学号 | name | sex |
+--------+--------+------+
| | 张三 | M |
| | 李四 | F |
| | 王五 | NULL |
+--------+--------+------+
4、修改约束
可以添加或删除约束,但是不能修改一个已有的约束。
ALTER [IGNORE] TABLE tbl_name
ADD [CONSTRAINT [symbol]] PRIMARY KEY(col_name,...)
|ADD [CONSTRAINT [symbol]] UNIQUE (col_name,...)
|ADD [CONSTRAINT [symbol]] FOREIGN KEY (col_name,...)
References parent_table(col_name)
|DROP PRIMARY KEY
|DROP FOREIGN KEY fk_symbo
|DROP {INDEX|KEY} index_name
示例:定义两张表t1和t2
mysql> create table t1(
-> a int not null primary key,
-> b int not null); mysql> create table t2(
-> a int not null primary key,
-> b int not null,
-> constraint c1 unique(b),
-> constraint fk1 foreign key(a) references t1(a)
-> ); 1)删除唯一性约束:删除对应的索引(index)即可
mysql> alter table t2
-> drop index c1; 2)给t1添加外键约束,取名fk2
mysql> alter table t1
-> add constraint fk2 foreign key(a) references t2(a); 3)删除外键fk2
mysql> alter table t1
-> drop foreign key fk2; 4)删除t1表的主键
mysql> alter table t1
-> drop primary key;
DDL中drop-alter table的更多相关文章
- My Sql 中要Alter Table的同学请注意!!!
首先我建议你在对MySQL表做DDL操作时: 1 执行 show processlist 查看,要操作的表(数据库对象)是否处于锁状态 if("未锁定") { 执行DDL语句 }e ...
- oracle DDL(create、alter、drop)
一.创建表1.创建表CREATE TABLE <table_name>( column1 DATATYPE [NOT NULL] [PRIMARY KEY], column2 DATATY ...
- MySQL5.6 ALTER TABLE 分析和测试
在MySQL5.5和之前版本,在运行的生产环境对大表(超过数百万纪录)执行Alter操作是一件很困难的事情.因为将重建表和锁表,影响用户者的使用.因此知道Alter操作何时结束对我们是非常重要的.甚至 ...
- sql语句-ALTER TABLE
在工作中常遇到要维护数据库表的列,这里主要介绍sql语句中的ALTER TABLE 语句.ALTER TABLE 语句用于在已有的表中添加.修改或删除列. 如需在表中添加列,请使用下列语法: ALTE ...
- mysql 添加索引,ALTER TABLE和CREATE INDEX的区别
nvicat-->mysql表设计-->创建索引. (1)使用ALTER TABLE语句创建索引,其中包括普通索引.UNIQUE索引和PRIMARY KEY索引3种创建索引的格式: PRI ...
- [Hive - LanguageManual] Create/Drop/Alter Database Create/Drop/Truncate Table
Hive Data Definition Language Hive Data Definition Language Overview Create/Drop/Alter Database Crea ...
- SQL ALTER TABLE 语句在项目中的使用
1.在实际的项目开发过程中,之前已经创建好的实体类可能需要增加/删除字段,亦或是更改已有字段的属性,比如主键的增长策略从自增型改为UUID型,那么就会涉及到 SQL 中 alter table 语句的 ...
- ORACLE中通过SQL语句(alter table)来增加、删除、修改字段
1.添加字段: alter table 表名 add (字段 字段类型) [ default '输入默认值'] [null/not null] ; 2.添加备注: comment on ...
- problem during schema drop, statement alter table ACT_RU_VARIABLE
将activiti的databaseSchemaUpdate设置为drop-create抛出DbSqlSession 错误 发布于2015-02-14 16:03:57 浏览7851次 Excepti ...
随机推荐
- Vue和Bootstrap的整合之路
我是一个刚刚接触前端开发的新手,所以有必要记录如何将Bootstrap和Vue进行整合. 如果你是老手,请直接绕道而过.作为一个新手,里面的步骤,过程或者专业术语未必正确,如果你发现哪里错误了,请发邮 ...
- 遇到attemp to invoke virtual method
这个很大原因是没有预先初始化sdk,检查application的配置是否配置了application:name
- 0.搭建myeclipse开发环境
1.配置jdk 2.myeclipse集成tomcat 选择默认jdk
- java网络编程之socket(2)
异步处理多客户端连接服务端 上篇讲到的是服务端接收一个客户端的请求之后就结束了,不能再接收其他客户端的请求了,实际情况上我们希望服务端能够处理来自不同用户的请求. 想到这里,或许我们可以用一个死循环, ...
- asp.net mvc视图中使用entitySet类型数据时提示出错
asp.net mvc5视图中使用entitySet类型数据时提示以下错误 检查了一下引用,发现已经引用了System.Data.Linq了,可是还是一直提示出错, 后来发现还需要在Views文件夹下 ...
- BOM浏览器对象模型下面几个比较实用的方法
location对象 location.href-- 返回或设置当前文档的URL location.search -- 返回URL中的查询字符串部分.例如 http://www.dreamdu.com ...
- sublime text 3 配置python IDE
Python越来越受“程序猿”们的青睐.快速的开发模式,简洁的代码格式,海量的扩展,这无疑都为python的火热奠定了基础. “磨刀不误砍柴工”,一款功能强劲的IDE能帮助开发者有效的管理.编辑,运行 ...
- vue.js 组件之间传递数据
前言 组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用.如何传递数据也成了组件的重要知识点之一. 组件 组件与组件之间,还存在着不同的关 ...
- Wireshark网络端点和会话
如果想让网络进行正常通信,你必须至少拥有两台设备进行数据流交互.端点(endpoint)就是指网络上能够发送和接受数据的一台设备.举例来说,在TCP/IP的通信中就有两个断电:接收和发送数据系统的IP ...
- 事务之使用JDBC进行事务的操作2
本篇将讲诉如何使用JDBC进行数据库有关事务的操作.在上一篇博客中已经介绍了事务的概念,和在MySQL命令行窗口进行开启事务,提交事务以及回滚事务的操作. 似乎事务和批处理都可以一次同时执行多条SQL ...