用SQL创建数据库

2016-01-29 16:42 9 1 收藏

用SQL创建数据库,用SQL创建数据库

【 tulaoshi.com - SQLServer 】

首先说说怎么用SQL语句创建数据库,创建数据库的语句有如下几种: 
   1. CREATE TABLE(创建新表) 
   2. CREATE INDEX(增加索引) 
   3. DROP INDEX(删除索引) 
   4. CONSTRAINT(约束语句) 
   5. ALTER TABLE(修改表) 
   6. DROP TABLE(删除表) 

CREATE TABLE语句: 
在数据库中生成新表,表中字段的类型可以为:INTEGER(整型)、LONG(长整型)、 SINGLE(单精度浮点数)、DOUBLE(双精度浮点数)、DATETIME(日期型,也可以写成DATE)、BIT(布尔型)、 TEXT(字符串型,最大255个字节)、MEMO(字符串型,最大可达1.2G字节)、 COUNTER(自动递增长整型,可确定记录的唯一性)、CURRENCY(货币型,精确到小数点左边15位,右边4位)、 BINARY(字节型,最大255个)、LONGBINARY(用于OLE对象)、GUID(全局唯一标识符)。  
生成表NewTable,该表有文本字段Field1和整型字段Field2,表名和字段名可以随便你取,不区分大小写,但是,有些保留字不能用作表名字段名,比如Number  
CREATE TABLE NewTable(Field1 TEXT(30), Field2 INTEGER);  
CREATE INDEX语句: 
INDEX是为了加快查找记录的速度,或者是为了增加字段约束关系而设置的。  
创建索引语句执行前表中可以有记录,但存在的记录必须满足该索引语句的约束关系,否则语句不能执行,另外要注意的是在同一个数据库中(而不仅仅是在同一个表中),索引名不能相同,否则语句也会失败。  
生成字段Field1的索引字段NewIndex,两条语句作用相同 
生成后Field1字段可以有相同的值,可以有空值(NULL)  
CREATE INDEX NewIndex ON NewTable (Field1); 
CREATE INDEX NewIndex ON NewTable (Field1) WITH IGNORE NULL; 

生成字段Field1的索引字段NewIndex,注意,每个表里只能有一个主索引(PRIMARY)。生成后Field1字段不能有相同的值,不能有空值(当然,如果是TEXT类型,可以有一个空串,但是空串不是空值)  
CREATE INDEX NewIndex ON NewTable(Field1) WITH PRIMARY; 

字段Field1不能有相同的值,但可以有空值(两个空值不算相同的值)  
CREATE UNIQUE INDEX NewIndex ON NewTable(Field1); 

字段Field1可以有相同的值,但不能有空值  
CREATE INDEX NewIndex ON NewTable(Field2) WITH DISALLOW NULL 

可以在索引语句中加入ASC(升序)或DESC(降序)来控制记录排列顺序如果不使用顺序字,SQL则默认使用ASC顺序  
CREATE INDEX NewIndex ON NewTable(Field1 ASC, Field2 DESC);  
DROP INDEX语句: 
删除表NewTable中的索引NewIndex,语句执行前索引NewIndex必须存在  
DROP INDEX NewIndex ON NewTable; 

CONSTRAINT语句: 
CONSTRAINT子句用于创建数据库完整性的索引,它和INDEX语句作用一样,有些地方可以互相替代,它可以使用PRIMARY KEY(主关键字),UNIQUE(唯一)和FOREIGN KEY(外部关键字),和INDEX相比不能使用IGNOR NULL和DISALLOW NULL,但多了FOREIGN KEY(这也是它最强大的地方)。另外, CONSTRAINT语句必须和CREATE TABLE或ALTER TABLE语句一起使用。  
生成表NewTable,主关键字段是Field1,主索引是NewPK  
CREATE TABLE NewTable(Field1 LONG CONSTRAINT NewPK PRIMARY KEY, Field2 MEMO, Field3 DATETIME); 


生成索引为NewUK的表NewTable,Field1不能有相同值,可以有空值  
CREATE TABLE NewTable(Field1 INTEGER CONSTRAINT NewUK UNIQUE); 


生成多列的主索引,两条记录的Field1和Field2不能全部相同,也不能为空值  
CREATE TABLE NewTable(Field1 INTEGER, Field2 CURRENCY, CONSTRAINT NewPK PRIMARY KEY(Field1, Field2)); 


生成多列的UNIQUE索引,两条记录的Field1和Field2不能全部相同注意,如果两条记录其中一个字段相同而另一个字段都是空值,那也算两个字段不同 &

来源:https://www.tulaoshi.com/n/20160129/1499357.html

延伸阅读
标签: SQLServer
SQL Server 6.X使用设备(device)存储数据库,每个设备为操作系统上的一个磁盘文件, SQL Server 7.0是否也是这样? 不是。SQL Server 7.0的数据库不再使用设备存储, SQL Server 7.0每个数据库至少需要两个文件(数据和日志),数据和日志无法共享一个文件,并且每个文件只能给一个数据库使用,无法共享。 存放SQL Server 7.0数据库的磁...
笔者认为,在创建索引时要做到三个适当,即在适当的表上、适当的列上创建适当数量的索引。虽然这可以通过一句话来概括优化的索引的基本准则,但是要做到这一点的话,需要数据库管理员做出很大的努力。具体的来说,要做到这个三个适当有如下几个要求。 一、 根据表的大小来创建索引。 虽然给表创建索引,可以提高查询的效率。但是数...
我把数据库操作类整理了一下,它包含了常用的数据库操作,由三种方式:简单的SQL拼接字符串的形式,SQL语句使用参数的形式和存储过程的形式,每种形式均有五个方法,并且都有事务.,可以直接调用.代码如下: 1//====================================================================== 2// 3// Copyright (C) 2007-2008 三月软件工...
1:磁盘寻道能力,以高速硬盘(7200转/秒),理论上每秒寻道7200次.这是没有办法改变的,优化的方法是----用多个硬盘,或者把数据分散存储. 2:硬盘的读写速度,这个速度非常的快,这个更容易解决--可以从多个硬盘上并行读写. 3:cpu.cpu处理内存中的数据,当有相对内存较小的表时,这是最常见的限制因素. 4:内存的限制.当cp...
标签: ASP
  51windows(原作) 一个用asp备份与恢复SQL Server数据库的例子代码,希望对一些朋友有用。(注意:数据库使用中可能无法恢复) <HTML<HEAD<TITLESQL Server 数据库的备份与恢复</TITLE<meta http-equiv="Content-Type" content="text/html; charset=gb2312"</HEAD<BODY<form method="post" name=myform选择...

经验教程

378

收藏

66
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部