)
SQL DEFAULT Constraint on ALTER TABLE
如果在表已存在的情况下为 \列创建 DEFAULT 约束,请使用下面的 SQL: MySQL:
ALTER TABLE Persons
ALTER City SET DEFAULT 'SANDNES' SQL Server / Oracle / MS Access:
ALTER TABLE Persons
ALTER COLUMN City SET DEFAULT 'SANDNES' 撤销 DEFAULT 约束
如需撤销 DEFAULT 约束,请使用下面的 SQL: MySQL:
ALTER TABLE Persons
ALTER City DROP DEFAULT
SQL Server / Oracle / MS Access: ALTER TABLE Persons
ALTER COLUMN City DROP DEFAULT
SQL CREATE INDEX 语句
CREATE INDEX 语句用于在表中创建索引。
在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据。 索引
您可以在表中创建索引,以便更加快速高效地查询数据。 用户无法看到索引,它们只能被用来加速搜索/查询。
注释:更新一个包含索引的表需要比更新一个没有索引的表更多的时间,这是由于索引本身也需要更新。因此,理想的做法是仅仅在常常被搜索的列(以及表)上面创建索引。 SQL CREATE INDEX 语法
在表上创建一个简单的索引。允许使用重复的值: CREATE INDEX index_name
ON table_name (column_name)
注释:\规定需要索引的列。 SQL CREATE UNIQUE INDEX 语法
在表上创建一个唯一的索引。唯一的索引意味着两个行不能拥有相同的索引值。 CREATE UNIQUE INDEX index_name ON table_name (column_name)
CREATE INDEX 实例
本例会创建一个简单的索引,名为 \,在 Person 表的 LastName 列: CREATE INDEX PersonIndex
36
ON Person (LastName)
如果您希望以降序索引某个列中的值,您可以在列名称之后添加保留字 DESC: CREATE INDEX PersonIndex ON Person (LastName DESC)
假如您希望索引不止一个列,您可以在括号中列出这些列的名称,用逗号隔开: CREATE INDEX PersonIndex
ON Person (LastName, FirstName)
SQL 撤销索引、表以及数据库
通过使用 DROP 语句,可以轻松地删除索引、表和数据库。 SQL DROP INDEX 语句
我们可以使用 DROP INDEX 命令删除表格中的索引。
用于 Microsoft SQLJet (以及 Microsoft Access) 的语法: DROP INDEX index_name ON table_name 用于 MS SQL Server 的语法:
DROP INDEX table_name.index_name 用于 IBM DB2 和 Oracle 语法: DROP INDEX index_name 用于 MySQL 的语法:
ALTER TABLE table_name DROP INDEX index_name
SQL DROP TABLE 语句
DROP TABLE 语句用于删除表(表的结构、属性以及索引也会被删除): DROP TABLE 表名称
SQL DROP DATABASE 语句
DROP DATABASE 语句用于删除数据库: DROP DATABASE 数据库名称
SQL TRUNCATE TABLE 语句
如果我们仅仅需要除去表内的数据,但并不删除表本身,那么我们该如何做呢? 请使用 TRUNCATE TABLE 命令(仅仅删除表格中的数据): TRUNCATE TABLE 表名称
SQL ALTER TABLE 语句 ALTER TABLE 语句
ALTER TABLE 语句用于在已有的表中添加、修改或删除列。 SQL ALTER TABLE 语法
如需在表中添加列,请使用下列语法:
37
ALTER TABLE table_name ADD column_name datatype 要删除表中的列,请使用下列语法: ALTER TABLE table_name DROP COLUMN column_name
注释:某些数据库系统不允许这种在数据库表中删除列的方式 (DROP COLUMN column_name)。 要改变表中列的数据类型,请使用下列语法: ALTER TABLE table_name
ALTER COLUMN column_name datatype 原始的表 (用在例子中的): Persons 表: Id 1 2 3 LastName Adams Bush Carter FirstName John George Thomas Address Oxford Street Fifth Avenue Changan Street City London New York Beijing SQL ALTER TABLE 实例 现在,我们希望在表 \中添加一个名为 \的新列。 我们使用下列 SQL 语句: ALTER TABLE Persons ADD Birthday date
请注意,新列 \的类型是 date,可以存放日期。数据类型规定列中可以存放的数据的类型。
新的 \表类似这样: Id 1 2 3 LastName Adams Bush Carter FirstName John George Thomas Address Oxford Street Fifth Avenue Changan Street City London New York Beijing Birthday 改变数据类型实例
现在我们希望改变 \表中 \列的数据类型。 我们使用下列 SQL 语句: ALTER TABLE Persons
ALTER COLUMN Birthday year
请注意,\列的数据类型是 year,可以存放 2 位或 4 位格式的年份。 DROP COLUMN 实例
接下来,我们删除 \表中的 \列: ALTER TABLE Person
38
DROP COLUMN Birthday Persons 表会成为这样: Id 1 2 3 LastName Adams Bush Carter FirstName John George Thomas Address Oxford Street Fifth Avenue Changan Street City London New York Beijing
SQL AUTO INCREMENT 字段
Auto-increment 会在新纪录插入表中时生成一个唯一的数字。 AUTO INCREMENT 字段
我们通常希望在每次插入新纪录时,自动地创建主键字段的值。 我们可以在表中创建一个 auto-increment 字段。 用于 MySQL 的语法
下列 SQL 语句把 \表中的 \列定义为 auto-increment 主键: CREATE TABLE Persons (
P_Id int NOT NULL AUTO_INCREMENT, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255), PRIMARY KEY (P_Id) )
MySQL 使用 AUTO_INCREMENT 关键字来执行 auto-increment 任务。 默认地,AUTO_INCREMENT 的开始值是 1,每条新纪录递增 1。
要让 AUTO_INCREMENT 序列以其他的值起始,请使用下列 SQL 语法: ALTER TABLE Persons AUTO_INCREMENT=100
要在 \表中插入新纪录,我们不必为 \列规定值(会自动添加一个唯一的值): INSERT INTO Persons (FirstName,LastName) VALUES ('Bill','Gates')
上面的 SQL 语句会在 \表中插入一条新纪录。\会被赋予一个唯一的值。\会被设置为 \,\列会被设置为 \。 用于 SQL Server 的语法
下列 SQL 语句把 \表中的 \列定义为 auto-increment 主键: CREATE TABLE Persons (
P_Id int PRIMARY KEY IDENTITY, LastName varchar(255) NOT NULL, FirstName varchar(255),
39
Address varchar(255), City varchar(255) )
MS SQL 使用 IDENTITY 关键字来执行 auto-increment 任务。 默认地,IDENTITY 的开始值是 1,每条新纪录递增 1。
要规定 \列以 20 起始且递增 10,请把 identity 改为 IDENTITY(20,10)
要在 \表中插入新纪录,我们不必为 \列规定值(会自动添加一个唯一的值): INSERT INTO Persons (FirstName,LastName) VALUES ('Bill','Gates')
上面的 SQL 语句会在 \表中插入一条新纪录。\会被赋予一个唯一的值。\会被设置为 \,\列会被设置为 \。 用于 Access 的语法
下列 SQL 语句把 \表中的 \列定义为 auto-increment 主键: CREATE TABLE Persons (
P_Id int PRIMARY KEY AUTOINCREMENT, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255) )
MS Access 使用 AUTOINCREMENT 关键字来执行 auto-increment 任务。 默认地,AUTOINCREMENT 的开始值是 1,每条新纪录递增 1。 要规定 \列以 20 起始且递增 10,请把 autoincrement 改为 AUTOINCREMENT(20,10) 要在 \表中插入新纪录,我们不必为 \列规定值(会自动添加一个唯一的值): INSERT INTO Persons (FirstName,LastName) VALUES ('Bill','Gates')
上面的 SQL 语句会在 \表中插入一条新纪录。\会被赋予一个唯一的值。\会被设置为 \,\列会被设置为 \。 用于 Oracle 的语法
在 Oracle 中,代码稍微复杂一点。
您必须通过 sequence 对创建 auto-increment 字段(该对象生成数字序列)。 请使用下面的 CREATE SEQUENCE 语法: CREATE SEQUENCE seq_person MINVALUE 1 START WITH 1 INCREMENT BY 1 CACHE 10
上面的代码创建名为 seq_person 的序列对象,它以 1 起始且以 1 递增。该对象缓存 10 个值以提高性能。CACHE 选项规定了为了提高访问速度要存储多少个序列值。
40