05 mysql之DDL

news2025/5/11 19:18:03

一、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),                    -- 年龄必须大于0
  gender 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.coloradmin.cn/o/2373360.html

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

相关文章

电池热管理CFD解决方案,为新能源汽车筑安全防线

在全球能源结构加速转型的大背景下,新能源汽车产业异军突起,成为可持续发展的重要驱动力。而作为新能源汽车 “心脏” 的电池系统,其热管理技术的优劣,直接决定了车辆的安全性、续航里程和使用寿命。电池在充放电过程中会产生大量…

TransmittableThreadLocal:穿透线程边界的上下文传递艺术

文章目录 前言一、如何线程上下文传递1.1 ThreadLocal单线程1.2 InheritableThreadLocal的继承困境1.3 TTL的时空折叠术 二、TTL核心设计解析2.1 时空快照机制2.2 装饰器模式2.3 采用自动清理机制 三、设计思想启示四、实践启示录结语 前言 在并发编程领域,线程上下…

基于STM32的甲醛检测

一、制作目标 以正点原子的miniSTM32F103RCT6开发板为主控,使用甲醛传感器检测环境空气中的甲醛含量(以mg/m^3为单位)、C02含量(以ppm为单位)和总有机挥发物含量TVOC(以mg/m^3为单位)在OLED显示…

洛图报告中的 FSHD 是什么?—— 解密九天画芯推动的三色光源显示技术

目录 一、洛图报告新焦点:FSHD 为何成为显示产业重要突破方向? (一)洛图报告核心结论:从技术突围到产业重构 二、技术解析:FSHD 如何重构显示底层逻辑? (一)物理架构…

【MySQL】事务(重点)

目录 一、什么是事务: 二、事务的前置知识了解 引擎是否支持事务 事务的提交方式 事务操作的前置准备: 三、事务回滚: 四、事务崩溃: 原子性: 持久性: 五、自动提交和手动提交: 六、…

Linux:线程同步与互斥

目录 线程互斥 锁 初始化 销毁 加锁 解锁 线程同步 条件变量 初始化 销毁 等待条件满足 唤醒等待 pthread_cond_signal pthread_cond_broadcast 生产者消费者模型 3种关系 2种角色 1个交易场所 POSIX信号量 初始化 销毁 等待 发布 线程互斥 互斥相关…

每天五分钟机器学习:拉格朗日对偶函数

本文重点 在数学优化领域,拉格朗日对偶函数作为连接原始约束问题与对偶问题的核心纽带,展现了将复杂约束优化转化为无约束优化的方式。 数学表达 原始问题建模 拉格朗日函数构造 此时的目标就是: 先假设w为常数,让拉格朗日函数对橙子变量λ求极大值,消掉λ之后,在对λ求…

AutoGen 框架解析:微软开源的多人 Agent 协作新范式

一、引言 在大语言模型(LLM)快速发展的今天,复杂任务的自动化协作需求日益增长。微软开源的AutoGen 框架(GitHub Star 超 10 万)提供了一种基于多智能体对话的协作范式,通过自然语言交互实现多角色 Agent …

【bibtex4word】在Word中高效转换bib参考文献,Texlive环境安装bibtex4word插件

前言 现已退出科研界,本人水货一个。希望帮到有缘人 本篇关于如何将latex环境中的参考文献bib文件转化为word,和一些踩坑记录。 可以看下面的资料进行配置,后面的文字是这些资料的补充说明。 参考文章:https://blog.csdn.net/g…

单片机-STM32部分:10-2、逻辑分析仪

飞书文档https://x509p6c8to.feishu.cn/wiki/VrdkwVzOnifH8xktu3Bcuc4Enie 安装包如下:根据自己的系统选择,目前这个工具只有window版本哦 安装方法比较简单,都按默认下一步即可,注意不要安装到中文路径哦。 其余部分参考飞书文档…

计算机网络基础科普

IP地址是计算机网络中标识设备的唯一地址 IPv4(32位)IPv6(128位) 1.IPv4(32位) 简介:IPv4(Internet Protocol version 4)是互联网协议(IP)的…

阿里云CDN的源站配置:权重的详解

在阿里云CDN中为静态资源域名cdn.example.com配置源站时,权重设置需根据实际架构和目标灵活调整。以下是具体建议和配置步骤: 一、权重的核心作用 在阿里云CDN中,源站权重用于控制多个源站之间的流量分配比例,适用于以下场景&…

虚幻引擎5-Unreal Engine笔记之显卡环境设置使开发流畅

虚幻引擎5-Unreal Engine笔记之显卡环境设置使开发流畅 code review! 文章目录 虚幻引擎5-Unreal Engine笔记之显卡环境设置使开发流畅1.电源管理2.显卡优先设置3.拯救者支持FnQ性能模式切换,建议开发前切至“野兽模式”或高性能模式。4.NVIDIA 驱动设置5.VS2022中…

【Linux】冯诺依曼体系结构和操作系统的理解

目录 冯诺依曼体系结构一个例子来深入理解 初识操作系统操作系统的作用设计操作系统的目的操作系统之上和之下分别有啥 管理的精髓,先描述,再组织 冯诺依曼体系结构 我们知道,计算机这个东西发明出来就是帮助人们快速解决问题的。那如果我们想…

计网学习笔记———网络

🌿网络是泛化的概念 网络是泛化的概念 🍂泛化理解 网络的概念在生活中无处不在举例:社交网络、电话网路、电网、计算机网络 🌿网络的定义 定义: 离散的个体通过通讯手段连成群体,实现资源的共享与交流、个…

数据集-目标检测系列- 烟雾 检测数据集 smoke >> DataBall

数据集-目标检测系列- 消防 浓烟 检测数据集 smoke>> DataBall 数据集-目标检测系列- 烟雾 检测数据集 smoke >> DataBall * 相关项目 1)数据集可视化项目:gitcode: https://gitcode.com/DataBall/DataBall-detections-10…

【单片机毕业设计15-基于stm32c8t6的智能酒窖系统设计】

【单片机毕业设计15-基于stm32c8t6的智能酒窖系统设计】 前言一、功能介绍二、硬件部分三、软件部分总结 前言 🔥这里是小殷学长,单片机毕业设计篇15-基于stm32c8t6的智能酒窖系统设计 🧿创作不易,拒绝白嫖可私 一、功能介绍 ----…

【Bluedroid】蓝牙 HID 设备服务注册流程源码解析:从初始化到 SDP 记录构建

本文围绕蓝牙 HID(人机接口设备)服务注册流程,详细解析从 HID 服务启用、设备初始化、L2CAP 通道注册到 SDP(服务发现协议)记录构建的全流程。通过分析关键函数如btif_hd_service_registration、BTA_HdEnable、HID_Dev…

TWAS、GWAS、FUSION

全基因组关联研究(GWAS,Genome-Wide Association Study)是一种统计学方法,用于在全基因组水平上识别与特定性状或疾病相关的遗传变异。虽然GWAS可以识别与性状相关的遗传信号,但它并不直接揭示这些遗传变异如何影响生物…

测试一下多模态提取图片中文字的能力

测试一下多模态提取图片中文字的能力 原图片, 提取结果, 各位嘉宾,大家好!明天(5月11日)9:00-12:00将在大连市高新园区星火亚庭32号A座一层二楼设置咖啡厅等六个小水活动。请大家积极安排时间,…