SQL 高级语法 (三)

1、UNION 操作符

说明:UNION 操作符用于合并两个或多个 SELECT 语句的结果集(UNION 内部的每个 SELECT 语句必须拥有相同数量的列,列也必须拥有相似的数据类型,同时,每个 SELECT 语句中的列的顺序必须相同)

语法:

  • UNION 操作符选取不同的值
SELECT column_name(s) FROM table1 UNION SELECT column_name(s) FROM table2;
  • 允许重复的值,请使用 UNION ALL
SELECT column_name(s) FROM table1 UNION ALL SELECT column_name(s) FROM table2;

实例:

1)从 "websites" 和 "apps" 表中选取所有不同的country(只有不同的值)

SELECT country FROM websites UNION ALL SELECT country FROM apps;

2)从 "websites" 和 "apps" 表中选取所有的country='US'的数据(也有重复的值)

SELECT country, name FROM websites WHERE country='US' UNION ALL SELECT country, app_name FROM apps WHERE country='US';

2、INSERT INTO SELECT 语句

说明:INSERT INTO SELECT 语句从一个表复制数据,然后把数据插入到一个已存在的表中,目标表中任何已存在的行都不会受影响。

语法:

INSERT INTO table2 SELECT * FROM table1;

或者

INSERT INTO table2 (column_name(s)) SELECT column_name(s) FROM table1;

实例:

1)复制 "apps" 中的数据插入到 "websites" 中

INSERT INTO websites (name, country) SELECT app_name, country FROM apps;

2)只复制"apps"表中app_name和country列的id=1的行内容到”website“表中

INSERT INTO websites (name, country) SELECT app_name, country FROM apps WHERE id=1;

3、CREATE DATABASE 语句

说明:用于创建数据库。

语法:

CREATE DATABASE dbname;

实例:

CREATE DATABASE test_db;

4、CREATE TABLE  语句

说明:用于创建数据库中的表

语法:

CREATE TABLE table_name
(
column_name1 data_type(size),
column_name2 data_type(size),
....
);

注:column_name 参数规定表中列的名称。

data_type 参数规定列的数据类型(例如 varchar、integer、decimal、date 等等)。

size 参数规定表中列的最大长度。

实例:

CREATE TABLE Persons
(
PersonID int,
LastName varchar(255),
FirstName varchar(255),
Address varchar(255),
City varchar(255)
);

5、SQL 约束

说明:约束用于规定表中的数据规则,如果存在违反约束的数据行为,行为会被约束终止,约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。

语法:

CREATE TABLE table_name
(
column_name1 data_type(size) constraint_name,
column_name2 data_type(size) constraint_name,
....
);

实例:

CREATE TABLE Persons
(
Id_P int NOT NULL PRIMARY KEY,   //PRIMARY KEY约束
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
);

6、NOT NULL 约束

说明:NOT NULL 约束强制列不接受 NULL 值。

实例:

1)强制 "ID" 列、 "LastName" 列以及 "FirstName" 列不能为空值

CREATE TABLE Persons
( ID int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255) NOT NULL,
Age int );

2)已创建的表的 "Age" 字段中添加 NOT NULL 约束

ALTER TABLE Persons MODIFY Age int NOT NULL;

3)一个已创建的表的 "Age" 字段中删除 NOT NULL 约束

ALTER TABLE Persons MODIFY Age int NULL;

7、UNIQUE 约束

说明:约束唯一标识数据库表中的每条记录。

UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证,PRIMARY KEY 约束拥有自动定义的 UNIQUE 约束,但每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。

实例:

1)在 "Persons" 表创建时在 "P_Id" 列上创建 UNIQUE 约束

MySQL用法

CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
UNIQUE (P_Id)
);

Oracle用法

CREATE TABLE Persons
(
P_Id int NOT NULL UNIQUE,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
);

2)命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束

CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT uc_PersonID UNIQUE (P_Id,LastName)
);

3)在表已被创建后,在 "P_Id" 列创建 UNIQUE 约束

ALTER TABLE Persons ADD UNIQUE (P_Id);

4)在表已被创建后命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束

ALTER TABLE Persons ADD CONSTRAINT uc_PersonID UNIQUE (P_Id,LastName);

5)撤销 UNIQUE 约束

MySQL用法

ALTER TABLE Persons DROP INDEX uc_PersonID;

Oracle用法

ALTER TABLE Persons DROP CONSTRAINT uc_PersonID;

8、PRIMARY KEY 约束

说明:约束唯一标识数据库表中的每条记录。

主键必须包含唯一的值,主键列不能包含 NULL 值,每个表都需有一个主键且只能有一个主键。

实例:

1) 在 "Persons" 表创建时在 "P_Id" 列上创建 PRIMARY KEY 约束

MySQL用法

CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
PRIMARY KEY (P_Id)
);

Oracle用法

CREATE TABLE Persons
(
P_Id int NOT NULL PRIMARY KEY,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
);

2)命名 PRIMARY KEY 约束,并定义多个列的 PRIMARY KEY 约束

CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT pk_PersonID PRIMARY KEY (P_Id,LastName)
);

注:只有一个主键 PRIMARY KEY(pk_PersonID),但pk_PersonID 的值是由两个列(P_Id 和 LastName)组成的

3)当表已被创建时,在 "P_Id" 列创建 PRIMARY KEY 约束

ALTER TABLE Persons ADD PRIMARY KEY (P_Id);

4)表已被创建时,命名 PRIMARY KEY 约束,并定义多个列的 PRIMARY KEY 约束

ALTER TABLE Persons ADD CONSTRAINT pk_PersonID PRIMARY KEY (P_Id,LastName);

 注:如果您使用 ALTER TABLE 语句添加主键,必须把主键列声明为不包含 NULL 值(在表首次创建时)

5)撤销 PRIMARY KEY 约束

MySQL用法

ALTER TABLE Persons DROP PRIMARY KEY;

Oracle用法

ALTER TABLE Persons DROP CONSTRAINT pk_PersonID;

9、FOREIGN KEY 约束

说明:一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY

示例说明:"Orders" 中的 "Id_P" 列指向 "Persons" 表中的 "Id_P" 列,"Persons" 表中的 "Id_P" 列是 "Persons" 表中的 PRIMARY KEY,"Orders" 表中的 "Id_P" 列是 "Orders" 表中的 FOREIGN KEY。

实例:

1) 在 "Orders" 表创建时为 "Id_P" 列创建 FOREIGN KEY

MySQL用法

CREATE TABLE Orders
(
Id_O int NOT NULL,
OrderNo int NOT NULL,
Id_P int,
PRIMARY KEY (Id_O),
FOREIGN KEY (Id_P) REFERENCES Persons(Id_P)
);

Oracle用法

CREATE TABLE Orders
(
Id_O int NOT NULL PRIMARY KEY,
OrderNo int NOT NULL,
Id_P int FOREIGN KEY REFERENCES Persons(Id_P)
);

2)命名 FOREIGN KEY 约束,以及为多个列定义 FOREIGN KEY 约束

CREATE TABLE Orders
(
Id_O int NOT NULL,
OrderNo int NOT NULL,
Id_P int,
PRIMARY KEY (Id_O),
CONSTRAINT fk_PerOrders FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P)
);

3)在 "Orders" 表已存在的情况下为 "Id_P" 列创建 FOREIGN KEY 约束

ALTER TABLE Orders ADD FOREIGN KEY (Id_P) REFERENCES Persons(Id_P);

4)命名 FOREIGN KEY 约束,以及为多个列定义 FOREIGN KEY 约束

ALTER TABLE Orders ADD CONSTRAINT fk_PerOrders FOREIGN KEY (Id_P) REFERENCES Persons(Id_P);

5)撤销 FOREIGN KEY 约束

MySQL用法

ALTER TABLE Orders DROP FOREIGN KEY fk_PerOrders;

Oracle用法

ALTER TABLE Orders DROP CONSTRAINT fk_PerOrders;

10、CHECK 约束

说明:CHECK 约束用于限制列中的值的范围,如果对单个列定义 CHECK 约束,那么该列只允许特定的值,如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。

实例:

1) 在 "Persons" 表创建时为 "Id_P" 列创建 CHECK 约束,CHECK 约束规定 "Id_P" 列必须只包含大于 0 的整数。

MySQL用法

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CHECK (Id_P>0)
);

Oracle用法

CREATE TABLE Persons
(
Id_P int NOT NULL CHECK (Id_P>0),
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
);

2)命名 CHECK 约束,以及为多个列定义 CHECK 约束

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
);

3)在表已存在的情况下为 "Id_P" 列创建 CHECK 约束

ALTER TABLE Persons ADD CHECK (Id_P>0);

4)在表已存在的情况下命名 CHECK 约束,以及为多个列定义 CHECK 约束

ALTER TABLE Persons ADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes');

5)撤销 CHECK 约束

MySQL用法

ALTER TABLE Persons DROP CHECK chk_Person;

Oracle用法

ALTER TABLE Persons DROP CONSTRAINT chk_Person;

11、DEFAULT 约束

说明:用于向列中插入默认值,如果没有规定其他的值,那么会将默认值添加到所有的新记录。

实例:

1)在 "Persons" 表创建时为 "City" 列创建 DEFAULT 约束

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255) DEFAULT 'Sandnes'
);

2)通过使用类似 GETDATE() 这样的函数,DEFAULT 约束也可以用于插入系统值

CREATE TABLE Orders
(
Id_O int NOT NULL,
OrderNo int NOT NULL,
Id_P int,
OrderDate date DEFAULT GETDATE()
);

3)在表已存在的情况下为 "City" 列创建 DEFAULT 约束

MySQL用法

ALTER TABLE Persons ALTER City SET DEFAULT 'SANDNES';

Oracle用法

ALTER TABLE Persons ALTER COLUMN City SET DEFAULT 'SANDNES';

4)撤销 DEFAULT 约束

MySQL用法

ALTER TABLE Persons ALTER City DROP DEFAULT;

Oracle用法

ALTER TABLE Persons ALTER COLUMN City DROP DEFAULT;

12、DEFAULT 约束

说明:用于在表中创建索引

语法:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值