MySQL中关于临时表的一些基本使用方法

作者:goldensun 时间:2024-01-18 01:22:34 

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

临时表中添加MySQL版本3.23。如果您使用的是旧版本的MySQL比3.23,可以不使用临时表,但可以使用堆表。

如前所述临时表将只持续只要的会话是存在的。如果运行一个PHP脚本中的代码,该临时表将被销毁时,会自动执行完脚本后。如果已连接到MySQL数据库的服务器上,通过MySQL的客户端程序的临时表将一直存在,直到关闭客户端或手动破坏的表。
实例

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


mysql> CREATE TEMPORARY TABLE SalesSummary (
 -> product_name VARCHAR(50) NOT NULL
 -> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
 -> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
 -> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO SalesSummary
 -> (product_name, total_sales, avg_unit_price, total_units_sold)
 -> VALUES
 -> ('cucumber', 100.25, 90, 2);

mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber   |   100.25 |     90.00 |        2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)

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

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

下面的例子为删除一个临时表。


mysql> CREATE TEMPORARY TABLE SalesSummary (
 -> product_name VARCHAR(50) NOT NULL
 -> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
 -> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
 -> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO SalesSummary
 -> (product_name, total_sales, avg_unit_price, total_units_sold)
 -> VALUES
 -> ('cucumber', 100.25, 90, 2);

mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber   |   100.25 |     90.00 |        2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)
mysql> DROP TABLE SalesSummary;
mysql> SELECT * FROM SalesSummary;
ERROR 1146: Table 'TUTORIALS.SalesSummary' doesn't exist

标签:MySQL,临时表
0
投稿

猜你喜欢

  • python 对象和json互相转换方法

    2022-06-27 18:40:14
  • Vuex简单入门

    2024-05-02 16:58:26
  • 什么是好的设计

    2010-02-25 12:22:00
  • Python中操作mysql的pymysql模块详解

    2024-01-14 08:14:32
  • vue中的input框点击后不聚焦问题

    2024-05-02 16:33:12
  • Python实现国外赌场热门游戏Craps(双骰子)

    2023-12-13 23:22:21
  • 详解numpy.ndarray.reshape()函数的参数问题

    2022-02-06 20:22:57
  • HTML5 的五个激动人心的特性

    2009-01-02 17:36:00
  • asp获取数据库中表名和字段名的代码

    2011-04-18 11:02:00
  • linux下导入、导出mysql数据库命令的实现方法

    2024-01-23 15:55:33
  • 使用Perl DBI操作MySQL的一些建议

    2024-01-16 11:20:55
  • python利用tkinter实现屏保

    2022-01-26 05:39:51
  • MS SQL2000 数据库自动备份方法

    2010-07-22 19:52:00
  • MySQL绿色解压缩版安装与配置操作步骤

    2024-01-14 07:00:15
  • 使用VS2005调试ASP程序方法

    2007-11-02 09:56:00
  • 基于Python实现船舶的MMSI的获取(推荐)

    2022-02-05 07:44:33
  • javascript unicode与GBK2312(中文)编码转换方法

    2024-04-17 10:09:36
  • Python 类属性与实例属性,类对象与实例对象用法分析

    2023-03-12 01:43:03
  • 代码详解Python的函数基础(1)

    2023-08-16 17:47:22
  • PHP和JavaScrip分别获取关联数组的键值示例代码

    2023-06-16 05:30:51
  • asp之家 网络编程 m.aspxhome.com