【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

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误