CREATE语句的开头都是一样的,然后是特定的细节。

CREATE <object type> <object name>  

一、CREATE DATABASE

  CREATE DATABASE命令用于创建一个数据库,创建一个数据库的最基本语法如下所示:

CREATE DATABASE <database name>

  CREATE DATABASE的完整语法

CREATE DATABASE <NewDataBase>
[ON [PRIMARY]
([NAME = <'logical file name'>,]
FILENAME = <'file name'>
[, SIZE = <size in kilobytes,megabytes,gigabytes,or terabytes>]
[, MAXSIZE = <size in kilobytes,megabytes,gigabytes,or terabytes>]
[, FILEGROWTH = <kilobytes,megabytes,gigabytes,or terabytes|percentage>])]
[LOG ON
([NAME = <'logical file name'>,]
FILENAME = <'file name'>
[, SIZE = <size in kilobytes,megabytes,gigabytes,or terabytes>]
[, MAXSIZE = <size in kilobytes,megabytes,gigabytes,or terabytes>]
[, FILEGROWTH = <kilobytes,megabytes,gigabytes,or terabytes|percentage>])]
[COLLATE <collation name>]
[FOR ATTAH [WITH <service broker>]| FOR ATTACH_REBUILD_LOG| WITH DB_CHAINING
ON| OFF | TRUSTWORTHY ON|OFF]
[AS SNAPSHOT OF <source database name>]
[;]

  说明一下:

  1、ON

  ON用于两个地方:一是定义存储数据的文件位置,二是定义存储日志的文件位置。PRIMARY意味着随后是存储数据的主文件组。也可以将数据存储在所谓的附属文件组里。

  SQL Server允许将数据库存储在多个文件中,而且允许将这些文件放在一个逻辑组里面,称为文件组

  2、NAME

  这个选项用于指定定义的文件的名称,但只是一个逻辑名称-SQL Server在内部使用该名称引用该文件。当需要修改(扩充或缩小)数据库和/或文件的大小事,需要使用这个名称。

  3、FILENAME

  这个选项,顾名思义-实际操作系统文件在磁盘上的物理名称,在该文件中将存储数据或日志(取决于定义哪个部分)。默认情况下,文件位于\Program Files\Microsoft SQLServer10.MSSQLSERVER\MSSQL(或者SQL Server安装主目录)的\Data子目录下。如果是处理物理数据库文件,那么名称将和数据库名称一样,但是带有.mdf扩展名。如果处理日志文件,那么名称和数据库文件的名称一样,但是有后缀_Log以及扩展名.ldf。建议使用默认扩展名.mdf(数据库)和.ldf(日志文件)。附属文件的扩展名是.ndf。

  4、SIZE

  数据库的初始大小。默认情况下大小的单位是M(兆字节),但是可以通过在数字后面使用KB而不是MB来指定kilobyte(千字节),或者更大的单位GB或者甚至TB。这个值至少与模型数据库一样大,而且必须是整数(不能带小数),否则出错。如果没有为SIZE提供一个值,那么数据库的初始大小值与模型数据库一样。

  5、MAXSIZE

  SQL Server有一个机制允许数据库在必要的时候自动分配附加的磁盘空间(增加大小)。MAXSIZE是数据库可以增加的最大大小。默认情况下,单位是M,但是同SIZE一样,可以使用KB、GB、TB来指定不同的单位。稍微不同的是,这个选项没有固定的默认值。如果没有提供这个值,那么认为没有最大值-实际的大小可以达到磁盘空间用完为止。

  如果数据库的大小达到了MAXSIZE参数指定的值,那么将开始出错,插入数据将不能执行。如果日志达到最大值,那么在数据库中将无法执行任何日志活动。

  6、FILEGROWTH

  FILEGROWTH主要用于确定数据库达到这个最大值的速度。提供一个值来说明文件每次增加多少字节(以KB、MB、GB、TB为单位)。或者,也可以按照指定数据库文件的每次增长百分比。如果选择百分比,那么数据库大小将按照当前数据文件的大小以指定的百分比增长。因此,如果指定一个初始大小为1GB的数据库文件以20%的速度增长,那么第一次扩展后为1.2GB,第二次扩展后为1.44GB。

  7、LOG ON

  LOG ON选项允许指定哪些文件需要日志,以及这些文件位于什么位置。如果没有指定该选项,那么SQL Server将在一个单独文件中创建日志,日志文件默认的大小是数据库文件的25%。在大多数其他方面,日志文件与主数据库文件具有同样的文件规范参数。

  提示:

  日志文件最好存储在与主数据文件不同的磁盘分区上。这样除了提供针对某个磁盘驱动器失效的额外安全措施外,还可以避免主数据文件与日志文件竞争磁盘文件的输入输出口。

  8、COLLATE

  该选项处理排序、字母大小写以及是否重音敏感问题。在安装SQL Server时,提供了默认的排序规则,但是可以在数据库层重写该默认值。

  9、FOR ATTACH

  可以使用该选项将已存在的一些数据库文件附加到当前的服务器上。这里的文件必须是数据库的一部分,并且在某个时候已经使用sp_detach_db恰当地与数据库分离了。这样贬低了sp_detach_db的功能,但是带有FOR ATTACH的CREATE DATABASE命令具有可以访问32000多个文件的优点,而sp_attach_db只限于16个文件。

  如果使用FOR ATTACH,那么必须完成文件位置信息中的ON PRIMARY部分的设置。CREATE DATABASE参数列表的其他部分可以省略,只要把数据库的文件路径附加到与原来数据库分离时相同的文件路径中。

  10、WITH DB CHAINING ON|OFF

  如果打开该选项,那么跨数据库的所有权链有效,而关闭该选项,则所有权链无效。

  11、TRUSTWORTHY

  这个选项是新添加的选项,为访问在SQL Server环境以外的系统资源和文件添加额外的安全层。例如,可能运行.NET程序集访问网络上的文件,如果这样的话,那么必须检查数据库确保程序集是可以信赖的。由于安全原因,这个选项在默认情况下是关闭的-在确实明白您将要做的事情和原因之后,再打开这个选项。

  示例:

CREATE DATABASE Accounting
ON
(
NAME = 'Accounting',  --数据库名称
FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\DATA\AccountingData.mdf',  --数据库文件位置
SIZE = 10,  --大小 10M
MAXSIZE = 50,  --最大大小 50M
FILEGROWTH = 5  --每次增加 5M
)
LOG ON
(
NAME = 'AccountingLog',
FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\DATA\AccountingLog.ldf',
SIZE = 5MB,
MAXSIZE = 25MB,
FILEGROWTH = 5MB
)

二、CREATE TABLE

  创建表的完整语法:

  CREATE TABLE [database_name.[owner].]table_name
  (
    <column name> <data type>
    [[DEFAULT <constant expression>] | [IDENTITY [(seed,increment) [NOT FOR REPLICATION]]]]
    [ROWGUIDCOL]
    [COLLATE <collation name>]
    [NULL|NOT NULL]      --是否允许为空
    [<column constraints>]  --列约束
    | [column_name AS compute_column_expression]
    | [<table_constraint>]  --表约束
    [,...n]
  )
  [ON{<filegroup>|DEFAULT}]
  [TEXTIMAGE_ON{<filegroup>|DEFAULT}]

  1、表名(table_name)和列名(column name)

  命名标准:

  [1] 对于名称的每个单词,要求首字母大写,而其他字母小写。

  [2] 当名称中有两个单词时,不要使用任何分隔符,通过将每个单词首字母大写来区分单词。其实关于下划线,差别不大。顺自己意愿。

  [3] 名称尽量短,但是要限制缩写,只有大家一看就看的明白的情况下才缩写。当缩写之后不容易看懂,不要缩写。

  [4] 当基于其他表来构建表时,需要在新的表名中包含所有父表的名称。如电影表Movies与演员表Stars的关系表:MovieStars。

  2、IDENTITY

  在数据库设计中,标识符就是SQL Server自动分配一个序号给插入的每个行。SQL Server开始计数的数字称为种子值,而这个值随着每行增加或减少的数量值称为增量。默认情况下种子值为1,增量为1,很多设计要求不要改动设个默认设置,不过,也可以设定种子为3,增量为5等,这种情况下,将从3开始计数,然后每次加5。得到8、13、18、23等。

  标识列必须是数值类型,在实际中,通常使用整型或大整型实现。

  标识符最常见的用法是生成一个新值作为每行的标识符,即标识列通常用于创建表的主键,但是IDENTITY与PRIMARY KEY是不同的概念,即不会因为有一个IDENTITY列就说明这个值是唯一的(例如可以重复设置种子值,使用前面用过的值)。IDENTITY值通常用于PRIMARY KEY列,但并不是必须这样使用。

  3、NOT FOR REPLICATION

  NOT FOR REPLICATION参数决定了当列发布到另一个数据库时,是为新的数据库分配一个新的标识列,还是保留已有的值。

  4、ROWGUIDCOL

  这个很像标识列,即用于唯一标识表的每行。当启用ROWGUIDCOL后,SQL Server没有采用数字技术,而是采用全局唯一标识符(Globally Unique Identifier)。这样即使将两张表的数据复制到一个表也没有问题,因此GUID在空间和时间上都是唯一的。

  5、COLLATE

  这个选项与在CREATE DATABASE命令中的作用基本一样,主要区别是作用范围,这里是在列的层次而不是数据库的层次定义的。

  6、NULL/NOT NULL

  这个选项说明指定列是否接受NULL值,在第一次安装SQL Server时,默认的列值是NOT NULL,除非指定允许为空。

  7、计算列

  可以创建一个本身没有任何数据的列,但列值是由表中其他列动态生成的。因为如果查询时指定列值,能给应该带来方便。

  具体语法如下:

  <column name> AS <computed column expression>

  示例:

  ExtendPrice AS Price * Quantity

  在上面的例子中,ExtendPrice的值是根据Price和Quantity计算得来。

  注意事项:

  1、不能使用子查询,而且值不能来自其他不同的表。

  2、可以在计算列上创建索引,但是必须采用特定的步骤。

  8、表约束

  表约束和列约束很相似,都是对可以插入表中的数据进行限制。它们之间有一点不同的是:表约束可以基于多个列。

  9、ON

  在处理数据库创建时,提到过可以创建不同的文件组,表定义中的ON子句就是用于指定希望表位于哪个文件组的一种方法。可以将给定的表放在一个特定的物理设备上,或者就按照大多数时候做的那样,省略ON子句。

  10、TEXTIMAGE_ON

  这个选项和前面讲到过的ON子句基本上相同,不同的是将该选择将表的特定部分移动到不同的文件组中。这个子句只有在表的定义中有text、ntext或image时才有效。当使用TEXTIMAGE_ON子句时,只是将BLOB信息移动到分离的文件组中--表的其他部分还在默认文件组或者ON子句选择的文件组中。

  示例:

  USE Accounting
  CREATE TABLE Customers
  {
    CustomerNo    int       IDENTITY NOT NULL,
    CostomerName   varchar(30)  NOT NULL,
    Address1     varchar(30)  NOT NULL,
    Address2     varchar(30)  NOT NULL,
    City        varchar(20)  NOT NULL
    State       char(2)    NOT NULL,
    Zip        varchar(10)  NOT NULL,
    Contact      varchar(25)  NOT NULL,
    Phone       char(15)    NOT NULL,
    FedIDNo      varchar(9)   NOT NULL,
    DateInSystem   smalldatetime NOT NULL
  }

  在CREATE代码前面添加USE<database name>行,这样能够确保当运行脚本时,是在所指定的数据库中创建表。

三、ALTER语句

  与CREATE语句很相似,ALTER语句的开头总有一样的:

ALTER <object type> <object name>

  1、ALTER DATABASE

  具体语法如下:

ALTER DATABASE <database name>
ADD FILE
([ NAME = <'logical file name'>,]
FILENAME = <'file name'>
[, SIZE = <size in KB,MB,GB or TB>]
[, MAXSIZE = < size in KB,MB,GB or TB>]
[, FILEGROWTH = <No of KB,MB,GB or TB | percentage>])
     [,...n][ TO FILEGROUP filegroup_name]
     [, OFFLINE]
|ADD LOG FILE
([ NAME = <'logical file name'>, ]
FILENAME = <'file name'>
[, SIZE = <size in KB,MB,GB or TB>]
[, MAXSIZE = < size in KB,MB,GB or TB>]
[, FILEGROWTH = <No of KB,MB,GB or TB | percentage>])
| REMOVE FILE <logical file name> [WITH DELETE]
| ADD FILEGROUP <filegroup name>
| REMOVE FILEGROUP <filegroup name>
| MODIFY FILE <filespec>
| MODIFY NAME = <new dbname>
| MODIFY FILEGROUP <filegroup name> {<filegroup property> | NAME = <new filegroup name>}
| SET <optionspec> [,...n][WITH <termination>]
| COLLATE <collation name>

  示例:将数据库扩充至100MB:

    ALTER DATABASE Accounting
  MODIFY FILE
(
NAME = Accounting,
SIZE = 100MB
)

  2、ALTER TABLE

  具体语法:

  ALTER TABLE table_name
{  [ALTER COLUMN <column_name>
{[<schema of new data type>].<new_data_type>[(precision [,scale])] max |
<xml schema collection> [COLLATE <collation_name>][NULL | NOT NULL] | [{ADD | DROP} ROWGUIDCOL] | PERSISTED}]
|ADD <column name> <data_type>
[[DEFAULT <constant_expression>] | [IDENTITY [(<seed>,<increment>)[NOT FOR REPLICATION]]]]
[ROWGUIDCOL]
[COLLATE <collation_name>]
[NULL | NOT NULL]
[<column_constraints>]
|[<column_name> AS <computed_column_expression>]
|ADD [CONSTRAINT <constraint_name>]
{  [{PRIMARY KEY | UNIQUE}
[CLUSTERED | NONCLUSTERED]
{(<column_name>[,...n])}
[WITH FILLFACTOR = <fillfactor>]
[ON {<filegroup> | DEFAULT}]
]
|FOREIGN KEY
[(<column_name>[,...n])]
REFERENCES <referenced_table> [(<referenced_column>[,,,n])]
[ON DELETE {CASCADE | NO ACTION}]
[ON UPDATE {CASCADE | NO ACTION}]
[NOT FOR REPLICATION]
| DEFAULT <constant_expression>
[FOR <column_name>]
| CHECK [NOT FOR REPLICATOPM]
(<search_conditions>)
[,...n][,...n]
|[WITH CHECK|WHTH NOCHECK]
|{ENABLE | DISABLE } TRIGGER
{ALL | <trigger name> [,...n]}
|DROP
{[CONSTRAINT] <constraint_name>
|COLUMN <column_name>}[,...n]
|{CHECK|NOCHECK} CONSTRAING
{ALL|<constraint_name>[,...n]}
|{ENABLE|DISABLE} TRIGGER
{ALL|<trigger_name>[,...n]}
| SWITCH [PARTITION <source partition number expression>]
TO [ schema_name. ] target_table
[PARTITION<target partition number expression>]
}

  下面给一些示例。

  添加一个列:

ALTER TABLE Employees
ADD
PreviousEmployer varchar(30) NULL

  执行以上语句后,语句是添加了,但是这些列是添加在列表的末尾,在SQL Server中没办法将列添加到特定位置。如果想将一个列移动到中间,那么需要创建一个全新的表,将数据复制到新表中,删除已有的表,然后将表重新命名。

四、DROP语句

  执行DROP语句与删除在DROP语句中引用的任何对象一样。这一操作快而简单,其语法对于所有主要的SQL Server对象(表、视图、存储过程及触发器)来说是相同的。语法如下所示:

DROP <object type> <object name> [,...n]

  以下给出一个同时删除两个表的例子:

  USE Accounting
  DROP TABLE Customer,Employess

  删除数据库的例子:

  USE master
  DROP DATABASE Accounting

  如果返回错误,数据库正在使用,不能删除的话,要检查一下两个问题。

  1、确保在Managerment Studio中的当前数据库不是要删除的数据库。

  2、确保没有打开其他显示要删除的数据库为当前数据库的连接。

T-SQL 之 DDL语法的更多相关文章

  1. SQL SERVER常用语法汇总

    阅读目录 一.SQL分类 二.基础语句 三.sql技巧 四.(MS SQL Server)SQL语句导入导出大全 回到目录 一.SQL分类 DDL—数据定义语言(CREATE,ALTER,DROP,D ...

  2. SQL中部分语法整理

    1.SELECT DISTINCT 语句 关键词DISTINCT用于返回唯一不同的值. 语法: SELECT DISTINCT 列名称 FROM 表名称 2.SELECT INTO语句 SELECT ...

  3. SQL server存储过程语法及实例(转)

    存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程cr ...

  4. 动态sql语句基本语法--Exec与Exec sp_executesql 的区别

    http://www.cnblogs.com/goody9807/archive/2010/10/19/1855697.html 动态sql语句基本语法 1   :普通SQL语句可以用Exec执行   ...

  5. SQL VIEW 使用语法

    之前一直都不知道VIEW有什么作用,写程序的时候也很少遇到过,复习SQL语句的时候碰到了,就记录下来吧. 什么是视图? 在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表. 视图包含行和列, ...

  6. [SQL]动态sql语句基本语法

    动态sql语句基本语法 :普通SQL语句可以用Exec执行 eg: Select * from tableName Exec('select * from tableName') Exec sp_ex ...

  7. SQL[连载2]语法及相关实例

    SQL[连载2]语法及相关实例 SQL语法 数据库表 一个数据库通常包含一个或多个表.每个表由一个名字标识(例如:"Websites"),表包含带有数据的记录(行). 在本教程中, ...

  8. SQL语句方法语法总结(二)

    1.给表插入数据. (1)INSERT INTO TBL_NAME VALUES (VALUE_1,VALUE_2,...) (2)INSERT INTO TBL_NAME (COL_1,COL_2, ...

  9. JAVA-Unit01: 数据库原理 、 SQL(DDL、DML)

    Unit01: 数据库原理 . SQL(DDL.DML) SQL语句是不区分大小写的,但是行业里习惯将关键字与分关键字用大小写岔开以提高可读性. SELECT SYSDATE FROM dual DD ...

  10. SQL语句基本语法总结

    SQL语句基本语法 表的创建.修改.删除: 表中数据的增加.修改.删除.查看: SQL的 语法.数据类型.约束.删除表中数据(2种方法).语句查询的执行顺序: 查询 单列.多列.全部 子查询 单行子查 ...

随机推荐

  1. 请画出Servlet 2.2以上Web Application的基本目录结构

    Java web工程下的webapp或WebContent就是工程的发布文件夹,发布时会把该文件夹发布到tomcat的webapps里. 一个web应用必须要有的目录文件如下: webapp/WebC ...

  2. poj2531(深搜剪枝)

    题意就是把节点分成A.B两组,节点间距C给了,要求解分组的方法,使得∑Cij (i∈A,j∈B)最大. 首先把所有节点都放在一组,然后采用深度优先搜索的方法,对每一个节点都做判断是否应该移到另一组去, ...

  3. poj2299(树状数组+离散化)

    这道题题意很简单,就是求逆序数.用暴力的方法是显然会超时的.这里考虑采用树状数组. 采用树状数组话遇到的问题就是需要999,999,999个空间来存放数据,这显然是不可行的.考虑到输入数据最多只有50 ...

  4. 【UOJ 79】 一般图最大匹配 (✿带花树开花)

    从前一个和谐的班级,所有人都是搞OI的.有 n 个是男生,有 0 个是女生.男生编号分别为 1,…,n. 现在老师想把他们分成若干个两人小组写动态仙人掌,一个人负责搬砖另一个人负责吐槽.每个人至多属于 ...

  5. BZOJ1552/3506 [Cerc2007]robotic sort

    Splay 与之前不同的是如果你仅仅是翻转左右区间的话可以在find里面做因为对他有影响的子树在做之前一定在他的上面从上到下搜索的过程可以把rever做了. 但这道题要求我们输出转换之前的,因此不能保 ...

  6. POJ 2406 Power Strings 简单KMP模板 strcmp

    http://poj.org/problem?id=2406 只是模板,但是有趣的是一个strcmp的字符串比较函数,学习到了... https://baike.baidu.com/item/strc ...

  7. 【tarjan+拓扑】BZOJ3887-[Usaco2015 Jan]Grass Cownoisseur

    [题目大意] 给一个有向图,然后选一条路径起点终点都为1的路径出来,有一次机会可以沿某条边逆方向走,问最多有多少个点可以被经过?(一个点在路径中无论出现多少正整数次对答案的贡献均为1) [思路] 首先 ...

  8. [CSAcademy]Squared Ends

    [CSAcademy]Squared Ends 题目大意: 给你一个长度为\(n(n\le10^4)\)的数列\(\{A_i\}(A_i\le10^6)\).定义区间\(A_{[l,r]}\)的代价为 ...

  9. trie--- POJ 3764 The xor-longest Path

    The xor-longest Path Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 5453   Accepted: 1 ...

  10. hihocoder编程收割赛20

    hihocoder编程收割赛20 hihocoder1542 : 无根数变有根树 hihocoder1542 思路: 树的遍历 ac代码: // hihocompete20_01.cpp : 定义控制 ...