mysql临时表更新_MySql 临时表

mysql临时表更新_MySql 临时表今天在项目中遇到一个 当 mysql 的 in 语句中数据量很大时 建立一个临时表的例子 于是楼主整理了一下关于临时表的知识 与大家分享一下 首先 临时表只在当前连接可见 当关闭连接时 Mysql 会自动删除表并释放所有空间 因此在不同的连接中可以创建同名的临时表 并且操作属于本连接的临时表 建立临时表 CREATETEMPOR table idVARCHAR 32 N

今天在项目中遇到一个,当mysql的in语句中数据量很大时,建立一个临时表的例子。于是楼主整理了一下关于临时表的知识,与大家分享一下~

首先,临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。因此在不同的连接中可以创建同名的临时表,并且操作属于本连接的临时表。

建立临时表:

CREATE TEMPORARY  TABLE temp_table (

id VARCHAR(32) NOT NULL,

NAME VARCHAR(100)

) ENGINE = MEMORY

注意最后面的ENGINE = MEMORY,其中ENGINE是数据库搜索引擎,常用的几种类型为MyISAM, MEMORY, InnoDB

1)MyISAM 管理非事物表。提供高速存储和检索,以及全文搜索能力

2)MEMORY存储引擎提供“内存中”表。就像MyISAM一样,MEMORY和MERGE存储引擎处理非事务表

注释:MEMORY存储引擎正式地被确定为HEAP引擎。

3)InnoDB和存储引擎提供事务安全表。这是默认的数据库表存储引擎

当然还有一种简单粗暴的方式建立临时表,直接将查询结果导入到临时表:

CREATE TEMPORARY  TABLE temp_table

ENGINE = MEMORY

SELECT * FROM `bm_sc_settlement`

创建临时表后,我们插入数据

INSERT INTO temp_table VALUES(‘1’, ‘a’);

INSERT INTO temp_table VALUES(‘2’, ‘b’);

INSERT INTO temp_table VALUES(‘3’, ‘c’);

INSERT INTO temp_table VALUES(‘4’, ‘d’);

INSERT INTO temp_table VALUES(‘5’, ‘e’);

查询:

SELECT * FROM temp_table;

bf6282d91aeebaf5677c06f43142e42c.png

可以看到我们插入的结果已经放到临时表中(也可以做更新及删除操作)

此时当我们关掉mysql客户端(楼主用的SQLyog),然后重新打开。执行查询临时表操作,会提示找不到该临时表

删除临时表:

DROP TEMPORARY TABLE IF EXISTS temp_table;

临时表使用有一些限制条件:

1)在同一个query语句中,相同的临时表只能出现一次。如:

SELECT * FROM temp_table a ,temp_table b;

错误信息:ERROR 1137 (HY000): Can’t reopen table: ‘temp_table’

同样相同临时表不能在存储函数中出现多次,如果在一个存储函数里,用不同的别名查找一个临时表多次,或者在这个存储函数里用不同的语句查找,都会出现这个错误。

2) 不同的临时表可以出现在同一个query语句中,如临时表temp_tb1, temp_tb2:

select * from temp_tb1, temp_tb2;

3)可以复制临时表得到一个新的临时表,如:

create temporary table new_table select * from old_table;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/232515.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java集合List用法总结

    Java集合List用法总结转自:https://www.jianshu.com/p/25aa92f8d681Java集合作为一个Developer,Java集合类是我们在工作中运用最多的、最频繁的类。相比于数组(Array)来说,集合类的长度可变,更加适合于现代开发需求;Java集合就像一个容器,可以存储任何类型的数据,也可以结合泛型来存储具体的类型对象。在程序运行时,Java集合可以动态的进行扩展,随着元素的增加而扩大。在Java中,集合类通常存在于java.util包中。Java集合主要由2大体系构成,分别是Co

    2022年7月7日
    34
  • qq不能接收图片如何解决_qq文件未上传至服务器

    qq不能接收图片如何解决_qq文件未上传至服务器原因一:一般是网速比较慢,电信联通教育他们内部传图片大家都能收到,教育网给联通发就一般收不到了,清理下你的QQ图片文件夹,里面堆积的图片太多了原因二:由于网络问题,查看手机移动数据流量或者wifi连接是否正常。QQ版本问题,将QQ版本升级到最新版本重新尝试发送图片。查看对方是否删除了自己以及屏蔽了消息,这样是无法正常发送图片如果你不能确定是否是因为QQ图片文件夹的关系导致自己不能发送图片,那么小…

    2022年8月10日
    8
  • navicat永久激活码最新2021【在线注册码/序列号/破解码】

    navicat永久激活码最新2021【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月19日
    151
  • css增加横着滚动条_CSS 设置滚动条样式的实现「建议收藏」

    webkit滚动条样式重置1、scrollbar包含scrollbarbuttons和一个track。track进一步细分为trackpieces和thumb。tracepieces为thumb的上半部分和半下部分。2、scrollbarcorner为横向和竖向的交叉角区域3、resize用来设置滚动条的交汇处上用于拖动调整元素大小的小控件组成结构图如下:一旦发现滚动条的自定义样式,浏览器…

    2022年4月8日
    702
  • 【Python 基础篇】Python代码 之 三目表达式总结

    【Python 基础篇】Python代码 之 三目表达式总结Python 中的三元表达式 result 为真时的结果 if 判断条件 else 为假时的结果 示例 gt gt gt x 1 gt gt gt y 2 gt gt gt result xifx gt yelsey 如果条件成立 将 x 的值赋给 result gt gt gt result2 上面的三元表达式等价于 gt gt gt x 1 gt gt gt y 2 gt gt gt ifx

    2025年6月19日
    4
  • window mysql慢日志_windows下如何启用mysql慢查询日志

    window mysql慢日志_windows下如何启用mysql慢查询日志今天在测试4000000条记录的mysql慢查询,数据库安装在windows上,百度了很多,都没有个测试可行的的解决方案或者经验之谈,可能是因为mysql版本不一样吧!这里做个记录以备忘记时候可以查看,也让其他朋友借鉴一下。这里用的mysql版本是5.6.17首先,修改mysql中的my.ini文件,关键代码如下:datadir=”D:/MySQL5.6/MySQLServer5.6/data…

    2022年8月31日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号