• MySQL笔记(一)之新建数据库和数据表


    创建数据库

    CREATE DATABASE database_name
    

    创建数据表

    CREATE TABLE table_name
    (
    列1 数据类型,
    列2 数据类型,
    列3 数据类型,
    ....
    )
    
    #常见的数据类型  
    integer(size)  整型  
    int(size)   整型  
    numeric(size,d)  浮点型  
    char(size)  固定长度字符型  
    varchar(size)  可变长度字符型  
    date(yyyymmdd)  日期类型  
    

    数据表的约束

    NOT NULL

    强制列不接受 NULL 值

    CREATE TABLE Persons
    (
    Id_P int NOT NULL,
    City varchar(255)
    )
    

    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'
    
    OrderDate date DEFAULT GETDATE()   # 可以使用函数
    )
    
    • 创建后添加约束
    ALTER TABLE Persons
    ALTER City SET DEFAULT 'SANDNES'
    
    • 撤销约束
    ALTER TABLE Persons
    ALTER City DROP DEFAULT
    

    UNIQUE

    唯一标识数据库表中的每条记录,一个数据表中可以有多个UNIQUE约束。

    • 创建时添加UNIQUE约束
    CREATE TABLE table_name
    (
    Id_P int NOT NULL,
    City varchar(255),
    UNIQUE (Id_P)       # 为一列指定UNIQUE约束
    CONSTRAINT uc_PersonID UNIQUE (Id_P,City)  # 命名UNIQUE 约束,并且为多列指定UNIQUE约束
    )
    
    • 创建后添加约束
    #添加一个约束
    ALTER TABLE Persons
    ADD UNIQUE (Id_P)
    
    #命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束
    ALTER TABLE Persons
    ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
    
    • 撤销UNIQUE约束
    ALTER TABLE table_name
    DROP INDEX uc_PersonID
    

    PRIMARY KEY

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

    • 创建时添加PRIMARY KEY约束
    CREATE TABLE Persons
    (
    Id_P int NOT NULL,
    City varchar(255),
    PRIMARY KEY (Id_P)   # 为一列指定UNIQUE约束
    CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,City) #命名 PRIMARY KEY 约束,以及为多个列定义 PRIMARY KEY 约束
    )
    
    • 创建后添加PRIMARY KEY 约束
    ALTER TABLE Persons
    ADD PRIMARY KEY (Id_P)
    
    ALTER TABLE Persons
    ADD CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,LastName)
    
    • 撤销 PRIMARY KEY 约束
    ALTER TABLE Persons
    DROP PRIMARY KEY
    

    FOREIGN KEY

    指向另一个表中的 PRIMARY KEY

    • 创建时添加FOREIGN KEY约束
    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)  # 一个约束
    
    CONSTRAINT fk_PerOrders FOREIGN KEY (Id_P) REFERENCES Persons(Id_P)  # 命名约束且指定多个约束
    )
    
    • 创建后添加PFOREIGN KEY 约束
    ALTER TABLE Orders
    ADD FOREIGN KEY (Id_P)
    REFERENCES Persons(Id_P)
    
    ALTER TABLE Orders
    ADD CONSTRAINT fk_PerOrders
    FOREIGN KEY (Id_P)
    REFERENCES Persons(Id_P)
    
    • 撤销 FOREIGN KEY 约束
    ALTER TABLE Orders
    DROP FOREIGN KEY fk_PerOrders
    

    CHECK

    束用于限制列中的值的范围

    • 创建时添加CHECK约束
    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)
    
    CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
    )
    
    
    • 创建后添加CHECK约束
    ALTER TABLE Persons
    ADD CHECK (Id_P>0)
    
    ALTER TABLE Persons
    ADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
    
    • 撤销 CHECK 约束
    ALTER TABLE Persons
    DROP CHECK chk_Person
    
  • 相关阅读:
    android焦点
    URI和URL的区别比较与理解
    Android Bundle类
    repo命令
    ubuntu adb找不到设备
    【python】-网络编程
    【python】-反射
    【python】-类的特殊成员方法
    【python】-7-面向对象的进阶
    【python】-多态
  • 原文地址:https://www.cnblogs.com/cnkai/p/7469587.html
Copyright © 2020-2023  润新知