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 ...等四种情况,还需要加上一种情况:它本身就是末级节点,与末级节点直接关联即可。
当你创建临时表的时候,你可以使用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 ...等四种情况,还需要加上一种情况:它本身就是末级节点,与末级节点直接关联即可。
相关文章推荐
- Mac下MySql卸载方法
- innobackupex命令对mysql数据库进行完全和增量备份
- MySQL命令大全
- 关于mysql的一些命令和错误
- MYSQL查询优化(二)
- MYSQL查询优化(一)
- 高效查看MySQL帮助文档的方法
- mysql 主从配置
- mysql user administration
- mysql正则表达式
- SSD 下的 MySQL IO 优化
- Mysql命令alter add:增加表的字段
- Mysql查看进程
- mysql常见错误
- mysql表分区例子
- mysql中root用户的密码修改和消除
- 安装、设置与启动MySql绿色版的方法
- mysql数据库表分区详解(数量过大的数据库表通过分区提高查询速度)
- 绿色版Mysql的安装配置
- MySQL++学习日志(一)