您的位置:首页 > 数据库 > MySQL

MySql创建临时表和特殊关联语句

2015-09-24 11:18 537 查看
创建临时表:

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

create temporary table tmp_table(name varchar(10) not null,passwd char(6) not null);



create temporary table if not exists sp_output_tmp engine= memory select …from … where ID=current_id;

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

create temporary table 权限。

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

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

2、临时表不支持mysql cluster(簇)

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

mysql> SELECT * FROM
temp_table, temp_table AS t2;

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

mysql bug地址:http://bugs.mysql.com/bug.php?id=10327

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

4、show tables 语句不会列举临时表

你不能用rename来重命名一个临时表。但是,你可以alter table代替:

mysql>ALTER TABLE orig_name
RENAME new_name;

临时表用完后要记得drop掉:

DROP TEMPORARY TABLE
IF EXISTS sp_output_tmp;

地区表的问题

一些树形结构的表,为了从最末级别,找到最高级别,特意给表中加了一个字段,专门记录路径,方便人能从最末级别找到最高级别。

表中加一个字段:path,专门靠程序维护这个字段,新增时,要同时收集从最高级到本级的分类路径,例如:目前有三个级次,一级、二级、三级,在添加三级分类时,需要将path字段值计算出来,这时这样存,”一级|二级“,将来如果需要与级次表做关联,例如需求是这样的:有张表,记录多个一级目录,他想查出来,一级目录下的所有子级别。

怎么办?用关联查询的方法,这两个表需要这样做关联: select * from a join b on a.class like '""+一级ID+|%' or a.class like '%!"+一级ID+"' or ...等四种情况,还需要加上一种情况:它本身就是末级节点,与末级节点直接关联即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: