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 列名;

四、DDL常见操作汇总的更多相关文章

  1. Mysql高手系列 - 第4天:DDL常见操作汇总

    这是Mysql系列第4篇. 环境:mysql5.7.25,cmd命令中进行演示. DDL:Data Define Language数据定义语言,主要用来对数据库.表进行一些管理操作. 如:建库.删库. ...

  2. X-Cart 学习笔记(四)常见操作

    目录 X-Cart 学习笔记(一)了解和安装X-Cart X-Cart 学习笔记(二)X-Cart框架1 X-Cart 学习笔记(三)X-Cart框架2 X-Cart 学习笔记(四)常见操作 五.常见 ...

  3. C#路径/文件/目录/I/O常见操作汇总

    文件操作是程序中非常基础和重要的内容,而路径.文件.目录以及I/O都是在进行文件操作时的常见主题,这里想把这些常见的问题作个总结,对于每个问题,尽量提供一些解决方案,即使没有你想要的答案,也希望能提供 ...

  4. C#路径/文件/目录/I/O常见操作汇总<转载>

    文件操作是程序中非常基础和重要的内容,而路径.文件.目录以及I/O都是在进行文件操作时的常见主题,这里想把这些常见的问题作个总结,对于每个问题,尽量提供一些解决方案,即使没有你想要的答案,也希望能提供 ...

  5. 【转】C#路径/文件/目录/I/O常见操作汇总

    文件操作是程序中非常基础和重要的内容,而路径.文件.目录以及I/O都是在进行文件操作时的常见主题,这里想把这些常见的问题作个总结,对于每个问题,尽量提供一些解决方案,即使没有你想要的答案,也希望能提供 ...

  6. JS 数组常见操作汇总,数组去重、降维、排序、多数组合并实现思路整理

    壹 ❀ 引 JavaScript开发中数组加工极为常见,其次在面试中被问及的概率也特别高,一直想整理一篇关于数组常见操作的文章,本文也算了却心愿了. 说在前面,文中的实现并非最佳,实现虽然有很多种,但 ...

  7. Oracle常见操作汇总(转)

    前言:Oracle学习也有十几天了,但是呢,接下来还要学习许多其他的东西,并不能提步不前,所以在此总结了以下Oracle中常用的命令和语句,没有语法都是实例,以便以后工作的时候随时翻看,毕竟是自己的东 ...

  8. Vim常见操作汇总

    1.跳到文本的最后一行:按“G”,即“shift+g”2.跳到最后一行的最后一个字符 : 先重复1的操作即按“G”,之后按“$”键,即“shift+4”.3.跳到第一行的第一个字符:先按两次“g”,4 ...

  9. mysql常见操作汇总

    1.Mysql服务突然启不来了,报错: 在分析时发现MySQL Server 5.0\data下面有个名称为用户名,扩展名为.err的文件: 150725 20:01:19 [Note] 自己的安装目 ...

随机推荐

  1. php 微信公众平台OAuth2.0网页授权,获取用户信息代码类封装demo

    get_wx_data.php <?php /** * 获取微信用户信息 * @author: Lucky hypo */ class GetWxData{ private $appid = ' ...

  2. PAT 甲级 1069 The Black Hole of Numbers (20 分)(内含别人string处理的精简代码)

    1069 The Black Hole of Numbers (20 分)   For any 4-digit integer except the ones with all the digits ...

  3. Win10下载安装PostgreSQL 11.1

    下载地址:https://get.enterprisedb.com/postgresql/postgresql-11.1-1-windows-x64.exe Installation Director ...

  4. 【Leetcode_easy】1021. Remove Outermost Parentheses

    problem 1021. Remove Outermost Parentheses 参考 1. Leetcode_easy_1021. Remove Outermost Parentheses; 完

  5. 树莓派3B安装arm64操作系统

    pi64 pi64基于Debian 9,地址如下https://github.com/bamarni/pi64 烧录过程还是用SDFormatter格式化,用Win32DiskImager写入即可,没 ...

  6. 高级UI-自定义Behavior

    Behavior本身是一个抽象类,可以用于两个view之间的状态监听,也可用于某个view监听CoordinateLayout里面的所有控件滑动状态,实现自定义Behavior则可以实现任意两个vie ...

  7. mysql You can't specify target table for update in FROM clause解决方法

    mysql You can't specify target table for update in FROM clause解决方法出现这个错误的原因是不能在同一个sql语句中,先select同一个表 ...

  8. Word 固定行间距公式图片显示不全、Word Eculid 字体导致行间距过大、Word 行间距过大

    1. 前言 1.有些文章行间距要求是固定值,比如,固定值15磅,但是这样会导致有些公式.图片显示不全.例如下图: 2.Euclid这个字体很容易导致行间距超大. 2. 解决方案 1.把固定值15磅改为 ...

  9. hdu 6609 区间条件前缀和 + 二分

    题目传送门//res tp hdu 目的 在尾部逐步插入n个元素,求插入第i个元素时,[1,i)内删去多少个元素,可使前缀和[1,i]不大于m 多测Q [1,15] n [1,2e5] m [1,1e ...

  10. C++根据用户输入打印对应的金层塔层数

    #include <iostream> #include <Windows.h> using namespace std; int main(void) { int row; ...