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

临时表中添加MySQL版本3.23。如果您使用的是旧版本的MySQL比3.23,可以不使用临时表,但可以使用堆表。如前所述临时表将只持续只要的会话是存在的。如果运行一个PHP脚本中的代码,该临时表将被销毁时,会自动执行完脚本后。如果已连接到MySQL数据库的服务器上,通过MySQL的客户端程序的临时表将一直...
MySQL中关于临时表的一些基本使用方法
临时表可能是非常有用的,在某些情况下,保持临时数据。最重要的是应该知道的临时表是,他们将当前的客户端会话终止时被删除。
临时表中添加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
exist2020-04-30
mengvlog 阅读 535 次 更新于 2025-10-30 15:40:47 我来答关注问题0
  • 临时表中添加MySQL版本3.23。如果您使用的是旧版本的MySQL比3.23,可以不使用临时表,但可以使用堆表。如前所述临时表将只持续只要的会话是存在的。如果运行一个PHP脚本中的代码,该临时表将被销毁时,会自动执行完脚本后。如果已连接到MySQL数据库的服务器上,通过MySQL的客户端程序的临时表将一直存...

  •  深空见闻 mysql临时表的限制

    用户需要拥有CREATE TEMPORARY TABLES权限才能创建临时表。同时,用户还需要具备对临时表进行SELECT、INSERT、UPDATE、DELETE等操作的相应权限。存储位置和大小限制:临时表可以存储在内存中(使用MEMORY引擎)或磁盘上(使用MyISAM或InnoDB引擎)。如果临时表存储在内存中,其大小受到max_heap_table_size和tmp_ta...

  •  hemu780924 关于mysql建立临时表的问题(新手入门)

    1)定义字段 CREATE TEMPORARY TABLE tmp_table (name VARCHAR(10) NOT NULL,value INTEGER NOT NULL )2)直接将查询结果导入临时表 CREATE TEMPORARY TABLE tmp_table SELECT * FROM table_name 2、另外mysql也允许你在内存中直接创建临时表,因为是在内存中所有速度会很快,语法如下:CREATE TEMPORARY T...

  • 在MySQL中,tmp表默认使用内存中的存储引擎(MEMORY),这样可以提高查询效率。但是,如果存储数据量较大,建议使用别的存储引擎,如MyISAM、InnoDB等。可以根据表的大小和查询需求来选择存储引擎,以充分发挥MySQL的性能优势。3. tmp表的使用范围 在使用tmp表时,需要注意使用范围。tmp表是临时性的,只有...

  • 如果你声明临时表是一个HEAP表,MySQL也允许你指定在内存中创建它:CREATE TEMPORARY TABLE tmp_table (name VARCHAR(10) NOT NULL,value INTEGER NOT NULL ) TYPE = HEAP 因为HEAP表存储在内存中,你对它运行的查询可能比磁盘上的临时表快些。然而,HEAP表与一般的表有些不同,且有自身的限制。详见...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部