数据库(MySQL) —— DDL语句

news2024/11/24 3:05:33

MySQL—— DDL语句

  • 什么是MySQL的DDL语句
  • 查看所有的所有数据库
  • 查看当前使用的数据库
  • 库操作
    • 创建库
    • 使用数据库
    • 删除库
  • 表操作
    • 创建表
    • 查询当前库中所有的表
    • 查询表结构
    • 查询指定表的建表语句
    • 删除表
  • 表修改
    • 删除字段
    • 修改数据类型
    • 修改字段名和字段类型
    • 重命名表
    • 删除指定表并重新创建该表

我们今天接着来学习MySQL的DDL语句,如果还没有看过上一篇MySQL的小伙伴可以点击这里:

https://blog.csdn.net/qq_67693066/article/details/138304228

什么是MySQL的DDL语句

MySQL的DDL(Data Definition Language,数据定义语言)语句是一类用于定义和管理数据库结构的SQL命令。DDL语句允许用户创建、修改和删除数据库中的各种对象,如数据库本身、表、列、索引、视图、存储过程、触发器等,而不涉及数据的实际操作。这些操作通常是数据库管理员(DBA)或有相应权限的开发人员执行的。

MySQL中常见的DDL语句包括:

  1. CREATE:用于创建数据库、表、索引、视图、存储过程、函数等数据库对象。
  • CREATE DATABASE mydb; 创建数据库
  • CREATE TABLE mytable (column1 datatype, column2 datatype); 创建表
  1. ALTER:用于修改现有数据库对象的结构,比如添加、删除或修改表的列、索引等。
  • ALTER TABLE mytable ADD column3 datatype; 向表中添加列
  1. DROP:用于删除数据库对象,比如删除表、索引或整个数据库。
  • DROP TABLE mytable; 删除表
  • DROP DATABASE mydb; 删除数据库
  1. TRUNCATE:虽然有时也被归类在DDL中,但实际上更多地影响数据,它用于清空表中的所有数据,但表结构保持不变。
  • TRUNCATE TABLE mytable; 清空表数据
  1. RENAME:用于重命名数据库或表。
  • ALTER TABLE oldname RENAME TO newname; 重命名表

DDL语句执行的结果通常会永久性地改变数据库结构,因此在执行之前应谨慎考虑并确保有相应的备份策略。

查看所有的所有数据库

查看所有的所有数据库我们要用到show databases

show databases;

在这里插入图片描述
同时注意一下,这几个数据库是系统自带的,不要删
在这里插入图片描述还有这几个用户,也是系统自带的,也不要删
在这里插入图片描述

查看当前使用的数据库

查看当前使用的数据库:

select database();

在这里插入图片描述这个结果表示我们还没有使用库。

库操作

创建库

创建库:

create database 数据库名字;

在这里插入图片描述

使用数据库

使用数据库:

use 数据库名;

在这里插入图片描述
再执行一次查看当前使用的数据库:
在这里插入图片描述

删除库

删除库:

drop database 数据库名称;

在这里插入图片描述

表操作

创建表

CREATE TABLE table_name (
    column1 datatype1,
    column2 datatype2,
    ...
);

其中,请将table_name替换为要创建的表的名称,将column1column2等替换为列名,将datatype1datatype2等替换为相应的数据类型。

例如,要创建一个名为employees的表,其中包含id、name和age列,您可以执行以下命令:

CREATE TABLE employees (
    id INT PRIMARY KEY,
    name VARCHAR(50),
    age INT
);

在这里插入图片描述

查询当前库中所有的表

查询当前库中所有的表:

show tables;

在这里插入图片描述

查询表结构

查询表结构:

desc 表名;

在这里插入图片描述

查询指定表的建表语句

查询指定表的建表语句:

show create table 表名;

在这里插入图片描述

删除表

删除表:

drop table 表名;

在这里插入图片描述

表修改

如果我们想给employees表加上一个新的字段,我们可以使用

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

例如,要在employees表中添加一个名为email的列,可以执行以下命令:

ALTER TABLE employees ADD COLUMN email VARCHAR(100);

在这里插入图片描述
再来看一下表结构:
在这里插入图片描述

删除字段

删除字段:

ALTER TABLE 表名 DROP COLUMN 字段;

例如,要从employees表中删除email列,您可以执行以下命令:

ALTER TABLE employees DROP COLUMN email;

在这里插入图片描述

修改数据类型

修改数据类型:

ALTER TABLE 表名 MODIFY COLUMN 旧类型 新类型;

例如,要将employees表中的age列的数据类型从INT更改为FLOAT,可以执行以下命令:

ALTER TABLE employees MODIFY COLUMN age FLOAT;

在这里插入图片描述

修改字段名和字段类型

修改字段名和字段类型:

ALTER TABLE 表名 CHANGE COLUMN 旧字段名 新字段名 类型(长度);

比如将employees表中的name改为NAME 并将varchar长度延伸到100:

ALTER TABLE employees CHANGE COLUMN name Name varchar(100);

在这里插入图片描述

重命名表

重命名表:

ALTER TABLE 旧表名 RENAME TO 新表名;

例如,要将employees表重命名为staff,您可以执行以下命令:

ALTER TABLE employees RENAME TO staff;

在这里插入图片描述

删除指定表并重新创建该表

删除指定表并重新创建该表:

TRUNCATE TABLE 表名;

我们可以对staff表进行操作:

TRUNCATE TABLE staff;

这里我先插入一条数据:
在这里插入图片描述

然后重新执行这条语句:
在这里插入图片描述再来看:

在这里插入图片描述
发现原来的记录没有了,这是因为我们删除又重新创建了表。

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

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

相关文章

c3 笔记7 css基本语法

相关内容:字体、段落、词间距、文字效果(对齐、上下标、阴影)、背景图、背景渐变、…… 单位pt与px的差别pt是印刷使用的字号单位,不管屏幕分辨率是多少,打印到纸上看起来都是相同的,lot的长度是0.01384英寸…

Mybatis四种实例化对象方式

代码准备 创建mybatis-config.xml <?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration…

【golang学习之旅】深入理解字符串string数据类型

系列文章 【golang学习之旅】报错&#xff1a;a declared but not used 【golang学习之旅】Go 的基本数据类型 目录 系列文章使用示例string的底层数据结构关于字符串复制字符串是不可变的如何高效的进行字符串拼接&#xff1f; 使用示例 Go 语言中的字符串只是一个只读的字节…

CUDA CPP Unity Compute Shader

为学 开始一个新的学习计划&#xff0c;涵盖&#xff1a; 主题学习内容CUDAProfessional CUDA C Programming/NVIDIA CUDA初级教程视频(周斌)CCPrimer / The Cherno CPPUnity Compute ShaderUdemy Learn to Write Unity Compute ShadersLinear AlgebraMIT 18.06 Prof.Gilbert…

typescript类型检查和原始类型

typescript类型检查和原始类型 类型检查 非严格类型是typescript默认的类型检查模式&#xff0c;在该模式下&#xff0c;类型检查的规则相对轻松&#xff0c;不会对undefined和null值做过多的限制&#xff0c;允许将undefined和null值赋给string类型的变量。进行JavaScript代…

【算法】高精度乘法

前言 最近在参加某个比赛的时候遇到了这个问题&#xff0c;用字符串表示时&#xff0c;长度能达到15&#xff0c;所以针对大数乘法写一篇文章。 高精度 * 低精度 在这种场景下&#xff0c;一般都是给定一个无法用int或long long 存储的数&#xff0c;再给定一个能用int或lon…

第74天:漏洞发现-Web框架中间件插件BurpSuite浏览器被动主动探针

目录 思维导图 前置知识 案例一&#xff1a;浏览器插件-辅助&资产&漏洞库-Hack-Tools&Fofa_view&Pentestkit 案例二&#xff1a; BurpSuite 插件-被动&特定扫描-Fiora&Fastjson&Shiro&Log4j 思维导图 前置知识 目标&#xff1a; 1. 用…

Linux 进程间通信之命名管道

&#x1f493;博主CSDN主页:麻辣韭菜&#x1f493;   ⏩专栏分类&#xff1a;Linux知识分享⏪   &#x1f69a;代码仓库:Linux代码练习&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习更多Linux知识   &#x1f51d; 目录 前言 命名管道 创建一个命名管道 …

八大排序详解:动图、代码、注释

目录 何为八大排序&#xff1f; 直接插入排序 排序过程解读 直接插入排序的特性总结&#xff1a; 希尔排序 希尔排序的特性总结&#xff1a; 直接选择排序 直接选择排序的特性总结&#xff1a; 堆排序 直接选择排序的特性总结&#xff1a; 冒泡排序 快速排序 1.Hoa…

全景剖析阿里云容器网络数据链路(七):Terway DataPath V2(Terway≥1.8.0)

作者&#xff1a;余凯 前言 近几年&#xff0c;企业基础设施云原生化的趋势越来越强烈&#xff0c;从最开始的IaaS化到现在的微服务化&#xff0c;客户的颗粒度精细化和可观测性的需求更加强烈。容器网络为了满足客户更高性能和更高的密度&#xff0c;也一直在高速的发展和演…

【JavaEE网络】网络编程及其应用概述

目录 面向字节流粘包问题 TCP异常情况TCP/UDP对比 网络层重点协议IP协议IP地址 面向字节流 粘包问题 在面向字节流的情况下&#xff0c;会产生一些其他的问题&#xff1a;粘包问题&#xff0c;这里“粘”的是“应用层数据报”&#xff0c;通过TCP read/write的数据&#xff0…

jvm 马士兵 01

01.JVM是什么 JVM是一个跨平台的标准 JVM只识别class文件&#xff0c;符合JVM规范的class文件都可以被识别

javaScript 判断闰年

接受用户输入年份 如果是闰年就弹出闰年&#xff0c;遇到平年就是弹出平年 var a prompt(请输入年份);if(a%40&&a%100!0||a%4000){alert(闰年);}else{alert(平年);}

智慧校园为师生带来的那些帮助

随着互联网技术的发展&#xff0c;学校高度重视校园信息化建设&#xff0c;越来越多的学校开始建设智能校园。智慧校园是以智慧校园建设为基础&#xff0c;为学生的校园生活和学校的日常管理带来生机和活力。 那么&#xff0c;在当代环境下建设智慧校园的必要性是什么呢&#x…

Java集合框架-容器源码分析

Java集合框架-容器&源码分析 文章目录 Java集合框架-容器&源码分析[TOC](文章目录)前言一、集合框架概述二、Collection接口及其子接口(List/Set)及实现类2.1 Collection接口中方法2.2 遍历&#xff1a;Iterator迭代器接口&foreach(5.0新特性)2.3 Connection子接口…

Java中使用Redis实现分布式锁的三种方式

1. 导语 随着软件开发领域的不断演进,并发性已经成为一个至关重要的方面,特别是在资源跨多个进程共享的分布式系统中。 在Java中,管理并发性对于确保数据一致性和防止竞态条件至关重要。 Redis作为一个强大的内存数据存储,为在Java应用程序中实现分布式锁提供了一种高效的…

WSL2连接Windows主机的Mysql

文章目录 需求查看主机IP防火墙设置Mysql设置允许远程连接WSL2连接Mysql 需求 在WSL2&#xff08;本机Ubuntu20.04&#xff09;运行的程序需要将数据写入到本机的Mysql服务器中 查看主机IP 两种办法&#xff1a; Windows主机输入 ipconfig&#xff0c;找到带有WSL后缀的部分…

第13章 软件测评相关标准

一、标准化概述 &#xff08;一&#xff09;概念 1、标准 一定范围内获得最佳秩序&#xff0c;经协商一致并由公认机构批准共同使用和重复使用的一种规范性文档&#xff0c;是标准化活动的核心产物。 2、标准化 一定范围内获得最佳秩序&#xff0c;对现实问题和潜在问题制…

ctfshow——SSRF

文章目录 web 351web 352web 353web 354web 355web 356web357web 358web 359web 360 SSRF(Server-Side Request Forgery&#xff1a;服务器端请求伪造) 是一种由攻击者构造形成由服务端发起请求的一个安全漏洞。一般情况下&#xff0c;SSRF攻击的目标是从外网无法访问的内部系统…

Java | Leetcode Java题解之第64题最小路径和

题目&#xff1a; 题解&#xff1a; class Solution {public int minPathSum(int[][] grid) {if (grid null || grid.length 0 || grid[0].length 0) {return 0;}int rows grid.length, columns grid[0].length;int[][] dp new int[rows][columns];dp[0][0] grid[0][0]…