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

创建临时表:

当你创建临时表的时候,你可以使用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 ...等四种情况,还需要加上一种情况:它本身就是末级节点,与末级节点直接关联即可。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值