今天开始的时间比昨天晚,其实午休的时间是差不多的,只是起来后稍微看了一点新闻,10分钟时间就没有了,所以要养成一个好习惯还真不容易,另外就是工作时间少看新闻,太浪费时间。

昨天在执行一个alter SQL语句时总是提示错误,看了好久才发现忘记写表名了,这也反映出对于基本的SQL操作还是不熟练,所以今天记录一下,由于alter table的内容很多,所以今天只是分析一下和add有关的内容。

一、语法定义

还是参考官方文档,其定义如下:

从这个定义上我们可以看到,必要的语句是

alter table tbl_name [command].

同时,这条语句还支持多个命令,相信很多人在修改一个表,比如增加几列时,都会写多个alter语句,但实际上一条就搞定了。

二、语义详解:

  下面我们对add相关的语法进行详细分析

  1. ADD  [COLUMN] col_name column_definition  [FIRST | AFTER col_name ]  | ADD [COLUMN] (col_name column_definition,...)

通过这个定义我们可以知道以下知识点:

   1)column关键字是可以省略的,以前我就闹过这个笑语,有同事写了个add 语句问我哪儿错了,我说是没有写column关键字。。现在想起简直好尴尬。

2)一条语句可以写多个add语句

   3)我们可以指定把这个列添加到某一列后面,或者是让其作为第一列,相应使用after col_name或first.

4)列的定义与创建表时报定义方式一致,即我们在写create table时怎么给列进行定义的,这儿就怎么定义

  2.  ADD {INDEX|KEY} [index_name] [index_type] (index_col_name,...) [index_option]

  这是添加普通索引的定义,主要有以下几点需要注意:

   1)需要使用INDEX或KEY来表明这是添加的一个索引,索引的名字可选。

   2)对于某些支持多种索引类型的引擎来说,我们可以指定索引的类型,指定的语句是使用USING 索引类型名,如果未指定,则使用第一个,具体如下:

Storage Engine Permissible Index Types
InnoDB BTREE
MyISAM BTREE
MEMORY/HEAP HASHBTREE
NDB HASHBTREE (see note in text)

     从上表我们可以看到,对于常用的InnoDB和MyISAM来说,其索引都只能是BTREE,所以这个index_type其实是没有必要指定的,通常情况下。

   3)index_col_name的定义是col_name[(length)] [ASC|DESC],即要作为索引的列及其顺序,支持多个列构成一个索引,默认情况下升序

   4)  index_option 指索引的一些附加信息,常用的是注释,形如comment 'this is a index'. 

3.  ADD [CONSTRAINT [symbol]] PRIMARY KEY [index_type] (index_col_name,...) [index_option]

这个语句表示添加主键约束,对于index_type,(index_col_name,..)及[index_option]来说前面已经解释过了,这里再解释一下 constraint [symbol].

   constraint 是约束的意思,后面可指定一个自定义的约束名,如果不提供,则mysql会自己生成一个约束名

4. ADD [CONSTRAINT [symbol]] UNIQUE [INDEX|KEY] [index_name] [index_type] (index_col_name,...) [index_option] ...

这个语句表示添加惟一约束,如果symbol和index_name都指定的话,则索引名取index_name,否则哪个指定了就取哪个,如果都没指定取列名,如果有多个列,取第一列的列名作为索引名

5.  ADD FULLTEXT [INDEX|KEY] [index_name] (index_col_name,...) [index_option] .

本语句表示添加全文索引, 其可选项不必再解释

6. ADD SPATIAL [INDEX|KEY] [index_name(index_col_name,...) [index_option]

      本语句表示添加空间索引, 其可选项也不必再解释

7. ADD [CONSTRAINT [symbol]] FOREIGN KEY [index_name] (index_col_name,...) reference_definition

本语句表示添加外键,需要注意的是reference_definition, 其形式如下:REFERENCES tbl_name (index_col_name,...), 即要指明关联到哪个表的哪个字段,或者是哪些字段。

三、总结

通过分析我们可以发现,使用alter table add类的语句,主要用于添加新的列和新的索引,对于索引的创建来说,有专门的create index 语句,这个相当于是另一种写法。记住了这个语句,我们就可以很方便的去对表结构做一些调整。

  

强大的修改数据库修改语句ALTER TABLE(一)[20160712]的更多相关文章

  1. ORACLE中通过SQL语句(alter table)来增加、删除、修改字段

    1.添加字段: alter table  表名  add (字段  字段类型)  [ default  '输入默认值']  [null/not null]  ; 2.添加备注: comment on ...

  2. sql语句-ALTER TABLE

    在工作中常遇到要维护数据库表的列,这里主要介绍sql语句中的ALTER TABLE 语句.ALTER TABLE 语句用于在已有的表中添加.修改或删除列. 如需在表中添加列,请使用下列语法: ALTE ...

  3. mysql数据库操作语句大全

    一 . 常用mysql命令行命令 1 .启动MYSQL服务  net start mysql 停止MYSQL服务  net stop mysql 2 . netstat –na | findstr 3 ...

  4. alter table 修改表结构规范

    use database_name; ) )), ADD INDEX index_time ( `timeId` ); # 添加主键: alter table table_name add prima ...

  5. sql语句修改数据库字段的长度

    修改字段的长度 alter table [OtpimizeRoute_Test].[dbo].[T_QueueFile] alter column ListFileName nvarchar()

  6. 【转】SQL 语句:Alter table

    转载自:http://www.w3school.com.cn/sql/sql_alter.asp ALTER TABLE 语句 ALTER TABLE 语句用于在已有的表中添加.修改或删除列. SQL ...

  7. MSSQL 修改数据库的排序规则

    1.修改数据库排序规则 ALTER DATABASE [CHARACTER] COLLATE Chinese_PRC_CI_AS ; 2.修改表中列的排序规则 如果下列其中之一当前正在引用一个列,则无 ...

  8. MSSQL2005 修改数据库的排序规则

    1.修改数据库排序规则ALTER DATABASE [DataBaseName] COLLATE Chinese_PRC_CI_AS ; 2.修改表中列的排序规则 如果下列其中之一当前正在引用一个列, ...

  9. SQL ALTER TABLE 语句

    ALTER TABLE 语句 ALTER TABLE 语句用于在已有的表中添加.修改或删除列. SQL ALTER TABLE 语法 如需在表中添加列,请使用下列语法: ALTER TABLE tab ...

随机推荐

  1. CentOS 6.5 Python 2.6.6+Flask 用wsgi方式部署在Apache 2.2.15下

    1,安装wsgi Apache模块 easy_install mod_wsgi 2,添加/etc/httpd/conf.d/wsgi.conf LoadModule wsgi_module modul ...

  2. Android 自定义View实现多行RadioGroup (MultiLineRadioGroup)

    一.项目概况 我们都知道RadioGroup可以实现选择框,但它有一个局限性,由于它是继承自LinearLayout的,所以只能有一个方向,横向或者纵向:但有时候仅一行的RadioGroup并不能满足 ...

  3. LevelDB(v1.3) 源码阅读之 Arena(内存管理器)

    LevelDB(v1.3) 源码阅读系列使用 LevelDB v1.3 版本的代码,可以通过如下方式下载并切换到 v1.3 版本的代码: $ git clone https://github.com/ ...

  4. mysql 启动错误-server PID file could not be found

    [root@centos var]# service mysqld stop MySQL manager or server PID file could not be found!       [F ...

  5. ReentrantLock的使用

    class BoundedBuffer { final Lock lock = new ReentrantLock(); final Condition notFull = lock.newCondi ...

  6. php生成随机密码(php自定义函数)转自先锋教程网

    php生成随机密码(php自定义函数) 时间:2015-12-16 20:43:49来源:网络 导读:php随机密码的生成代码,使用php自定义函数生成指定长度的随机密码,密码规则为小写字母与数字的随 ...

  7. JavaScript备忘录(1)——内置类型

    JavaScript有一些内置类型,还有很多常用的内置的方法,本文稍作总结,以备查阅. 值类型 我的理解,值类型是分配在栈上的,而引用类型(当然也包括引用类型内部的值类型)是分配在堆上的.值类型是不可 ...

  8. sqlmap 技巧整理

    收集了一些利用Sqlmap做注入测试的TIPS,其中也包含一点绕WAF的技巧,便于大家集中查阅,欢迎接楼补充.分享. TIP1 当我们注射的时候,判断注入 http://site/script?id= ...

  9. bootstrap插件学习-bootstrap.button.js

    先看bootstrap.button.js的结构 var Button = function ( element, options ){} //构造器 Button.prototype = {} // ...

  10. 如何自学Android--转

    原文地址:http://blog.csdn.net/lavor_zl/article/details/51217319 1. Java知识储备 本知识点不做重点讲解: 对于有基础的同学推荐看<J ...