DDL:数据定义语言

创建create

创建库

  • 语法:create database 【if not exists】库名
# 创建库
CREATE DATABASE IF NOT EXISTS books
## 通用写法
DROP DATABASE IF EXISTS 旧库名
CREATE DATABASE 新库名

创建表

  • 语法:
/*
create table 表名(
列名 列的类型【(长度)约束】,
列名 列的类型【(长度)约束】,
...
列名 列的类型【(长度)约束】 # 最有一个不加逗号

*/
# 如
CREATE TABLE book(
id INT,
bName VARCHAR(20)
);
# 通用写法
DROP TABLE IF EXISTS 旧表名
CREATE TABLE 新表名();

修改alter

修改库

# 一般不建议更改库
# 更改库的字符集
ALTER DATABASE books CHARACTER SET utf8;

修改表

核心语法: alter table 表名 add|drop|modify|change column 列名

  • 修改列名
  • 修改列的类型或约束
  • 添加新列
  • 删除列
  • 修改表名
# 修改列名
ALTER TABLE book CHANGE COLUMN bName bname VARCHAR(10)
# 修改列类型
ALTER TABLE book MODIFY COLUMN id VARCHAR(3)
# 修改列约束
# 添加主键
ALTER TAELE book MODIFY COLUMN id INT PRIMARY REY;
ALTER TABLE book ADD PRIMARY KEY(id);
# 添加外键 为主表stu的id添加外键约束,外键是从表major中的majorid
ALTER TABLE stu ADD CONSTRAINT fk_stu_major FOREIGN KEY(majorid)REFERENCES major(id);
# 添加新列
ALTER TABLE book ADD COLUMN age INT;
# 删除列
ALTER TABLE book DROP COLUMN age;
# 修改表名

删除drop

删除库

# 删除库
DROP DATABASE IF EXISTS books

删除表

DROP TABLE IF EXISTS books;

复制表

  • 仅仅复制表的结构
  • 复制表的结构和数据
# 仅仅复制表的结构
CREATE TABLE copy1 LIKE books;
# 复制表的结构和数据
CREATE TABLE copy2 SELECT * FROM books
# 还可以只复制 部分数据 加晒选条件即可

数据库中常见数据类型

数值型-整型/浮点型

整型

整型类型 字节 整型类型 字节
Tinyint 1 Smallint 2
Smallint 3 Int/integer 4
Bigint 4
  • 特点:

    ①如果不设置无符号还是有符号,默认是有符号,如果想设置无符号,需要添加unsigned关键字

    ②如果插入的数值超出了整型的范围,会报out of range异常,并且插入临界值

    ③如果不设置长度,会有默认的长度]

    ④长度代表了显示的最大宽度,如果不够会用0在左边填充,但必须搭配zerofill使用!

浮点型

+ 分类:
1.浮点型
float(M,D)
double(M,D)
2.定点型
dec(M,D)
decimal(M,D)
浮点类型 字节 浮点类型 字节
float 4 double 8

定点型 字节
dec(M,D),decimal(M,D) M+2
  • M:整数部位+小数部位
  • D:小数部位
  • 特点:

    ①如果超过范围,则插入临界值

    ②M和D都可以省略

    ③如果是decima1,则M默认为10,D默认为0;如果是floatdouble,则会根据插入的数值的精度来决定精度

    ④定点型的精确度较高

字符型-短型/长型

/*
较短的文本:
char
varchar
较长的文本:
text
blob(较大的二进制)
*/

日期型

/*
分类:
date只保存日期
time只保存时间
year只保存年
datetime保存日期+时间
timestamp保存日期+时间
特点:
字节范围时区等的影响
字节 范围 时区影响
datetime 8 1000-9999 不受
timestamp 4 1970-2038 受
*/

常见约束

  • NOT NULL:非空,用于保证该字段的值不能为空
  • DEFAULT:默认,用于保证该字段有默认值
  • PRIMARY KEY:主键,用于保证该字段的值具有唯一性,并且非空
  • UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空
  • CHECK:检查约束【mysq1中不支持】
  • FOREIGN KEY:外键,用于限制两个表的关系

    列级约束
CREATE TABLE IF NOT EXISTS stu(
id INT PRIMARY KEY, # 主键
sName VARCHAR(20) NOT NULL, # 非空
gender CHAR CHECK(gender='男' OR gender='女'), #检查
seat INT UNIQUE, # 唯一
age INT DEFAULT 18, # 默认
majorId INT REFERENCES major(id) #外键
); CREATE TABLE major(
id INT PRIMARY KEY,
mName VARCHAR(20) NOT NULL
)

表级约束

CREATE TABLE stu(
id INT,
sName VARCHAR(20),
gender CHAR,
seat INT,
majorId INT, # CONSTRAINT 别名 可省略
CONSTRAINT Pk PRIMARY KEY(id), #外键
CONSTRAINT uq UNIQUE(seat), #唯一
CONSTRAINT fk_stu_major FOREIGN KEY(majorId) REFERENCES major(id) # 外键
);

主键和唯一区别

唯一性 是否为空 一个表中是否有多个 是否允许组合
主键 × 至多1个 √,不推荐
唯一 可以多个 √,不推荐

外键

  • 要求在从表设置外键关系
  • 从表的外键列的类型和主表的关联列的类型要求一致或兼容,名称无要求
  • 主表的关联列必须是一个key(一般是主键或唯一)
  • 插入数据时,先插入主表,再插入从表
  • 删除数据时,先删除从表,再删除主表

标识列即自增长

id INT PRIMARY KEY AUTO_INCREMENT, #设置id是自增长类型

/*
1、标识列不一定要和主键搭配,但要求是一个key
2、一个表可以有至多一个标识列
3、标识列的类型只能是数值型
4、标识列可以通过 SET auto_increment_increment = 3;设置步长
*/

MySQL-4-DDL的更多相关文章

  1. mysql online ddl

        大家知道,互联网业务是典型的OLTP(online transaction process)应用,这种应用访问数据库的特点是大量的短事务高并发运行.因此任何限制高并发的动作都是不可接受的,甚至 ...

  2. [资料收集]MySQL在线DDL工具pt-online-schema-change

    MySQL在线DDL工具pt-online-schema-change pt-online-schema-change使用说明(未完待续) 官网

  3. 关于MySQL Online DDL

    1. Online DDL 在 MySQL 5.1 (带InnoDB Plugin)和5.5中,有个新特性叫 Fast Index Creation(下称 FIC),就是在添加或者删除二级索引的时候, ...

  4. MySQL在线DDL gh-ost 使用说明

    背景: 作为一个DBA,大表的DDL的变更大部分都是使用Percona的pt-online-schema-change,本文说明下另一种工具gh-ost的使用:不依赖于触发器,是因为他是通过模拟从库, ...

  5. MySQL使用DDL语句创建表

    一.使用DDL语句创建表 DDL语言全面数据定义语言(Data Define Language) 主要的DDL动词: CREATE(创建).DROP(删除).ALTER(修改) TRUNCATE(截断 ...

  6. 详谈 MySQL Online DDL

    作为一名DBA,对数据库进行DDL操作非常多,如添加索引,添加字段等等.对于MySQL数据库,DDL支持的并不是很好,一不留心就导致了全表被锁,经常搞得刚入门小伙伴很郁闷又无辜,不是说MySQL支持O ...

  7. MySQL Online DDL导致全局锁表案例分析

    MySQL Online DDL导致全局锁表案例分析 我这边遇到了什么问题? 线上给某个表执行新增索引SQL, 然后整个数据CPU打到100%, 连接数暴增到极限, 最后导致所有访问数据库的应用都奔溃 ...

  8. MySQL在线DDL工具 gh-ost

    一.简介 gh-ost基于 golang 语言,是 github 开源的一个 DDL 工具,是 GitHub's Online Schema Transmogrifier/Transfigurator ...

  9. 【科普】MySQL中DDL操作背后的并发原理

    一. 简介 DQL:指数据库中的查询(select)操作. DML:指数据库中的插入(insert).更新(update).删除(delete)等行数据变更操作. DDL:指数据库中加列(add co ...

  10. MySQL online ddl原理

    背景 dba的日常工作肯定有一项是ddl变更,ddl变更会锁表,这个可以说是dba心中永远的痛,特别是执行ddl变更,导致库上大量线程处于“Waiting for meta data lock”状态的 ...

随机推荐

  1. C. Tourist Problem 2021.3.29 晚vj拉题 cf 1600 纯数学题

    拉题链接  https://vjudge.net/contest/430219#overview 原题链接  https://codeforces.com/problemset/problem/340 ...

  2. SVG 和 CSS3 实现一个超酷爱心 Like 按钮

    在现代网页中,我们经常可以在一些文章.视频和图片页面上找到"Like"按钮,并且通过点击该按钮来表示自己对该内容的喜欢或者不喜欢.大部分"Like"按钮是纯文本 ...

  3. 2021.12.06 P2508 [HAOI2008]圆上的整点(数论+ π )

    2021.12.06 P2508 [HAOI2008]圆上的整点(数论+ \(\pi\) ) https://www.luogu.com.cn/problem/P2508 题意: 求一个给定的圆 \( ...

  4. Java第十五周作业

    Cola公司的雇员分为以下若干类:(知识点:多态) [必做题]• 4.1 ColaEmployee :这是所有员工总的父类,属性:员工的姓名,员工的生日月份.方法:getSalary(int mont ...

  5. Apache Doris 通过ODBC连接SQL Server

    社区有小伙伴有使用Doris ODBC外表连接SQL Server数据库,使用中遇到不知道驱动怎么安装,苦于我这边也没有SQL Server的环境,正好社区有用户使用了这个数据库,也安装ODBC驱动测 ...

  6. python基础-基本数据类型(二)

    一.序列类型 序列类型是用来表示有序的元素集合 1.字符串(str) python中字符串通常用str表示,字符串是使用单引号,双引号,三引号包裹起来的字符的序列,用来表示文本信息. 1.1 字符串的 ...

  7. python3 常见错误(一)

    以下全部是在python3中适用. 错误一: 函数默认参数 Python允许为函数的参数提供默认的可选值.但是它可能会导致一些易变默认值的混乱.例子: 我们希望每次调用myFun函数,list1都为默 ...

  8. 浅尝Spring注解开发_AOP原理及完整过程分析(源码)

    浅尝Spring注解开发_AOP原理及完整过程分析(源码) 浅尝Spring注解开发,基于Spring 4.3.12 分析AOP执行过程及源码,包含AOP注解使用.AOP原理.分析Annotation ...

  9. 服务器BIOS和BMC等知识详解

    一个执着于技术的公众号 引言:以BIOS为核心的固件产业,是信创产业链的重要组成部分,可被誉为信创产业的"山海关".在计算机体系中,BIOS 有着比操作系统更为底层和基础性的作用, ...

  10. 运维:DevSecOps

    什么是DevSecOps DevSecOps 是一场关于 DevOps 概念实践或艺术形式的变革.DevOps之父Patrick Debios 强调:"DevOps2.0时代应首先解决人的问 ...