zoukankan      html  css  js  c++  java
  • 四、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 列名;

  • 相关阅读:
    mybatis 批量插入时候的一个注意点
    centos7 kubernetes单机安装
    debug 模式缓慢
    那些年,我们误解的 JavaScript 闭包
    maven仓库的配置
    闭包
    docker 搭建自己的github
    docker 搭建小型的node开发环境。
    jquery validate
    使用ueditor中的setContent() 时经常报innerHtml错误(笔记)
  • 原文地址:https://www.cnblogs.com/biao/p/11708390.html
Copyright © 2011-2022 走看看