05 mysql之DDL

一、SQL的四个分类

我们通常可以将 SQL 分为四类,分别是:
DDL(数据定义语言)、DML(数据操作语言)、 DCL(数据控制语言)和 TCL(事务控制语言)。

DDL 用于创建、删除、修改数据库结构(如表、索引、视图等),核心语句createdropalter、truncate
DML 负责数据的插入、删除、更新和查询,核心语句insertdeleteupdate
DQL 负责从数据库中检索数据,是使用频率最高的SQL类型,核心语句select
DCL 用于管理数据库访问权限和数据安全,核心语句grantrevoke

二、什么是 DDL?

DDL 是 SQL 的一部分,用于定义和管理数据库的结构(模式)。主要命令包括:

  • CREATE:创建数据库、表、视图等对象
  • ALTER:修改现有数据库对象
  • DROP:删除数据库对象
  • TRUNCATE:删除表中的数据但保留结构

其中DROP是删除数据库,可以参考之前的文章。

三、创建数据库

语句:CREATE DATABASE 数据库名;

我们使用root登录mysql,输入CREATE DATABASE school_db;

一般来说,我们采用root创建数据库,然后可以将其赋予别的用户进行管理,我们把该数据库赋给leo用户权限 

GRANT ALL PRIVILEGES ON school_db.* TO 'leo'@'localhost';

四、创建表 

我们采用navicat对SQL语句进行演示,使用navicat登录leo用户,会看到有个school_db的数据库

创建 MySQL 数据表的 SQL 通用语法:

CREATE TABLE table_name (column1 datatype,column2 datatype,...
);

参数说明:

  • table_name 是你要创建的表的名称。
  • column1column2, ... 是表中的列名。
  • datatype 是每个列的数据类型。

下面是示例:

4.1 创建学生表

CREATE TABLE students (student_id INT PRIMARY KEY AUTO_INCREMENT,  -- 主键,自增student_name VARCHAR(50) NOT NULL,          -- 非空字段age INT CHECK (age > 0),                    -- 年龄必须大于0gender ENUM('M', 'F', 'Other') DEFAULT 'Other',  -- 枚举类型birth DATE NOT NULL                         -- 生日
);

在学习这个链接上右键刷新,然后我们就可以看到建立的数据表了。 

4.2 创建老师表

在上个示例中,我们采用的是SQL语句创建的,我们还可以使用navicat通过界面进行创建

第一步:在表上右键,新建表

第二步:添加主键

第三步:保存表,右上角,保存:
 

输入表名:Teachers,然后点保存
 

第四步:添加字段
通过添加字段按钮,依次添加如下字段 ,其中工作年限设置为0

第五步:添加外键

外键用于在两个表之间建立一对一、一对多或多对多的关系。例如,在老师表和学生表之间,老师表中的mentor_student_id字段可以作为外键,关联到学生表中的student_id字段,从而实现老师和学生之间的关联,老师表也称为父表,学生表也成为子表。

五、修改表结构(ALTER)

添加一个新列到 students 表: 

ALTER TABLE students ADD COLUMN email VARCHAR(100) UNIQUE;

修改 teachers 表的 subject 列:

ALTER TABLE teachers MODIFY subject VARCHAR(60) NOT NULL;

六、删除表 

6.1 删除表(保留结构):

TRUNCATE TABLE students;  -- 清空数据但保留表结构

注意:因为在Teachers表中包含有students的外键,删除是会出错的,所以需要先去删除Teachers的外键。

6.2 删除表(结构和数据):

DROP TABLE teachers;

七、查看表结构

 使用 DESCRIBE 或 SHOW CREATE TABLE 查看表定义:

DESCRIBE students;
SHOW CREATE TABLE students;

八、navicat导出表结构

可以通过在表上右键->转储SQL文件,导出数据表的结构和数据
比如到处的数据表结构文件内容如下:里面清晰的定义了表的字段等详细内容
 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/79239.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1 2 3 4 5顺序插入,形成一个红黑树

红黑树的特性与优点 红黑树是一种自平衡的二叉搜索树,通过额外的颜色标记和平衡性约束,确保树的高度始终保持在 O(log n)。其核心特性如下: 每个节点要么是红色,要么是黑色。根节点和叶子节点(NIL节点)是…

微服务6大拆分原则

微服务6大拆分原则 微服务拆分是指将一个大型应用程序拆分成独立服务的过程,在微服务拆分时,需要考虑以下6大微服务拆分原则 一、单一职责原则 微服务单一职责原则,是指每个微服务应该专注于解决一个明确定义的业务领域或功能,…

java: Compilation failed: internal java compiler error 报错解决方案

java: Compilation failed: internal java compiler error 报错解决方案 如下图所示: 在编译的时候提示 java: Compilation failed: internal java compiler error 原因:内部 java 编译错误,一般是编译版本不匹配。 问题解决 项目中有以下设置JDK版本…

介绍一下ReentrantLock 跟 Synchronized 区别

ReentrantLock 跟 Synchronized 区别 面试回答: 相同点: synchronized 和 ReentrantLock 都是用来保护资源线程安全的。 都可以保证可见性。 synchronized 和 ReentrantLock 都拥有可重入的特点。 从基本语义和概念上说 synchronized: Java 内建的…

第7次课 栈A

课堂学习 栈(stack) 是一种遵循先入后出逻辑的线性数据结构。 我们可以将栈类比为桌面上的一摞盘子,如果想取出底部的盘子,则需要先将上面的盘子依次移走。我们将盘子替换为各种类型的元素(如整数、字符、对象等&…

ts装饰器

TypeScript 装饰器是一种特殊类型的声明,能够被附加到类声明、方法、访问符、属性或参数上。它本质上是一个函数,会在运行时被调用,并且被装饰的声明信息会作为参数传递给装饰器函数。 装饰器的分类 类装饰器 类装饰器作用于类构造函数&…

【金仓数据库征文】政府项目数据库迁移:从MySQL 5.7到KingbaseES的蜕变之路

摘要:本文详细阐述了政府项目中将 MySQL 5.7 数据库迁移至 KingbaseES 的全过程,涵盖迁移前的环境评估、数据梳理和工具准备,迁移实战中的数据源与目标库连接配置、迁移任务详细设定、执行迁移与过程监控,以及迁移后的质量验证、系…

VB与Excel无缝连接实现指南

一、前期准备 引用Excel对象库: 在VB开发环境中,点击"项目"→"引用" 勾选"Microsoft Excel XX.X Object Library"(XX.X代表版本号) 创建Excel应用程序对象: vb Dim xlApp As Excel.…

【MySQL】数据库、数据表的基本操作

个人主页:Guiat 归属专栏:MySQL 文章目录 1. MySQL基础命令1.1 连接MySQL1.2 基本命令概览 2. 数据库操作2.1 创建数据库2.2 查看数据库2.3 选择数据库2.4 修改数据库2.5 删除数据库2.6 数据库备份与恢复 3. 表操作基础3.1 创建表3.2 查看表信息3.3 创建…

cursor sign in 网页登录成功,sursor软件里一直登陆不成功没有登陆信息

今天在使用cursor登陆无法登陆,点击sigin in打开网址登陆成功后,软件里一直无法显示登陆信息。 点击sigin in 在网址登陆成功后 解决办法: 方法1.设置windows默认应用为chrome. 办法2: 删除代理 cursor上ctrl, 打开设置,找到…

深入理解卷积神经网络的输入层:数据的起点与预处理核心

内容摘要 本文围绕卷积神经网络输入层展开,详细介绍其在网络中的重要作用,包括接收不同领域数据的形式及传递数据的过程。深入解读数据预处理的关键操作,如去均值、归一化和PCA/白化。助力读者透彻理解输入层,为构建高效卷积神经…

解决 MySQL 数据库无法远程连接的问题

在使用 MySQL 数据库时,遇到这样的问题: 本地可以连接 MySQL,但远程机器连接时,总是报错 Host ... is not allowed to connect to this MySQL server。 这通常是因为 MySQL 的用户权限或配置限制了远程访问。 1. 登录 MySQL 数据…

MCP认证全解析:从零到微软认证专家

MCP认证全解析:从零到微软认证专家 什么是MCP认证? Microsoft Certified Professional(MCP)是由微软官方颁发的技术认证,旨在验证IT从业者在微软技术栈(如Azure、Windows Server、SQL Server等&#xff0…

驱动开发系列57 - Linux Graphics QXL显卡驱动代码分析(四)显示区域更新

一:概述 前面在介绍了显示模式设置(分辨率,刷新率)之后,本文继续分析下,显示区域的绘制,详细看看虚拟机的画面是如何由QXL显卡绘制出来的。 二:相关数据结构介绍 struct qxl_moni…

远程调用负载均衡LoadBalancer

1. 什么是负载均衡 负载均衡就是将负载(工作任务,访问请求)进行分摊到多个操作单元(服务器,组件)上进行执行。 根据负载均衡发生位置的不同,一般分为服务端负载均衡和客户端负载均衡。 服务端负载均衡:指的…

【深度学习】【目标检测】【Ultralytics-YOLO系列】YOLOV3核心文件detect.py解读

【深度学习】【目标检测】【Ultralytics-YOLO系列】YOLOV3核心文件detect.py解读 文章目录 【深度学习】【目标检测】【Ultralytics-YOLO系列】YOLOV3核心文件detect.py解读前言if name ‘main’parse_opt函数main函数run函数不同命令参数的推理结果常规推理命令推理命令(新增…

NextPolish1.4.1 安装与使用-bioinformatics tools54

01 简介 NextPolish 是一个用于修正由低准确度长读段(如 ONT 或 CLR)组装出来的基因组序列中碱基错误(SNV/Indel)的工具。它支持: 仅使用短读段 仅使用长读段 同时使用短读段与长读段 NextPolish 包含两个核心模块…

Vue3 el-tree:全选时只返回父节点,半选只返回勾选中的节点(省-市区-县-镇-乡-村-街道)

需求原因:全选时,传给接口的code数据太多了; 如果加上 check-strictly 父节点与子节点无关联,可以初步满足需求 效果如下使用了check-strictly的话,tree就没有了半选效果 不好的地方:用户体验感不好&#x…

使用 docker 安装 nacos3.x

一、安装 nacos 1.拉取镜像 使用如下指令拉取镜像 docker pull nacos/nacos-server 拉取完成后,可以使用以下命令查看是否拉取到对应的镜像,默认拉取最新镜像 docker images 2.新建挂载文件目录 mkdir -p /home/ubuntu/nacos/conf/mkdir -p /home/…

高性能Python Web 框架--FastAPI 学习「基础 → 进阶 → 生产级」

以下是针对 FastAPI 的保姆级教程,包含核心概念、完整案例和关键注意事项,采用「基础 → 进阶 → 生产级」的三阶段教学法: 一、FastAPI介绍 FastAPI 是一个现代化的、高性能的 Python Web 框架,专门用于构建 APIs(应…