【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领…

pyqt5与selenium混合使用心得

最近想爬一个网站的数据,有用户名密码 但登陆时验证码比较麻烦,是实时变化的一个动态地址 主要给客户使用的 所以无需全自动抓取 def send_request(driver, url, params, method=POST):if method == GET:parm_str = for key, value in params.items():parm_str = parm_st…

MQ组件之RabbitMQ学习

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

【LeetCode-46.全排列】

题目详情: 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1: 输入:nums [1,2,3] 输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2: …

字符型数据详解

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

DPDK and Trex环境指南

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

Linux的常用命令-1

ifconfig:看网络 ifconfig -a:看所以包括禁掉的网卡 ifconfig 网卡名 down:关网卡 ifconfig 网卡名 up:开网卡 ps -ef|grep 服务名:显示进程(ps -ef|grep sshd) kill -9 进程编号:杀进程 clear:清屏 exit:退出shell 切用户 …

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

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;不让它检测出我是他大佬

重要的数据模型之一Brand

重要的数据模型之一Brand 1. 创建class类2. 属性 2.1 属性name2.2 其他属性2.3 代码2.4 绘制牌2.5 添加属性2.6 重写绘制函数2.7 错误2.8 简单测试一下 3. 定义一个线程4. 修改5. 本次结束代码 重要的数据模型之一Brand 学习于bilibili 春娇与志明 1. 创建class类 在model包…

【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. ⾃由(不会被强加商业产品和…

练习题-15

问题&#xff1a;设函数 f ( x ) ∑ n 0 ∞ cos ⁡ ( n x ) 2 n f(x)\sum_{n 0}^{\infty} \frac{\cos (nx)}{2^n} f(x)∑n0∞​2ncos(nx)​. 求 A ∫ 0 2 π f 2 ( x ) d x A\int_0^{2\pi} f^2(x) dx A∫02π​f2(x)dx. 解&#xff1a;把 f f f看成是某个周期 2 π 2\pi 2…

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;没有引用传递 文章讲解 文…