【MySQL】对表的相关操作(DDL)

2024-03-22 14:52

本文主要是介绍【MySQL】对表的相关操作(DDL),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

👦个人主页:@Weraphael
✍🏻作者简介:目前学习计网、mysql和算法
✈️专栏:MySQL学习
🐋 希望大家多多支持,咱一起进步!😁
如果文章对你有帮助的话
欢迎 评论💬 点赞👍🏻 收藏 📂 加关注✨


前言

以下对表的操作需要在你先使用某个数据表

use [数据表];

目录

  • 前言
  • 一、 创建表(增)
  • 二、查看表(查)
      • 2.1 查看当前数据库有几张表
      • 2.3 查询表的详细信息(查看表结构)
      • 2.3 查询表创建或修改的信息
  • 三、修改表(改)
      • 3.1 修改表名
      • 3.2 向表中添加字段
      • 3.3 向表中插入数据
      • 3.4 修改字段类型
      • 3.5 修改字段名
      • 3.6 删除某一字段及其对应的列数据
  • 四、删除表(删)

一、 创建表(增)

【语法】

create [if not exists] table [表名](field1 datatype,field2 datatype,field3 datatype
)character charset=字符集 collate=校验规则 engine=存储引擎;

说明:

  • field:表示列名。
  • datatype:表示列的类型。
  • character set:指定表的字符集。如果没有指定字符集,则以所在数据库的字符集为准。
  • collate:指定表的校验规则。如果没有指定校验规则,则以所在数据库的校验规则为准。
  • engin:指定表的存储引擎。

当然你也可以不指定字符集、校验规则以及存储引擎,因此建表的语法可以简写成以下这样:

create table [表名](field1 datatype,field2 datatype,field3 datatype...
);

【创建表案例】

默认我已经创建了数据库Userdatabase,如果需要在某个数据库建表,所以需要使用先该数据库Userdatabase

use Userdatabase;

在这里插入图片描述

接下来开始建一个用户表users

create table users(id int comment '用户id',name varchar(32) comment '用户名字',password char(32) comment '用户密码',birthday date comment '用户生日'
)charset=utf8 collate=utf8_general_ci engine=MyIsam;# comment - 在创建表的同时为特定列添加注释
# 字段类诸如varchar、char和date后面会讲

【说明】

不同的存储引擎,创建表的文件不一样。users表我这里设置的是存储引擎是MyISAM,在数据库目录有三个不同的文件,分别是:

  • users.frm表结构
  • users.MYD表数据
  • users.MYI表索引

在这里插入图片描述

当然了,不同的存储引擎的文件个数其实是不一样的,这和 【索引/事务】 是有关的(不做详解,后期再说)。这里我再创建一个engineinnodb的表,其内容和以上一模一样,观察存储目录

在这里插入图片描述

在这里插入图片描述

二、查看表(查)

2.1 查看当前数据库有几张表

show tables;

在这里插入图片描述

2.3 查询表的详细信息(查看表结构)

# 查看表结构
desc [表名];

在这里插入图片描述

【说明】

在这里插入图片描述

2.3 查询表创建或修改的信息

# 查询表创建或修改的信息
show create table [表名] \G;
# \G - 人性化展示(可加可不加)

在这里插入图片描述

我们发现,以上是我们建表时的SQL语句。可是,我们建表时的SQL语句全是小写命令啊,为什么这里变大写了呢?

原因很简单,我们在【MySQL】数据库的基础概念 说过,MySQL架构中有解析器和查询优化器,它们会对 SQL语句进行词法、语法分析,然后对查询执行计划进行优化,选择最佳的查询执行策略,以提高查询性能和效率。

三、修改表(改)

在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表

3.1 修改表名

alter table [表名] rename to [新表名]
# to 可加可不加

在这里插入图片描述

3.2 向表中添加字段

alter table [表名] add [新添加字段] [字段类型] comment '字段的描述信息' after [某个字段];
# after是在某一个已知字段后添加
# 没有在某个字段前添加,本人亲测~

如果新增多个字段时,需要使用()将新增的一批字段括起来

alter table [表名] add (字段1 字段类型1 comment ' ', 字段1 字段类型1 comment ' ', ...);

需要注意: 新增一个字段时,可以指定位置;如果新增多个字段,就不能指定位置。

【使用案例】

假设我要在表users中,在name字段后添加age字段

在这里插入图片描述

3.3 向表中插入数据

insert into [表名] (字段1, 字段2, ..)  values (数据1, 数据2, ...);
# 数据需要和字段一一对应

注意:如果插入的数据包含所有字段,那么(字段1, 字段2, ..)就可以省略,如:

insert into [表名] values (数据1, 数据2, ...);

检索指定表中的所有数据

select * from [表名];

【使用案例】

在这里插入图片描述

3.4 修改字段类型

alter table [表名] modify [字段名] [新字段类型];

【使用案例】

id的字段类型改为定长字符串类型char

在这里插入图片描述

当然也可以查询表创建时信息

show create table [表名] \G;

在这里插入图片描述

可以看到,之前的注释没了,并且字段的类型也修改了(覆盖原来的内容)

3.5 修改字段名

alter table [表名] change [旧字段名] [新字段名] [新字段类型];

【使用案例】

将原id字段修改为hobby,并且字段类型为varchar(32)

在这里插入图片描述

3.6 删除某一字段及其对应的列数据

alter table [表名] drop [字段];

【使用案例】

hobby字段删除

在这里插入图片描述

四、删除表(删)

注意:删除表请谨慎操作,建议删除前先备份。

drop table [表名];

这篇关于【MySQL】对表的相关操作(DDL)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/835517

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1