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;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容