一、MySQL 临时表

临时表是会话级别的临时数据载体,其设计初衷是为了满足短期数据处理需求,以下从技术细节展开说明。

(一)核心特性拓展

       1.生命周期与会话绑定

  • 会话结束的判定:包括正常断开连接(exit/quit)、连接超时(由wait_timeout参数控制)、客户端进程崩溃等。
  • 特殊场景:若使用连接池,会话可能被复用,临时表会持续存在至连接真正释放,需手动删除避免残留
    2.会话隔离性
  • 可见性边界:仅当前会话的线程可访问,即使是同一用户的其他连接也无法查看。例如,用户 A 通过 Navicat 创建临时表tmp_log,同时通过 MySQL 命令行连接同一数据库,无法查询到tmp_log。
  • 命名冲突处理:当临时表与普通表同名时,会话内的所有操作(SELECT/INSERT等)默认指向临时表,若需访问普通表需指定数据库名(如SELECT * FROM db1.normal_table)。
    3.存储机制详解
  • 内存存储触发条件:当临时表数据量未超过tmp_table_size(默认 16MB)且max_heap_table_size(默认 16MB)时,使用内存存储(基于MEMORY引擎)。
  • 磁盘存储转换:当数据量超过阈值或包含TEXT/BLOB字段时,自动转为磁盘存储(基于InnoDB或MyISAM引擎,由default_tmp_storage_engine参数控制),存储路径可通过tmpdir参数查看(默认/tmp)。

(二)操作全流程案例

1. 复杂查询中的临时表应用
-- 场景:统计近30天各地区用户消费总额,需多表关联计算中间结果CREATE TEMPORARY TABLE tmp_user_orders (user_id INT,region VARCHAR(50),total_amount DECIMAL(10,2));-- 插入关联数据INSERT INTO tmp_user_ordersSELECTu.id,u.region,SUM(o.amount)FROM users uJOIN orders o ON u.id = o.user_idWHERE o.create_time >= DATE_SUB(CURDATE(), INTERVAL 30 DAY)GROUP BY u.id, u.region;-- 基于临时表做二次统计SELECT region, SUM(total_amount) AS region_totalFROM tmp_user_ordersGROUP BY region;-- 手动清理DROP TEMPORARY TABLE tmp_user_orders;
2. 临时表的结构修改

临时表支持有限的ALTER操作(如添加字段),但不支持重命名或修改引擎:

ALTER TEMPORARY TABLE tmp_student ADD COLUMN gender ENUM('M','F');

(三)引擎差异与限制

  • MEMORY引擎临时表:不支持TEXT/BLOB字段,数据易失(数据库重启后消失,但不影响会话内使用)。
  • InnoDB临时表:支持事务和行级锁,适合并发场景,但性能略低于内存表。
  • 共同限制:不支持外键、分区表、全文索引,无法被RENAME语句重命名。

二、MySQL 复制表

复制表是基于源表创建的独立表,常用于数据备份、环境克隆等场景,其细节处理直接影响使用效果。

(一)创建方法对比与底层差异

方法

语法示例

结构复制范围

数据复制

适用场景

SELECT法

CREATE TABLE c1 SELECT * FROM s1;

仅字段和数据类型,无索引 / 约束

全量数据

快速复制简单表数据

LIKE法

CREATE TABLE c2 LIKE s1;

完整结构(字段、类型、索引、约束、引擎)

无数据

精确克隆表结构

组合法

CREATE TABLE c3 LIKE s1; INSERT INTO c3 SELECT * FROM s1;

完整结构

全量数据

需要保留约束的数据复制

约束复制细节:
  • SELECT法:仅复制NOT NULL约束,丢失主键、自增(AUTO_INCREMENT)、外键等。
  • LIKE法:完整复制所有约束,包括AUTO_INCREMENT的当前值(如源表自增列最大为 100,复制表插入时从 101 开始)。

(二)高级复制场景

1. 复制部分字段与计算列
-- 复制源表的id、name字段,并添加计算列age_groupCREATE TABLE user_simpleSELECTid,name,CASE WHEN age < 18 THEN 'minor' ELSE 'adult' END AS age_groupFROM users;
2. 跨数据库复制表
-- 从db1复制表到db2(需有目标库权限)CREATE TABLE db2.copy_table LIKE db1.source_table;INSERT INTO db2.copy_table SELECT * FROM db1.source_table;
3. 复制表时过滤重复数据
-- 复制去重后的数据CREATE TABLE unique_usersSELECT DISTINCT * FROM users WHERE phone IS NOT NULL;

(三)索引与性能考量

  • 复制表的索引继承:LIKE法会复制源表的所有索引(主键、二级索引等),SELECT法仅复制隐式索引(如NOT NULL字段的索引)。
  • 大数据量复制优化:
-- 关闭索引更新提升插入速度ALTER TABLE copy_table DISABLE KEYS;INSERT INTO copy_table SELECT * FROM source_table;ALTER TABLE copy_table ENABLE KEYS;

三、临时表与复制表的深度对比

对比项

临时表

复制表

存储位置

内存(小数据)/tmpdir(大数据)

数据库数据目录(与普通表一致)

事务影响

支持事务(InnoDB引擎),回滚时数据清空但表结构保留

完全遵循事务规则(同普通表)

权限要求

仅需CREATE TEMPORARY TABLES权限

需源表SELECT权限和目标库CREATE权限

备份影响

不会被mysqldump备份

会被正常备份(属于普通表)

性能开销

创建 / 删除快,适合高频短期使用

创建时需复制数据 / 索引,开销与数据量正相关

四、常见问题

(一)临时表常见问题

  1. 连接池中的残留问题:在 Spring Boot 等框架中,连接池复用会导致临时表未及时删除,建议在代码中显式执行DROP TEMPORARY TABLE IF EXISTS。
  2. 内存溢出风险:大量创建内存临时表可能触发OOM,可通过SHOW GLOBAL STATUS LIKE 'Created_tmp_tables'监控创建量,超过阈值时调大tmp_table_size。

(二)复制表常见问题

  1. 外键依赖失效:复制表不会复制外键关联的父表,需手动创建父表或禁用外键检查(SET foreign_key_checks = 0)。
  2. 自增列冲突:若复制表用于数据迁移,需重置自增起始值(ALTER TABLE copy_table AUTO_INCREMENT = 1001)。

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

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

相关文章

从配置到调试:WinCC与S7-1200/200SMT无线Modbus TCP通讯方案

测试设备与参数l 西门子PLC型号&#xff1a;S7-1200 1台l 西门子PLC型号&#xff1a;S7-200Smart 1台l 上位机&#xff1a;WinCC7.4 1台l 无线通讯终端——DTD418MB 3块l 主从关系&#xff1a;1主2从l 通讯接口&#xff1a;RJ45接口l 供电&#xff1a;12-24VDCl 通讯协议&a…

Android沉浸式全屏显示与隐藏导航栏的实现

1. 总体流程以下是实现沉浸式全屏显示和隐藏导航栏的流程&#xff1a;步骤描述步骤1创建一个新的Android项目步骤2在布局文件中定义需要展示的界面步骤3在Activity中设置沉浸式全屏显示步骤4处理系统UI的显示与隐藏步骤5运行应用并测试效果2. 详细步骤步骤1&#xff1a;创建一个…

EN 62368消费电子、信息技术设备和办公设备安全要求标准

EN 62368认证标准是一项全球性的电子产品安全标准&#xff0c;用于评估和认证消费电子、信息技术设备和办公设备的安全性。该标准由国际电工委员会(IEC)制定&#xff0c;取代了传统的EN60065和EN 60950两个标准&#xff0c;成为国际电子产品安全领域的新指导。IEC /EN 62368-1是…

【unity实战】使用Splines+DOTween制作弯曲手牌和抽牌动画效果

最终效果 文章目录最终效果前言实战1、Splines的使用2、绘制样条线3、DOTween安装和使用4、基于样条曲线&#xff08;Spline&#xff09;的手牌管理系统4.1 代码实现4.2 解释&#xff1a;&#xff08;1&#xff09;计算第一张卡牌的位置&#xff08;居中排列&#xff09;&#…

Flask模板注入梳理

从模板开始介绍&#xff1a;Flask中有许多不同功能的模板&#xff0c;他们之间是相互隔离的地带&#xff0c;可供引入和使用。Flask中的模块&#xff1a;flask 主模块&#xff1a;包含框架的核心类和函数&#xff0c;如 Flask&#xff08;应用实例&#xff09;、request&#x…

企业级的即时通讯平台怎么保护敏感行业通讯安全?

聊天记录存在第三方服务器、敏感文件被误发至外部群组、离职员工仍能查看历史消息.对于金融、医疗、政务等对数据安全高度敏感的行业而言&#xff0c;“沟通效率与”信息安全”的矛盾&#xff0c;从未像今天这样尖锐。企业即时通讯怎么保护敏感行业通讯安全&#xff1f;这个问题…

Java Spring框架最新版本及发展史详解(截至2025年8月)-优雅草卓伊凡

Java Spring框架最新版本及发展史详解&#xff08;截至2025年8月&#xff09;-优雅草卓伊凡引言今天有个新项目 客户问我为什么不用spring 4版本&#xff0c;卓伊凡我今天刚做完项目方案&#xff0c;我被客户这一句问了有点愣住&#xff0c;Java Spring框架最新版本及发展史详解…

Android实现Glide/Coil样式图/视频加载框架,Kotlin

Android实现Glide/Coil样式图/视频加载框架&#xff0c;Kotlin <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name"android.permission.READ_EXTERNAL_STORAGE" /><uses-permiss…

【k8s】pvc 配置的两种方式volumeClaimTemplates 和 PersistentVolumeClaim

pvc配置实例 实例1在Deployment中配置 template:xxxxxxvolumeClaimTemplates:- metadata:name: dataspec:accessModes:- ReadWriteOnceresources:requests:storage: 1GistorageClassName: nfsdev-storageclass (创建好的storageClassName)实例2#先创建一个pvc 然后在 Deploym…

Logistic Loss Function|逻辑回归代价函数

----------------------------------------------------------------------------------------------- 这是我在我的网站中截取的文章&#xff0c;有更多的文章欢迎来访问我自己的博客网站rn.berlinlian.cn&#xff0c;这里还有很多有关计算机的知识&#xff0c;欢迎进行留言或…

计算机网络技术-知识篇(Day.1)

一、网络概述 1、网络的概念 两个不在同一地理位置的主机&#xff0c;通过传输介质和通信协议&#xff0c;实现通信和资源共享。 2、网络发展史 第一阶段&#xff08;20世纪60年代&#xff09; 标志性事件&#xff1a;ARPANET的诞生关键技术&#xff1a;分组交换技术 第二…

工业元宇宙:迈向星辰大海的“玄奘之路”

一、从认知革命到工业革命&#xff1a;文明跃迁的底层逻辑1.1 认知革命&#xff1a;人类协作的基石时间线&#xff1a;约7万年前&#xff0c;智人通过语言和想象力构建共同虚拟现实&#xff0c;形成部落协作模式。核心突破&#xff1a;虚构能力&#xff1a;创造神、国家、法律等…

9. React组件生命周期

2. React组件生命周期 2.1. 认识生命周期 2.1.1. 很多事物都有从创建到销毁的整个过程&#xff0c;这个过程称之为生命周期&#xff1b;2.1.2. React组件也有自己的生命周期&#xff0c;了解生命周期可以让我们在最合适的地方完成想要的功能2.1.3. 生命周期和生命周期函数的关系…

【单板硬件开发】关于复位电路的理解

阅读紫光同创供应商提供的FPGA单板硬件开发手册&#xff0c;发现复位电路他们家解释的很通俗易懂&#xff0c;所以分享一下。如下图&#xff0c;RST_N 是低有效的异步全芯片复位信号&#xff0c;一般外部连接电路有 3 种形式如图 3–2&#xff0c;可根据实际需要选择合适的电路…

《Unity Shader入门精要》学习笔记一

1、本书的源代码 https://github.com/candycat1992/Unity_Shaders_Book 2、第1章 Shader是面向GPU的工作方式 3、第2章 渲染流水线 Shader&#xff1a;着色器 渲染流水线&#xff1a;目标是渲染一张二维纹理&#xff0c;输入是一个虚拟摄像机、一些光源、一些Shader以及纹…

从零到一:TCP 回声服务器与客户端的完整实现与原理详解

目录 一、TCP 通信的核心逻辑 二、TCP 服务器编程步骤 步骤 1&#xff1a;创建监听 Socket 步骤 2&#xff1a;绑定地址与端口&#xff08;bind&#xff09; 步骤 3&#xff1a;设置监听状态&#xff08;listen&#xff09; 步骤 4&#xff1a;接收客户端连接&#xff08…

MyBatis-Plus核心内容

MyBatis-Plus MyBatis-Plus 是一个基于 MyBatis的增强工具&#xff0c;旨在简化开发过程&#xff0c;减少重复代码。它在MyBatis的基础上增加了CRUD操作封装&#xff0c;条件构造器、代码生成器等功能。 一、核心特性与优势 1. 核心特性 无侵入&#xff1a;只做增强不做改变&am…

计算机网络摘星题库800题笔记 第4章 网络层

第4章 网络层4.1 网络层概述题组闯关1.在 Windows 的网络配置中&#xff0c;“默认网关” 一般被设置为 ( ) 的地址。 A. DNS 服务器 B. Web 服务器 C. 路由器 D. 交换机1.【参考答案】C 【解析】只有在计算机上正确安装网卡驱动程序和网络协议&#xff0c;并正确设置 IP 地址信…

非root用户在linux中配置zsh(已解决ncurses-devel报错)

Zsh&#xff08;Z Shell&#xff09;是一款功能强大的交互式 Unix shell&#xff0c;以其高度可定制性和丰富的功能著称&#xff0c;被视为 Bash 的增强替代品。它支持智能补全、主题美化、插件扩展&#xff08;如 Oh My Zsh 框架&#xff09;、自动纠错、全局别名等特性&#…

《Foundations and Recent Trends in Multimodal Mobile Agents: A Survey》论文精读笔记

论文链接&#xff1a;https://arxiv.org/pdf/2411.02006 摘要 文章首先介绍了核心组件&#xff0c;并探讨了移动基准和交互环境中的关键代表性作品&#xff0c;旨在全面理解研究重点及其局限性。 接着&#xff0c;将这些进展分为两种主要方法&#xff1a; 基于提示的方法&a…