四、DDL常见操作汇总

DDL: Data Define Language 数据定义语言,主要用来对数据库、表进行一些管理操作。如:建库、删库、建表、修改表、删除表、对列的增删改等。

一、库的管理

  1、创建库    create database [if not exists] 库名

  2、删除空    drop database [if exists] 库名

  3、建库通用写法

    drop database if exists 旧库名;

    create database 新库名;

    ----show databases like 'javacode2018';列出javacode2018库信息。

二、表管理

  1)、创建表

    create table 表名(
        字段名1 类型[(宽度)] [约束条件] [comment '字段说明'],
        字段名2 类型[(宽度)] [约束条件] [comment '字段说明'],
        字段名3 类型[(宽度)] [约束条件] [comment '字段说明']
    )[表的一些设置];

    注意:

    1、在同一张表中,字段名不能相同;

    2、宽度和约束条件为可选参数,字段名和类型是必须的

    3、最后一个字段不能加逗号

    4、类型是用来限制 字段 必须以何种数据类型来存储记录

    5、类型其实也是对字段的约束(约束字段下的记录必须为XX类型)

    6、类型后写的 约束条件 是在类型之外的 额外添加的约束

    约束条件

    1、not null 标识该字段不能为空

    2、default value 为该字段设置默认值,默认值为value

    3、primary key 标识该字段为该表的主键,可以唯一的标识记录,插入重复数据会报错

      两种写法:

        方式一:跟在列后

             create table test3(

                ->   a int not null comment '字段a' primary key
                -> );

        方式二:在所有列定义之后定义,如下:            

              create table test4(
                ->   a int not null comment '字段a',
                ->   b int not null default 0 comment '字段b',
                ->   primary key(a)
                -> );

        方式2支持多字段作为主键,多个之间用逗号隔开,语法:primary key(字段1,字段2,字段n),示例:PRIMARY KEY (a,b)

    4、foreign key 为表中的字段设置外键

      语法:foreign key(当前表的列名) references 引用的外键表(外键表中字段名称)

      例如:foreign key(ts5_a) references test5(a)  

       create table test6(
          ->   b int not null comment '字段b',
          ->   ts5_a int not null,
          ->   foreign key(ts5_a) references test5(a)
          -> );
    

      说明:表示test6中ts5_a字段的值来源于表test5中的字段a。

      注意几点:

      • 两张表中需要建立外键关系的字段类型需要一致

      • 要设置外键的字段不能为主键

      • 被引用的字段需要为主键

      • 被插入的值在外键表必须存在,如上面向test6中插入ts5_a为2的时候报错了,原因:2的值在test5表中不存在

    5、unique key(uq) 标识该字段的值是唯一的

      方式1:跟在字段后,如下:

        create table test8(
            ->    a int not null comment '字段a' unique key
            ->  );
  

      方式2:所有列定义之后定义,如下:

        create table test9(
            ->    a int not null comment '字段a',
            ->   unique key(a)
            ->  );
   

      方式2支持多字段,多个之间用逗号隔开,语法:unique key(字段1,字段2,字段n),示例:unique key(a,b)

    6、auto_increment:标识该字段的值自动增长(整数类型,而且为主键)

      create table test11(
          ->   a int not null AUTO_INCREMENT PRIMARY KEY comment '字段a',
          ->   b int not null comment '字段b'
          -> );
      

      字段a为自动增长,默认值从1开始,每次+1

      关于自动增长字段的初始值、步长可以在mysql中进行设置,比如设置初始值为1万,每次增长10    

    注意:

      自增长列当前值存储在内存中,数据库每次重启之后,会查询当前表中自增列的最大值作为当前值,如果表数据被清空之后,数据库重启了,自增列的值将从初始值开始

  2)、删除表

    drop table [if exists] 表名;

  3)、修改表名

    alter table 表名 rename [to] 新表名;

  4)、表设置备注

    alter table 表名 comment '备注信息';

  5)、复制表 

    只复制表结构

    create table 表名 like 被复制的表名;

    复制表结构+数据

    create table 表名 [as] select 字段,... from 被复制的表 [where 条件];

    create table test13 as select * from test11;

三、表中列的管理

  1)、添加列

    alter table 表名 add column 列名 类型 [列约束];

    alter table test14 add column b int not null default 0 comment '字段b';

  2)、修改列

    alter table 表名 modify column 列名 新类型 [约束];
    或者
    alter table 表名 change column 列名 新列名 新类型 [约束];

    2种方式区别:modify不能修改列名,change可以修改列名

  3)、删除列

    alter table 表名 drop column 列名;

原文地址:https://www.cnblogs.com/biao/p/11708390.html