zoukankan      html  css  js  c++  java
  • 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 约束

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

    语法:

    一入运维深似海,从此不见彼岸花
  • 相关阅读:
    SQL Server需要监控哪些计数器
    将表里的数据批量生成INSERT语句的存储过程 继续增强版
    [Java]
    [Linux] 安装JBoss
    [Spring]
    [Spring]
    [Maven]
    [Maven]
    [Spring MVC]
    [Spring MVC]
  • 原文地址:https://www.cnblogs.com/cn-jasonho/p/13285585.html
Copyright © 2011-2022 走看看