【MySQL】表的操作{创建/查看/修改/删除}

news2025/1/11 11:41:27

文章目录

  • 1.创建表
    • 1.1comment:注释信息
    • 1.2存储引擎
  • 2.查看表
  • 3.修改表
    • 3.1add添加列,对原数据无影响
    • 3.2drop删除列
    • 3.3modify修改列类型
    • 3.4change修改列名
    • 3.5rename [to]修改表名
  • 4.删除表
  • 5.总结

1.创建表

CREATE TABLE table_name (
	field1 datatype,
	field2 datatype,
	field3 datatype
) character set 字符集 collate 校验规则 engine 存储引擎;
field 表示列名
datatype 表示列的类型
character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准
collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准

在这里插入图片描述

show create table user1;
show create table user1 \G;

1.1comment:注释信息

注释对于数据库的性能没有任何影响,它们只是作为元数据存储在数据库中,供人阅读。
注释的长度是有限制的,具体限制取决于MySQL的版本和配置,但通常足够长以包含有用的信息。

CREATE TABLE employee (  
    id INT AUTO_INCREMENT COMMENT '员工编号',  
    name VARCHAR(100) COMMENT '员工姓名',  
    position VARCHAR(100) COMMENT '职位',  
    salary DECIMAL(10, 2) COMMENT '薪资',  
    PRIMARY KEY (id)  
) COMMENT='员工信息表';

通过SHOW CREATE TABLE可以查看创建表时的语句

在这里插入图片描述

1.2存储引擎

不同的存储引擎,创建表的文件不一样。

users 表存储引擎是 MyISAM ,在数据目中有三个不同的文件,分别是:
users.frm:表结构
users.MYD:表数据
users.MYI:表索引
innodb是.frm和.ibd(数据和索引放在一个文件)

2.查看表

字段名 字段类型 是否允许为空 索引类型 默认值 扩充
在这里插入图片描述

在这里插入图片描述

3.修改表

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

ALTER TABLE tablename ADD (column datatype [DEFAULT expr][,column datatype]...);
ALTER TABLE tablename MODIfy (column datatype [DEFAULT expr][,column datatype]...);
ALTER TABLE tablename DROP (column);

插入两条记录

insert into users values(1,'a','b','1982-01-04'),(2,'b','c','1984-01-
04');

3.1add添加列,对原数据无影响

在这里插入图片描述

3.2drop删除列

alter table users drop password;

删除字段一定要小心,删除字段及其对应的列数据都没了

3.3modify修改列类型

在这里插入图片描述

3.4change修改列名

alter table Users change name Name varchar(60); --新字段需要完整定义

3.5rename [to]修改表名

alter table users rename [to] Users;

4.删除表

DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...
drop table Users;

5.总结

在MySQL中,DROP TABLE语句用于删除一个或多个表,并释放与之相关的空间。当你想要彻底移除表及其所有数据时,这个语句非常有用。DROP TABLE语句的语法支持一些选项,如TEMPORARY和IF EXISTS,这些选项提供了额外的灵活性和错误处理机制。

基本语法
sql
DROP TABLE [IF EXISTS] tbl_name [, tbl_name] …
使用TEMPORARY关键字
TEMPORARY关键字用于指定要删除的表是临时表。临时表只在当前会话(或连接)中可见,并且当会话结束时会自动删除。然而,如果你想要在当前会话中提前删除临时表,可以使用DROP TEMPORARY TABLE语句。但是,需要注意的是,在DROP TABLE语句中直接使用TEMPORARY关键字并不是MySQL的标准用法。要删除临时表,通常只需使用DROP TABLE,因为MySQL能够识别出哪些表是临时的。

使用IF EXISTS选项
IF EXISTS选项在尝试删除一个或多个表之前检查这些表是否存在。如果表存在,则将其删除;如果表不存在,则不会引发错误,而是简单地忽略该表并继续执行语句中的其他操作(如果有的话)。这在你不知道表是否存在但想要安全地尝试删除它时非常有用。

示例
删除名为my_table的表(如果它存在):
sql
DROP TABLE IF EXISTS my_table;
同时删除两个表(table1和table2),如果它们都存在:
sql
DROP TABLE IF EXISTS table1, table2;
注意:虽然这里提到了TEMPORARY,但在标准DROP TABLE语法中,如果你想要删除临时表,通常不需要(也不能)显式指定TEMPORARY。只需确保你正在正确的会话中操作,并且知道哪些表是临时的。
注意事项
使用DROP TABLE时要格外小心,因为一旦执行,表及其所有数据将被永久删除,且无法恢复(除非你有备份)。
如果你只是想删除表中的数据但保留表结构,应该使用TRUNCATE TABLE语句而不是DROP TABLE。
DROP TABLE操作通常不会记录在二进制日志中,除非你设置了相应的二进制日志格式(如ROW格式),但这取决于你的MySQL配置和版本。

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

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

相关文章

springboot医院门诊挂号系统-计算机毕业设计源码033123

目 录 摘要 1 绪论 1.1研究背景及意义 1.2研究现状 1.3系统开发技术的特色 1.4论文结构与章节安排 2 医院门诊挂号系统系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1数据增加流程 2.3.2数据修改流程 2.3.3数据删除流程 2.3 系统功能分析 2.3.1 功能性分析 2.…

第一百三十八节 Java数据类型教程 - Java boolean数据类型和float数据类型

Java数据类型教程 - Java boolean数据类型 布尔数据类型只有两个有效值:true和false。 这两个值称为布尔值字面量。 我们可以使用布尔值字面量 boolean done; // Declares a boolean variable named done done true; // Assigns true to done布尔变量不能转换为任何其他…

什么是分库分表?它有哪些实现类型?

假如你正在使用关系型数据库开发一款健康类系统。业务发展很好,系统有很多活跃的新老用户,这些用户会和平台的医生团队进行交互,每天可能会生成数万甚至数十万级别的业务数据。这样的话,随着数据量越来越大,系统中的某…

如何选择易用性高的项目管理软件?

随着项目管理在各行各业的广泛应用,选择一款易用性高的项目管理软件变得越来越重要。易用性高的软件可以帮助企业提高工作效率,降低管理成本,同时还能提升团队之间的协作能力。那么,如何选择一款易用性高的项目管理软件呢&#xf…

C++ Linux调试(无IDE)

跨平台IDE编译调试C很方便,如QTCreate 、VSCode、Eclipse等,但是如果只能使用Shell控制台呢,gdb调试的优势就很明显了,在没有IDE的情况下,这个方式最有效。因为上手不是很难,特此整理 参考链接 目录 1、G…

边缘网关在实际应用中的价值与挑战-天拓四方

随着物联网、大数据和人工智能等技术的快速发展,边缘计算逐渐崭露头角,成为推动数字化转型的关键力量。而边缘网关,作为边缘计算的核心组成部分,其重要性不言而喻。本文将以某智能制造企业为例,结合数据分析&#xff0…

MySQL高级-MVCC- readview介绍

文章目录 1、介绍2、ReadView中包含了四个核心字段:3、版本链数据的访问规则:4、不同的隔离级别,生成ReadView的时机不同: 1、介绍 ReadView(读视图)是 快照读 SQL执行时MVCC提取数据的依据,记录…

微信小程序订单发货管理接入

订单发货管理接入指引:https://mp.weixin.qq.com/cgi-bin/announce?token1148555877&actiongetannouncement&key11671435333v04b2&version1&langzh_CN&platform2https://mp.weixin.qq.com/cgi-bin/announce?token1148555877&actiongetann…

Redis基础教程(十):HyperLogLog

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 💝&#x1f49…

掌握IP代理API提取技巧,让你的网络操作更高效!

IP代理在现代网络中扮演着越来越重要的角色。今天,我们将深入探讨IP代理的API提取知识,帮助大家更好地理解和应用这一技术。 IP代理API是什么? IP代理API是提供IP代理服务的接口,允许开发者通过编程方式自动获取和管理代理IP。通…

土壤养分检测仪——助力农田监测

在现代化的农业生产中,精准施肥、科学种植已成为提升作物产量与品质的关键。为了实现这一目标,土壤养分检测仪成为了农田科技的得力助手。这款仪器不仅配备了成品药剂和检测器材,还能在现场进行快速测定,广泛应用于农田土壤养分的…

干式电抗器的工作原理是什么

干式电抗器是电力系统中常用的无功补偿设备,主要用于调节电网的电压、提高功率因数、限制短路电流等。它的工作原理主要是通过在电路中引入一个与负载电流相反的磁场,从而产生一个与负载电流相抵消的电抗力,达到调节电压和功率因数的目的。 干…

昇思25天学习打卡营第12天|linchenfengxue

DCGAN生成漫画头像 通过示例代码说明DCGAN网络如何设置网络、优化器、如何计算损失函数以及如何初始化模型权重。 GAN基础原理 生成式对抗网络(Generative Adversarial Networks,GAN)是一种生成式机器学习模型,是近年来复杂分布上无监督学习最具前景的…

全面详解菲律宾slots游戏本土网盟广告CPI流量效果分析

全面详解菲律宾slots游戏本土网盟广告CPI流量效果分析 一、引言 随着互联网的普及和移动设备的广泛应用,网络游戏行业迅速崛起,成为全球娱乐市场的一大热门。菲律宾作为东南亚地区的重要国家,其网络游戏市场也呈现出蓬勃的发展势头。在这样的…

免费分享:2022年全国地铁站点数据(附下载方法)

数据简介 2022年全国地铁站点数据不仅反应我国城市交通网络的日益完善,也为城市规划、公共交通优化、商业布局、应急响应及智慧城市建设提供了宝贵的数据支持与参考,助力城市发展与居民生活质量的全面提升。 数据属性 数据名称:全国地铁站点…

iPhone苹果手机怎么取消腾讯视频VIP会员自动续费?

腾讯视频会员分为VIP(同时在线设备5台、同时播放设备2台;)和SVIP(同时在线设备8台、同时播放设备3台;),在iPhone苹果手机上开通腾讯视频连续包月、包季、包年后,需要手动取消才能关闭…

全网最全最细的jmeter接口测试教程,建议收藏

在日常工作中,尤其是做接口测试时,我们最经常用到的两个工具,就是Jmeter和postman。今天,我们主要是讲一讲Jmeter在接口测试这一块的一些方式方法。内容比较多,大家可以收藏一下,以后慢慢学。 1&#xff0…

【QT】概述|对象树模型|两种控件模式|信号和槽|lambda

目录 什么是QT 特点 QT程序 main函数 QT按钮 纯代码模式 图形化模式 对象树模型 信号和槽 连接与断开 自动连接 断开连接 信号的发射 lambda表达式 基本语法 捕获列表 Lambda表达式用于信号与槽的连接 例如 什么是QT Qt是一个跨平台的C图形用户界面应用…

AJAX的概述 ,同步和异步的区别 ,AJAX 的交互模型和传统交互模型的区别

一. AJAX的概述 1.1 什么是ajax 同步: 异步: 1.AJAX Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。 ​ 说明:异步:就是不同步。例如我们向后台发送请求,同步的方式是后台必…

南京·2024江苏眼睛健康产业展览会观众邀请·徐州站

6月29日,南京2024全国眼睛健康产业博览会暨眼科医学大会,组委会一行六人来到国家级历史文化名城-徐州,开启了南京全国眼博会江苏省十三个城市线下观众邀请的徐州站工作。徐州,作为华东重要门户城市,华东地区重要的科教…