mysql建立临时表

在生成报表的时候, 由于使用的查询条件中, 用的 in 函数比较多, 而且关联了好几个表, 所以查询的速度超慢, 甚至会死掉整个数据库. 我以为用 or 可以会快点, 不过, 还是一样, 因为我使用了 in 用在两个字符串上了, 没办法, 想了很久, 常试了很多, 还是不行... 终于, 想到用临时表了, 这一样来, 我不用改变原来条件中读出的数据, 我只需要把原来读出来的数据放在临时表里, 再在显临时表里加上那两个使用in的条件就可以了, 速度快了很多... 哈~很开心, 现在把这个知识记下...

1、临时表再断开于mysql的连接后系统会自动删除临时表中的数据,但是这只限于用下面语句建立的表:
A. 定义字段(注意:不同于mssql,在表名前加上#或@, 这里是加上 temporary.)

 create temporary table tmp_table ( 

      idno int not null,
      name varchar(10) not null
  )


B. 可以直接将查询结果导入临时表 (我觉得这种方法很有用, 特别对多表关联, 可以直接把查询出来的放在临时表,再读取)

create temporary table tmp_table select * from table_name 

2、另外mysql也允许你在内存中直接创建临时表,因为是在内存中所有速度会很快,语法如下:
create temporary table tmp_table ( 

     idno int not null,
     name varchar(10) not null

  ) TYPE = HEAP 



注意: 只有断开数据库连接才会被清空数据,在一个数据库连接里面发行多次sql的话系统是不会自动清空临时表数据的。


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值