【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 [表名];

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

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

相关文章

GPT-5可能会在今年夏天作为对ChatGPT的“实质性改进”而到来

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

MQ组件之RabbitMQ学习

MQ组件之RabbitMQ入门 同步调用和异步调用 在微服务架构中,服务之间的调用有同步调用和异步调用两种方式。 我们使用OpenFeign去调用是同步调用,同步调用的缺点很明显,在下图的场景中,支付完成后需要调用订单服务、仓库服务、短…

字符型数据详解

1 字符常量 C的字符常量是用单撇号括起来的一个字符。如a,x,D,?,$等都是字符常量。注意,a和A是不同的字符常量。 除了以上形式的字符常量外,C还允许用一种特殊形式的字符常量,就是以一个“\”开头的字符序列。例如,前面已经遇到过的,在printf函数中的…

DPDK and Trex环境指南

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、测试拓扑图 二、VirtualBox的网卡配置 三、DPDK支持的网卡 四、DPDK安装 1.DPDK向导 1). 英文向导 2). 中文向导 2.DPDK源码下载 3.DPDK源码解压 4.…

今日问题:动态分配内存出错

2024.3.22 在搜素了许多文章和查阅了许多博客后依然没有找到问题所在&#xff0c;最后无意之间翻看以前的关于动态内存管理的代码后发现&#xff1a; 没加头文件&#xff1a;#include<stdlib.h> 苦笑不得了属于是 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio…

蓝桥杯day7刷题日记

P8697 [蓝桥杯 2019 国 C] 最长子序列 思路&#xff1a;直接遍历&#xff0c;和子序列相同就记录&#xff0c;不然就下一位 #include <iostream> #include <string> using namespace std; int res;int main() {string s,t;cin>>s>>t;int i0,j0;while…

关于msvcp140.dll丢失的解决方法详情介绍,修复dll文件的安全注意事项

在使用电脑的过程中&#xff0c;是否有遇到过关于msvcp140.dll丢失的问题&#xff0c;遇到这样的问题你是怎么解决的&#xff0c;都有哪些msvcp140.dll丢失的解决方法是能够完美解决msvcp140.dll丢失问题的&#xff0c;今天小编将带大家去了解msvcp140.dll文件以及分析完美解决…

代码随想录 Day-23

力扣题目 406.根据身高重建队列 思路 这里可以看出来是有两个维度考虑&#xff0c;和力扣题目 135.分发糖果&#xff08;可以看我day-22的文章&#xff09; 有点类似。 因此遇到这种两个维度权衡的时候&#xff0c;一定是先考虑一个维度再按照另一个维度来重新考虑排序。 两…

innodb 的 buffer pool 管理 page

page 页结构 page是整个InnoDB存储的最基本构件&#xff0c;也是InnoDB磁盘管理的最小单位&#xff0c;与数据库相关的所有内容都存储在这种Page结构里。 Page分为几种类型&#xff0c;常见的页类型有 数据页(Btree Node)Undo页(Undo Log Page)系统页(System Page)事务数据页 …

PC显示字体和浏览器的字体不一致

1&#xff1a;设置了PC的区域&#xff0c;显示字符&#xff0c; 2&#xff1a;导致浏览器显示的字符一半大一半小 3&#xff1a;为什么去设置这个&#xff0c;因为担心封号 4&#xff1a;不让它检测出我是他大佬

【C++初阶】第七站:string类的初识(万字详解、细节拉满)

前言&#xff1a; &#x1f4cd;本文知识点&#xff1a;string的初识 &#x1f4a8;个人博客:Dream_Chaser&#xff5e;-CSDN博客 &#x1f6a9;本专栏&#xff1a;C 目录 一、什么是STL 二、STL的六大组件 三、STL的缺陷 四、为什么学习string类&#xff1f; 五、标准库中…

云ERP vs 本地ERP:优劣对比与选择指南

在性能方面&#xff0c;本地ERP需要需要较高级别的计算机系统和其他设备来确保其高效运行。如果企业的计算机设备不够先进&#xff0c;那么选择本地ERP可能导致系统性能下降。而云ERP解决方案则能保证性能&#xff0c;只要企业拥有稳定的互联网连接即可。 在成本方面&#xff0…

Linux的基本使用

1.Linux的背景 1.1什么Linux Linux是⼀个操作系统.和Windows是"并列"的关系. 1.2Linux系统的优势 1. 开源(意味着免费,便宜) 2. 稳定(Linux可以运⾏很多年,都不会发⽣重⼤问题) 3. 安全(Linux只有管理员或者特定⽤⼾才能访问Linux内核) 4. ⾃由(不会被强加商业产品和…

EasyCloud软件简介

运行环境&#xff1a;Win10 PCL1.9 VTK8.1 Qt5.12 VS2017 基于PCL点云库的三维点云数据处理软件 1&#xff0e;软件用户界面 本软件的用户界面主要包括以下几个部分&#xff08;如图1&#xff09;&#xff1a; [1]菜单栏&#xff0c;将软件功能模块划分为不同菜单&…

JAVA八股--集合面试题

AVA八股--集合面试题--上 java只有值传递&#xff0c;没有引用传递代理模式Java之HashMap和Hashtable选用 ArrayDeque 来实现队列要比 LinkedList 更好为什么HashMap的长度一定是2的次幂&#xff1f;HashMap常见遍历方式 java只有值传递&#xff0c;没有引用传递 文章讲解 文…

第四讲 Buffer Pool

问题&#xff1a;DBMS 是如何管理其内存和磁盘之间来回移动数据的&#xff1f; 答案&#xff1a;在决定如何在磁盘中来回移动数据时&#xff0c;我们必须考虑两个关键方面&#xff1a; 空间控制【Spatial Control】&#xff1a; 将页【pages】写在在磁盘的什么地方&#xff…

vsc ctrl+. 无效的问题

描述 ubuntu ibus 输入法 vsc ctrl.快捷键无效 输出 _e 解决方案: 运行 ibus-setup 把表情符号这里的快捷键改了

mysql 空间查询 多边形内的点

数据库查询 # 1新增空间point类型坐标字段 ALTER TABLE gaoxin_isdp.business_master ADD COLUMN location2 point NULL AFTER location;# 2从原字段更新点位字段&#xff0c;原字段poi1是字符串106.474596,29.464360 UPDATE business_master SET location POINT(substr(poi…

基于Springboot+Vue的前后端分离的简单Demo案例(一)

后端创建Springboot项目 创建数据库表结构及表信息 添加依赖&#xff08;pom.xml&#xff09; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/X…

微服务网关介绍

1. 为什么是Spring Cloud Gateway 一句话&#xff0c;Spring Cloud已经放弃Netflix Zuul了。现在Spring Cloud中引用的还是Zuul 1.x版本&#xff0c;而这个版本是基于过滤器的&#xff0c;是阻塞IO&#xff0c;不支持长连接。Zuul 2.x版本跟1.x的架构大一样&#xff0c;性能也有…