DDL(数据定义语言)

库和表的管理

库的管理:

    一、创建库
    create database 库名
    二、删除库
    drop database 库名
表的管理:

Eg. 
    #1.创建表
    CREATE TABLE IF NOT EXISTS stuinfo(
        stuId INT,
        stuName VARCHAR(20),
        gender CHAR,
        bornDate DATETIME 
    );

    DESC studentinfo;
    #2.修改表 alter
    语法:ALTER TABLE 表名 ADD|MODIFY|DROP|CHANGE COLUMN 字段名 【字段类型】;
    
    #①修改字段名
    ALTER TABLE studentinfo CHANGE  COLUMN sex gender CHAR;
    
    #②修改表名
    ALTER TABLE stuinfo RENAME [TO]  studentinfo;
    #③修改字段类型和列级约束
    ALTER TABLE studentinfo MODIFY COLUMN borndate DATE ;
    
    #④添加字段
    ALTER TABLE studentinfo ADD COLUMN email VARCHAR(20) first;
    #⑤删除字段
    ALTER TABLE studentinfo DROP COLUMN email;
    
    #3.删除表
    DROP TABLE [IF EXISTS] studentinfo;
    
    #4.表的复制
    INSERT INTO author VALUES
    (1,'树上春树','日本'),
    (2,'莫言','中国'),
    (3,'冯唐','中国'),
    (4,'金庸','中国')
    
    #①.仅复制表的结构
    CREATE TABLE copy LIKE author;
    
    #②.复制表的结构+数据
    CREATE TABLE copy2
    SELECT * FROM author;
    
    #③.只复制部分数据
    CREATE TABLE copy3
    SELECT id,au_name
    FROM author
    WHERE nation='中国';
    
    #④.仅复制某些字段
    CREATE TABLE copy4
    SELECT id,au_name
    FROM author
    WHERE 1=2;

常见类型

    整型:
        tinyint、smallint、mediumint、int/integer、bigint
        1           2           3       4          8
    小数:
        浮点型:float、double
        定点型:dec、decimal
    字符型:
        较短的文本:char(固定长度字符)、varchar(可变长度字符)
        较长的文本:text、blob(较长的二进制数据)
    日期型:date、datetime、timestamp、time、year
    Blob类型:
    
    原则:所选择的类型越简单越好,能保存数值的类型越小越好 

常见约束

含义:一种限制,用于限制表中的数据,为了保证表中的数据的准确性和可靠性
分类:
    NOT NULL:非空,用于保证该字段值不能为空
    DEFAULT:默认,用于保证该字段有默认值
    UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空
    CHECK:检查约束【MySQL不支持】
    PRIMARY KEY:主键,用于保证该字段的值具有唯一性,并且非空
    FOREIGN KEY:外键,用于限制两个表的关系,用于保证该字段值必须来自于主表的关联列的值,在从表添加外键约束,用于引用主表中某列的值

主键和唯一:
    1.区别:
    ①一个表至多有一个主键,但可以有多个唯一
    ②主键不允许为空,唯一可以为空
    2.相同点
    ①都有唯一性
    ②都支持组合键,但不推荐

外键:
    1.用于限制两个表的关系,从表的字段值引用了主表的某字段值
    2.外键列和主表的被引用列要求类型一致,意义一样
    3.主表的被引用列要求是一个key(一般就是主键)
    4.插入数据,先插入主表;删除数据,先删除从表
一、创建表时添加约束
    语法:
        直接在字段名和类型名后面追加约束类型即可
    
二、修改表时添加约束
    1、添加列级约束
    alter table 表名 modify column 字段名 字段类型 新约束;
    2、添加表级约束
    alter talbe 表名 add 【constraint 约束名】 约束类型(字段名);
    
三、修改表时删除约束
    
Eg.
    CREATE TABLE stuinfo(
        id INT PRIMARY KEY,#主键
        stuName VARCHAR(20) NOT NULL,#非空
        gender CHAR(1) CHECK(gender='男' OR gender='女'),#检查
        seat INT UNIQUE,#唯一
        age INT DEFAULT 18,#默认约束
        majorId INT REFERENCES major(id)#外键
    );
    
    CREATE TABLE major(
        id INT PRIMARY KEY,
        marjorName VARCHAR(20)
    );
    
    DESC stuinfo;
    
    SHOW INDEX FROM stuinfo;
    
    #2.添加表级约束
    /*
    语法:在各个字段的最下面
    【CONSISTENT 约束名】 约束类型(字段名)
    */
    DROP TABLE IF EXISTS stuinfo;
    CREATE TABLE stuinfo(
        id INT,
        stuname VARCHAR(20),
        gender CHAR(1),
        seat INT,
        age INT,
        majorid INT,
        
        CONSTRAINT pk PRIMARY KEY(id),#主键
        CONSTRAINT uq UNIQUE(seat),#唯一键
        CONSTRAINT ck CHECK(gender='男' OR gender='女'),#检查(没效果)
        CONSTRAINT fk_stuinfo_major FOREIGN KEY(majorid) REFERENCES major(id)#外键
    );
    SHOW INDEX FROM stuinfo;
    
    #二、修改表时添加约束
    DROP TABLE IF EXISTS stuinfo;
    CREATE TABLE stuinfo(
        id INT,
        stuname VARCHAR(20),
        gender CHAR(1),
        seat INT,
        age INT,
        majorid INT
    );
    
    DESC stuinfo;
    #1.添加非空约束
    ALTER TABLE stuinfo
    MODIFY COLUMN stuname VARCHAR(20) NOT NULL;
    
    #2.添加默认约束
    ALTER TABLE stuinfo MODIFY COLUMN age INT DEFAULT 18;
    
    #3.添加主键
    ALTER TABLE stuinfo MODIFY COLUMN id INT PRIMARY KEY;
    ALTER TABLE stuinfo ADD PRIMARY KEY(id);
    
    #4.添加唯一键
    ALTER TABLE stuinfo MODIFY COLUMN seat INT UNIQUE;
    ALTER TABLE stuinfo ADD UNIQUE(seat);
    
    #5.添加外键
    ALTER TABLE stuinfo ADD CONSTRAINT fk_stuinfo_major FOREIGN KEY(majorid) REFERENCES major(id);
    
    #三、修改表时删除约束
    #1.删除非空约束
    ALTER TABLE stuinfo MODIFY COLUMN stuname VARCHAR(20) NULL;
    
    #2.删除默认约束
    ALTER TABLE stuinfo MODIFY COLUMN age INT;
    
    #3.删除主键
    ALTER TABLE stuinfo DROP PRIMARY KEY;
    
    #4.删除唯一键
    ALTER TABLE stuinfo DROP INDEX seat;
    
    #5.删除外键
    ALTER TABLE stuinfo DROP FOREIGN KEY fk_stuinfo_major;
    
    

标识列

    含义:又称自增长列,可以不同手动的插入值,系统提供默认的序列值
    特点:
        1.标识列必须和key搭配
        2.一个表最多一个标识列
        3.标识列类型只能是数值型
        4.标识列可以通过SET AUTO_INCREMENT_INCREMENT = 3;设置步长,可以通过手动插入值设置起始值
Eg.        
    #标识列
    #一、创建表时设置标识列
    DROP TABLE IF EXISTS tab_identity;
    CREATE TABLE tab_identity(
        id INT,
        NAME FLOAT,
        seat INT
    );
    
    TRUNCATE TABLE tab_identity;
    INSERT INTO tab_identity(id,NAME) VALUES(NULL,'John');
    INSERT INTO tab_identity(NAME) VALUE('lucy');
    SET AUTO_INCREMENT_INCREMENT = 3;
    
    SELECT * FROM tab_identity;
    
    #二、修改表时设置标识列
    ALTER TABLE tab_identity MODIFY COLUMN id INT PRIMARY KEY AUTO_INCREMENT
    
    #三、修改表时删除标识列
    ALTER TABLE tab_identity MODIFY COLUMN id INT;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容