SQL之DDL(数据定义语言)

2023-05-16

1.库的管理

创建库
create database [if not exists] 库名;
更改库的字符集
alter database 库名 character set [gbk/utf-8];
删除库
drop database [if exists] 库名;

2.表的管理

① 创建

create table 表名(
列名 列的类型[(长度) 约束],
列名 列的类型[(长度) 约束],

列名 列的类型[(长度) 约束]
)

②修改

alter table 表名 add|drop|modify|change column 列名 [列类型 约束];

  1. 修改列名

alter table 表名 change column 原列名 新列名 列类型;

  1. 修改列的类型或约束

alter table 表名 modify colum 列名 类型;

  1. 添加新列

alter table 表名 add column 列名 类型;

  1. 删除列

alter table 表名 drop column 列名;

  1. 修改表名

alter table 表名 rename to 新表名;

③删除

drop table 表名;

④ 复制

  1. 仅复制表结构

create table 表名 like 要复制表结构的表名

  1. 表结构+内容都复制

create table 表名 select * from 要复制的表的表名

  1. 只复制部分数据

create table 表名
select 列名1,列名2…
from 要复制表的表名
where …

3.常见约束

含义: 用于限制表中的数据,为了保证表中数据的准确和可靠性。
分类:六大约束

NOT NULL: 非空,用于保证该字段的值不能为空。
DEFAULT: 默认,用于保证该字段有默认值。
PRIMARY KEY: 主键,用于保证该字段的值有唯一性,且不为空。
UNIQUE: 唯一,用于保证该字段的值有唯一性,且可以为空。
CHECK: 检查约束(mysql中不支持)。
FOREIGN KEY: 外键,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值。在从表添加外键约束,用于引用主表中某列的值。

  1. 列级约束
  • mysql中只支持:默认、非空、主键、唯一
CREATE TABLE stuinfo(
	id INT PRIMARY KEY,#主键
	stuName VARCHAR(20) NOT NULL,#非空
	gender CHAR CHECK(gender='男' OR gender='女'),#检查(不报错)
	seat INT UNIQUE,#唯一
	age INT DEFAULT 18,#默认
	majorId INT  REFERENCES major(id)#外键
);
  1. 表级约束
  • 不支持默认和非空,一个表可以添加多个外键
CREATE TABLE stuinfo(
	id INT,
	stuName VARCHAR(20),
	gender CHAR,
	seat INT,
	age INT,
	majorId INT,
	
	CONSTRAINT pk PRIMARY KEY(id),
	CONSTRAINT ck CHECK(gender='男' OR gender='女'),
	CONSTRAINT uq UNIQUE(seat),
	CONSTRAINT fk FOREIGN KEY(majorId) REFERENCES major(id)
);
  1. 表级约束与列级约束区别
位置支持的约束类型是否可以起约束名
表级约束列名的后面语法都支持(外键没有效果)不可以
列级约束所有列的下面默认、非空不支持,其他支持可以(主键没有效果)

4.自增长列(标识列)

含义: 可以不用手动插入值,系统提供默认序列值(从1开始)。

  1. 查看自增长步长
SHOW VARIABLES LIKE '%auto_increment%';
  1. 设置自增长步长
SET auto_increment_increment=5;#将步长设置为5

创建表时设置自增长列

CREATE TABLE tab_identity(
	id INT PRIMARY KEY AUTO_INCREMENT,
	name VARCHAR(20)
);

修改表时设置自增长列

ALTER TABLE 表名 MODIFY COLUMN 列名 INT  AUTO_INCREMENT;
ALTER TABLE 表名 MODIFY COLUMN 列名 INT;#修改表时删除自增长列
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SQL之DDL(数据定义语言) 的相关文章

随机推荐

  • @PathVariable注解的用法和作用

    64 PathVariable注解的用法和作用 64 PathVariable 映射 URL 绑定的占位符 通过 64 PathVariable 可以将 URL 中占位符参数绑定到控制器处理方法的入参中 URL 中的 xxx 占位符可以通过
  • 最新虚拟机中Ubuntu18.04安装教程(傻瓜教程)

    1 文件和软件下载 下载Ubuntu18 04文件 可以直接点下方的链接下载 Ubuntu18 04安装链接 下载VMware Workstation 笔者这边使用的是VMware Workstation15 5pro xff0c 大家也可
  • optimizer优化器详解

    在机器学习中 xff0c 优化器 xff08 optimizer xff09 是一种用于更新模型参数以最小化训练误差的算法 它可以将损失函数的梯度作为输入 xff0c 并根据该梯度调整模型参数的值 常见的优化器算法包括随机梯度下降 xff0
  • Java创建多线程的四种方式

    一 继承Thread类 1 创建一个继承于Thread类的子类 2 重写Thread类的run gt 将此线程执行的操作声明在run 中 3 创建Thread类的子类的对象 4 通过此对象调用start 启动当前线程 调用当前线程的run
  • MySQL基础

    本单元目标 一 为什么要学习数据库 二 数据库的相关概念 DBMS DB SQL 三 数据库存储数据的特点 四 初始MySQL MySQL产品的介绍 MySQL产品的安装 MySQL服务的启动和停止 MySQL服务的登录和退出 MySQL的
  • Thread类中的常用方法

    Thread类中的常用方法 xff08 学习总结 xff09 xff1a 序号函数作用1start 启动当前线程 xff1b 调用当前线程的run 2run 通常需要重写Thread类中的此方法 xff0c 将创建的线程要执行的操作生命在此
  • 线程的同步机制

    方式一 xff1a 同步代码块 span class token keyword synchronized span span class token punctuation span 同步监视器 span class token punc
  • Java常用类总结

    一 字符串相关的类 String类及其常用方法 1 String声明为final的 xff0c 不可被继承 2 String实现了Serializable接口 xff1a 表示字符串是支持序列化的 xff1b 实现了Comparable接口
  • java获取两个字符串中最大相同字串

    span class token keyword import span span class token keyword static span java span class token punctuation span lang sp
  • jdk提供的4种注解

    元注解 xff1a 对现有的注解进行解释说明的注解 Retention xff1a 指定所修饰的Annotation的生命周期 xff1a SOURCE CLASS xff08 默认行为 xff09 RUNTIME xff0c 只有声明为R
  • Java中List接口常用方法

    List除了从Collection集合继承的方法外 xff0c List集合里添加了一些根据索引来操作集合元素的方法 xff1a 序号返回值函数作用1voidadd int index Object ele 在index位置插入ele元素2
  • 对Java中Class类的理解并获取Class实例

    关于java lang Class类的理解 类的加载过程 xff1a 程序经过javac exe命令以后 xff0c 会生成一个或多个字节码文件 class结尾 接着我们使用java exe命令对某个字节码文件进行解释运行 相当于将某个字节
  • 类加载器ClassLoader及应用

    类加载器ClassLoader span class token keyword public span span class token keyword class span span class token class name Cla
  • 创建运行时类的对象、调用运行时类的指定结构以及获取运行时类的完整结构

    创建两个类 一个注解 一个接口 用来准备测试 span class token keyword public span span class token keyword class span span class token class n
  • Lambda表达式基本使用的六种情况

    举例 xff1a o1 o2 gt Integer compare o1 o2 格式 xff1a lambda操作符 或 箭头操作符 左边 xff1a lambda形参列表 xff08 其实就是接口中的抽象方法的形参列表 xff09 右边
  • DBeaver登录Mysql所犯的低级错误

    1 简介 DBeaver是免费和开源 xff08 GPL xff09 为开发人员和数据库管理员通用数据库工具 2 安装DBeaver 3 DBeave连接MySQL 3 1 在DBeaver界面的左上角 xff0c 找到加号 xff0c 选
  • sql基础

    DB xff1a 数据库 database xff1a 存储数据的 仓库 它保存了一系列有组织的数据 DBMS xff1a 数据库管理系统 Database Management System 数据库是通过DBMS创建和操作的容器 SQL
  • SQL之DQL语言

    1 基础查询 语法 xff1a select 查询列表 from 表名 其中 xff1a 表中的字段 常量值 表达式 函数 查询字段 xff1a select 字段 多个字段中间逗号隔开 from 表名 查询常量值 xff1a select
  • Ubuntu中安装.deb格式的软件包

    使用dpkg命令进行安装 dpkg命令常用格式如下 xff1a sudo dpkg I iptux deb 查看iptux deb软件包的详细信息 xff0c 包括软件名称 版本以及大小等 xff08 其中 I等价于 info xff09
  • SQL之DDL(数据定义语言)

    1 库的管理 创建库 create database if not exists 库名 更改库的字符集 alter database 库名 character set gbk utf 8 删除库 drop database if exist