北京SEO

mysql创建与删除临时表sql语句

2019/10/10/17:36:15  阅读:2307  来源:谷歌SEO算法  标签: SEO工具

在mysql应用开发中临时表是我们一个很重要的数据处理优化东西,我们经常会处理各种大数据或其它问题利用TEMPORARY临时表来处理,下面我来介绍临时表创建与删除方法.

临时表可能是非常有用的,在某些情况下,保持临时数据,最重要的是应该知道的临时表是,他们将当前的客户端会话终止时被删除.

当你创建临时表的时候,你可以使用temporary关键字,代码如下:

  1. createtemporarytabletmp_table(namevarchar(10)notnull,passwdchar(6)notnull)‘
  2. //或
  3. CREATETEMPORARYTABLEIFNOTEXISTSsp_output_tmpENGINE=MEMORYSELECTfromwhereID=current_id;

临时表只在当前连接可见,当这个连接关闭的时候,会自动drop,这就意味着你可以在两个不同的连接里使用相同的临时表名,并且相互不会冲突,或者使用 已经存在的表,但不是临时表的表名,当这个临时表存在的时候,存在的表被隐藏了,如果临时表被drop,存在的表就可见了,创建临时表你必须有create temporary table 权限.

下面几点是临时表的限制:

临时表只能用在 memory,myisam,merge,或者innodb

临时表不支持mysql cluster(簇)

在同一个query语句中,你只能查找一次临时表,例如,下面的就不可用,代码如下:

mysql> SELECT * FROM temp_table, temp_table AS t2;

ERROR 1137: Can't reopen table: 'temp_table'

如果在一个存储函数里,你用不同的别名查找一个临时表多次,或者在这个存储函数里用不同的语句查找,这个错误都会发生.

show tables 语句不会列举临时表,你不能用rename来重命名一个临时表,但是,你可以alter table代替,代码如下:

mysql>ALTER TABLE orig_name RENAME new_name;

临时表用完后要记得drop掉,代码如下:

DROP TEMPORARY TABLE IF EXISTS sp_output_tmp;

创建临时表,实例,下面是一个例子,使用临时表在PHP脚本中,使用mysql_query()函数,可以使用相同的代码,代码如下:

  1. mysql>CREATETEMPORARYTABLESalesSummary(
  2. ->product_nameVARCHAR(50)NOTNULL
  3. ->,total_salesDECIMAL(12,2)NOTNULLDEFAULT0.00
  4. ->,avg_unit_priceDECIMAL(7,2)NOTNULLDEFAULT0.00
  5. ->,total_units_soldINTUNSIGNEDNOTNULLDEFAULT0
  6. );
  7. QueryOK,0rowsaffected(0.00sec)
  8. mysql>INSERTINTOSalesSummary
  9. ->(product_name,total_sales,avg_unit_price,total_units_sold)
  10. ->VALUES
  11. ->('cucumber',100.25,90,2);
  12. mysql>SELECT*FROMSalesSummary;
  13. +--------------+-------------+----------------+------------------+
  14. |product_name|total_sales|avg_unit_price|total_units_sold|
  15. +--------------+-------------+----------------+------------------+
  16. |cucumber|100.25|90.00|2|
  17. +--------------+-------------+----------------+------------------+
  18. 1rowinset(0.00sec)

当发出一个SHOW TABLES命令,那么临时表将不会被列在列表中,现在如果将MySQL的会话的注销,那么会发出SELECT命令,那么会发现没有在数据库中的数据,即使临时表也就不存在了.

删除临时表:默认情况下,所有的临时表被删除时,MySQL的数据库连接被终止,不过要删除他们之前就应该发出DROP TABLE命令.

下面的例子为删除一个临时表,代码如下:

  1. mysql>CREATETEMPORARYTABLESalesSummary(
  2. ->product_nameVARCHAR(50)NOTNULL
  3. ->,total_salesDECIMAL(12,2)NOTNULLDEFAULT0.00
  4. ->,avg_unit_priceDECIMAL(7,2)NOTNULLDEFAULT0.00
  5. ->,total_units_soldINTUNSIGNEDNOTNULLDEFAULT0
  6. );
  7. QueryOK,0rowsaffected(0.00sec)
  8. mysql>INSERTINTOSalesSummary
  9. ->(product_name,total_sales,avg_unit_price,total_units_sold)
  10. ->VALUES
  11. ->('cucumber',100.25,90,2);
  12. mysql>SELECT*FROMSalesSummary;
  13. +--------------+-------------+----------------+------------------+
  14. |product_name|total_sales|avg_unit_price|total_units_sold|
  15. +--------------+-------------+----------------+------------------+
  16. |cucumber|100.25|90.00|2|
  17. +--------------+-------------+----------------+------------------+
  18. 1rowinset(0.00sec)//phpfensi.com
  19. mysql>DROPTABLESalesSummary;
  20. mysql>SELECT*FROMSalesSummary;
  21. ERROR1146:Table'TUTORIALS.SalesSummary'doesn'texist

广告内容

mysql创建与删除临时表sql语句 mysql创建与删除临时表sql语句 mysql创建与删除临时表sql语句

相关阅读

热门评论

木木老贼 木木老贼

互联网营销达人~

总篇数181

精选文章

RMAN中catalog和nocatalog区别介绍 小技巧:为Linux下的文件分配多个权限 zimbra8.5.1安装第三方签名ssl证书的步骤 解决mysql不能远程连接数据库方法 windows服务器mysql增量备份批处理数据库 mysql中slow query log慢日志查询分析 JavaScript跨域问题总结 Linux下负载均衡软件LVS配置(VS/DR)教程 mysql中权限参数说明 MYSQL(错误1053)无法正常启动

SEO最新算法