sql语法:详解DDL

news2024/10/2 8:35:29

Mysql版本:8.0.26
可视化客户端:sql yog

目录

  • 一、DDL是什么?
  • 二、和数据库相关的DDL
    • 2.1 创建数据库
    • 2.2 删除数据库
    • 2.3 查看所有的数据库,当前用户登录后,可以看到哪些数据库
    • 2.4 查看某个数据库的详细定义
    • 2.5 修改数据库的编码
    • 2.6 使用数据库
  • 三、和数据表相关的DDL
    • 3.1 查看某个数据库的所有表格
    • 3.2 创建数据表
    • 3.3 查看表的详细定义信息
    • 3.4 查看表结构
    • 3.5 删除表格,包括表结构和里面的数据
    • 3.6 修改表的字符集和校对规则
    • 3.7 修改表结构:增加字段
    • 3.8 修改表结构:删除字段
    • 3.9 修改一个字段名称
    • 3.10 修改表结构:修改字段的数据类型
    • 3.11 修改表结构:修改字段位置
    • 3.12 修改表名称(重命名表)


提示:以下是本篇文章正文内容,下面案例可供参考

一、DDL是什么?

DDL,英文全称为Data Definition Language,中文释义为“数据库模式定义语言”,即是用于创建库、创建表、修改库和表的结构,虽说有了可视化客户端,可以很方便的使用上述功能,但在批量修改的业务场景下,以此DDL写成的sql脚本比在可视化客户端下执行相比,简直好用太多。


二、和数据库相关的DDL

2.1 创建数据库

👉语法:

CREATE DATABASE 数据库名

案例: 创建数据库0225db

CREATE DATABASE 0225db;

在这里插入图片描述

2.2 删除数据库

👉语法:

DROP DATABASE IF EXISTS 数据库名称

案例:删除数据库0225db

DROP DATABASE IF EXISTS 0225db;

2.3 查看所有的数据库,当前用户登录后,可以看到哪些数据库

👉语法:

SHOW DATABASES:

SHOW DATABASES:

在这里插入图片描述

2.4 查看某个数据库的详细定义

👉语法:

SHOW CREATE DATABASE 数据库名称;

案例:查看0225db的详细定义

代码演示如下:

SHOW CREATE DATABASE 0225db;

在这里插入图片描述

2.5 修改数据库的编码

👉语法

ALTER DATABASE 数据库名 CHARACTER SET 新的字符集名称 COLLATE 校对规则

案例:修改数据库0106db的编码规则

修改之前:

在这里插入图片描述
代码修改如下所示:

ALTER DATABASE 0106db CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE DATABASE `0106db` /*!40100 DEFAULT CHARACTER SET utf8 */ /*!80016 DEFAULT ENCRYPTION='N' */

在这里插入图片描述
在这里插入图片描述

注意:

假如你现在修改了数据库的字符集规则,原来已经存放的数据表的字符集规则不变

2.6 使用数据库

👉语法:

use 数据库名;


三、和数据表相关的DDL

一般先要指定在哪个数据库,才能对表进行操作

3.1 查看某个数据库的所有表格

👉语法

USE 数据库名;
SHOW TABLES;

show tables from 数据库名;

案例:查看0106db下的所有数据表

代码演示如下:

USE 0106db;
SHOW TABLES;


SHOW TABLES FROM 0106db;

在这里插入图片描述

3.2 创建数据表

👉语法

CREATE TABLE 表名称(
	字段名1 数据类型,
	字段名2	数据类型,
	字段名3 数据类型
)

案例:创建学生表Stu,其中包含学生学号,姓名,出生日期,成绩,体重,性别,电话等字段。

代码演示如下:

CREATE TABLE Stu(
	sid INT,
	sname VARCHAR(20),
	birthday DATE,
	score INT,
	gender ENUM('男','女'),
	weight DOUBLE(4,1),
	tel CHAR(11)
)

在这里插入图片描述

3.3 查看表的详细定义信息

👉语法:

SHOW CREATE TABLE 表名称;

案例:查看表stu的详细定义信息

SHOW CREATE TABLE STU;

在这里插入图片描述

3.4 查看表结构

👉语法:

DESC 数据表名;

案例:查看数据表stu的表结构

代码演示如下:

DESC stu;

在这里插入图片描述

3.5 删除表格,包括表结构和里面的数据

👉语法:

①DROP TABLE 表名称;

②DROP TABLE stu IF EXISTS;

第二句的意思是:如果数据库中存在stu表,就把它从数据库0102db中删掉。
👉推荐使用第二种,避免出现“Unknown table ‘0106db.stu’”报错信息。

案例:删除学生表stu

代码演示如下:

DROP TABLE  IF EXISTS stu;

在这里插入图片描述

3.6 修改表的字符集和校对规则

👉语法:

ALTER TABLE 表名称 CHARSET=新字符集 COLLATE=新校对规则;

案例:修改表stu的字符集为utf8mb4,校队规则为utf8mb4_0900_ai_ci

修改之前:

在这里插入图片描述

代码修改如下:

ALTER TABLE stu CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

在这里插入图片描述

3.7 修改表结构:增加字段

👉语法:

ALTER TABLE 表名称 ADD COLUMN 字段名 数据类型;

案例:给学生表stu增加一个varchar(50) 的字段address

代码演示如下:

ALTER TABLE stu ADD COLUMN address VARCHAR(50);

在这里插入图片描述

3.8 修改表结构:删除字段

👉语法:

ALTER TABLE 表名称 DROP COLUMN 字段名;

案例:在学生表中删除刚才新加的字段address

代码演示如下:

ALTER TABLE stu DROP COLUMN address ;

在这里插入图片描述

3.9 修改一个字段名称

👉语法:

ALTER TABLE 表名称 CHANGE 旧字段名称 新的字段名称 数据类型;

案例:将stu表的tel字段改名为phone

修改之前:
在这里插入图片描述
代码修改之后;

ALTER TABLE stu CHANGE tel phone CHAR(11);

在这里插入图片描述

3.10 修改表结构:修改字段的数据类型

👉语法:

ALTER TABLE 表名称 MODIFY 字段名称 新数据类型;

案例:将stu表的score字段的数据类型修改为double

修改之前:

在这里插入图片描述

代码修改之后:

ALTER TABLE stu MODIFY score DOUBLE:

在这里插入图片描述

3.11 修改表结构:修改字段位置

👉语法:

①ALTER TABLE 表名 MODIFY 字段名称 数据类型 AFTER 另一个字段;

👉上述代码的意思:将要修改位置的字段挪到指定字段的后面

②ALTER TABLE 表名称 MODIFY 字段名称 数据类型 FIRST;

👉上述代码的意思:将要修改位置的字段挪到表格第一行

案例:在stu表中将phone字段挪到sname字段之后

修改之前:

在这里插入图片描述
代码修改之后:

ALTER TABLE stu MODIFY phone CHAR(11) AFTER sname

在这里插入图片描述

案例:将表stu中的字段gender挪到表格首行

修改之前:

在这里插入图片描述
代码修改之后;

ALTER TABLE stu MODIFY gender ENUM('男','女') FIRST;

在这里插入图片描述

3.12 修改表名称(重命名表)

👉语法;

ALTER TABLE 表名称 RENAME TO 新名称;

案例:将表stu重命名为t_stu

代码演示如下:

ALTER TABLE stu RENAME TO t_stu;

在这里插入图片描述


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

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

相关文章

你一定能看懂的数据库事务和事务特性实现原理

一。概念 事务 是数据库执行原子操作的基本单位。一个事务中的多个修改,则要么全部成功执行,要么全部不执行。 关于事务的 MYSQL 官网的解释 Transactions are atomic units of work that can be *committed* or *rolled back*. When a transaction ma…

PyTorch 深度学习实战 | DIEN 模拟兴趣演化的序列网络

01、实例:DIEN 模拟兴趣演化的序列网络 深度兴趣演化网络(Deep Interest Evolution Network,DIEN)是阿里巴巴团队在2018年推出的另一力作,比DIN 多了一个Evolution,即演化的概念。 在DIEN 模型结构上比DIN 复杂许多,但大家丝毫不用担心,我们将DIEN 拆解开来详细地说…

Unity+jenkins自动化打包(1)

一 安装Jenkins https://www.jenkins.io/download/ 官网 1) 使用 brew 安装 2) 安装完成后一般都会遇到问题 我用的是jenkins-lts 稳定版 解决办法 删除掉对应的文件夹 1 rm -rf /usr/local/Homebrew/Library/Taps/homebrew/homebrew-services 2…

内网穿透实现在外远程SQL Server数据库 - Windows环境

目录 前言 1. 本地安装配置SQL Server 2. 将本地sqlserver服务暴露至公网 2.1 本地安装cpolar内网穿透 2.2 创建隧道 3. 公网远程连接sqlserver 3.1 使用命令行远程连接sqlserver, 3.2 使用图形界面远程连接sqlserver 3.3 使用SSMS图形界面远程连接sqlserver 4. 配置…

【服务器】威联通NAS文件共享 - 搭建SFTP服务并内网穿透实现在外远程访问

Yan-英杰的主页 悟已往之不谏 知来者之可追 C程序员,2024届电子信息研究生 目录 前言 1. 威联通NAS启用SFTP 2. 测试局域网访问 3. 内网穿透 3.1 威联通安装cpolar内网穿透 3.2 创建隧道 3.3 测试公网远程访问 4. 配置固定公网TCP端口地址 4.1 保留一个固定TCP…

AI绘图设计师Stable Diffusion成为生产力工具(六):制作一张庆祝五一劳动节的海报

S:AI能取代设计师么? I :至少在设计行业,目前AI扮演的主要角色还是超级工具,要顶替?除非甲方对设计效果无所畏惧~~ 预先学习: 安装webui《Windows安装Stable Diffusion WebUI及问题解决记录》。…

Spring《二》bean的实例化与生命周期

🍎道阻且长,行则将至。🍓 上一篇:Spring《一》快速入门 下一篇:Spring《三》DI依赖注入 目录 一、bean实例化🍍1.构造方法 ***2.静态工厂 *使用工厂创建对象实例化bean 3.实例工厂 ***使用示例工厂创建对象…

深度学习必备书籍——《Python深度学习 基于Pytorch》

作为一名机器学习|深度学习的博主,想和大家分享几本深度学习的书籍,让大家更快的入手深度学习,成为AI达人!今天给大家介绍的是:《Python深度学习 基于Pytorch》 文章目录 一、背景二、内容简介三、新版特色四、作者介绍…

3.26学习周报

文章目录 前言文献阅读摘要简介方法结果讨论结论 时间序列预测学习1.基础知识1.1什么是时间序列?1.2时间序列的基本任务?2.时间序列预测算法汇总LSTM学习 总结 前言 本周阅读文献《Simulate the forecast capacity of a complicated water quality mode…

【SpringBoot】| 邮箱发送验证码,你会了吗?

目录 🦁 题外话🦁 提前准备2.1 配置邮箱第三方登录2.1.1 点击设置——账户2.1.2 开启POP3/SMTP服务 2.2 添加依赖2.3 yaml配置 🦁 进入主题🦁 测试使用🦁 尾声3.1 安利一个生成验证码的工具类3.1.1 添加依赖3.1.2 编写…

Qt音视频开发32-qmedia内核回调拿图片数据

一、前言 使用qmediaplayer来打开视频并播放,默认首选会采用QVideoWidget控件来展示,优点是不用自己来绘制,一切交给了QVideoWidget控件,这样可以做到极低的CPU占用,缺点也明显,就是无法拿到每一帧的图片,很多时候我们还需要主动拿到每一帧的图片来运算做人工智能,通过…

hive之left semi join(左半连接)使用方法

目录 一、建表数据准备 二、语法 三、left semi join例子 四、left semi join、join、left join的区别 1、left semi join 2、left join 3、join 结语 一、建表数据准备 参考hive之full outer join(全连接)使用方法_IMezZ的博客-CSDN博客目录介…

【Bard】谷歌的人工智能工具—Bard初体验

文章目录 一、Bard介绍二、Bard体验1、加入Bard的候补名单2、登入Bard篇3、使用Bard篇(1)提供三种预选方式✨(2)创作生成各类文案(3)无生成图画能力(4)支持语音转文本输入✨&#xf…

AI绘图设计师Stable Diffusion成为生产力工具(五):放大并修复老照片、马赛克照片、身份证件照

S:你安装stable diffusion就是为了看小姐姐么? I :当然不是,当然是为了公司的发展谋出路~~ 预先学习: 安装webui《Windows安装Stable Diffusion WebUI及问题解决记录》。运行使用时问题《Windows使用Stable Diffusion时…

MySQL安装和配置(保姆级别和全网最详细教程)

前言 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系…

OPNET Modeler 例程——ALOHA和CSMA的性能对比

文章目录 概述一、创建 ALOHA 协议模型二、创建 CSMA 协议模型三、创建收信机进程和节点模型四、创建总线型链路模型五、创建网络模型六、查看仿真结果总结 概述 本例程以以太网为例论述总线型网络的建模方法,对数据链路层的 MAC 技术进行建模分析,并进…

【多线程】常见的锁策略

✨个人主页:bit me👇 ✨当前专栏:Java EE初阶👇 ✨每日一语:老当益壮,宁移白首之心;穷且益坚,不坠青云之志。 目 录 🏳️一. 乐观锁 vs 悲观锁🏴二. 普通的互…

【数据分析之道-NumPy(七)】numpy字符串函数

文章目录 专栏导读1、函数说明2、add()函数3、multiply()函数4、center()函数5、capitalize()函数6、title()函数7、lower()函数8、upper()函数9、split()函数10、splitlines()函数11、strip()函数12、join()函数 专栏导读 ✍ 作者简介:i阿极,CSDN Pytho…

2023-04-16 学习记录--C/C++-邂逅C/C++

一、固定格式 ⭐️ stdio的理解: abbr.标准输入输出&#xff08;standard input/output&#xff09;。 #include <stdio.h> int main() {... // 表达式return 0; }二、printf语句&#xff08;输出语句&#xff09; ⭐️ &#xff08;一&#xff09;、前提【重要】 注意&a…

小程序组件化开发

前言 随着小程序的普及&#xff0c;越来越多的开发者开始使用小程序进行开发&#xff0c;而小程序的组件化开发已经成为了一种标配的开发模式。本文将深入介绍小程序组件化开发的相关知识&#xff0c;包括组件的定义、生命周期、通信和使用等方面&#xff0c;帮助大家更好地理解…