Foxtable(狐表)用户栏目专家坐堂 → [求助]临时表在SQL中怎么用


  共有5331人关注过本帖树形打印复制链接

主题:[求助]临时表在SQL中怎么用

帅哥哟,离线,有人找我吗?
chnfo
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
[求助]临时表在SQL中怎么用  发帖心情 Post By:2020/1/11 12:22:00 [只看该作者]

项目中有两个表,表A和表B,都使用外部数据源,表B中有一表达式列Temp(逻辑型)
 
如果我想生成一个临时表dt,并且将它在另外的SQL中引用(例如用exist),因为如果用 in的话,一是效率比较低,二是in的数据量超过1000,就得分批执行,可能效率更低


此主题相关图片如下:无标题.png
按此在新窗口浏览图片

 
[此贴子已经被作者于2020/1/11 12:28:58编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
chnfo
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
  发帖心情 Post By:2020/1/11 12:30:00 [只看该作者]

上传整段代码时总是报错,不让上传,只能截图了


 回到顶部
帅哥哟,离线,有人找我吗?
chnfo
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
  发帖心情 Post By:2020/1/11 13:15:00 [只看该作者]

能不能这么用呢


图片点击可在新窗口打开查看此主题相关图片如下:无标题.png
图片点击可在新窗口打开查看


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/1/11 14:12:00 [只看该作者]

临时表,和表达式里都无法在sql里使用,sql只能使用数据库存在的表和列

 回到顶部
帅哥哟,离线,有人找我吗?
chnfo
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
  发帖心情 Post By:2020/1/11 17:25:00 [只看该作者]

有没有变通的办法?
一是用SQL执行的效率更高一些
二是如果选中的行数比较多的话,再去用in效率反而更低

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/1/11 17:33:00 [只看该作者]

应该这样用

select * from (生成临时表的sql) as a where xxxx

 回到顶部
帅哥哟,离线,有人找我吗?
chnfo
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
  发帖心情 Post By:2020/1/11 17:35:00 [只看该作者]

问题是生成临时表要用到临时列啊。

selec  t * f  rom 表B wh  ere Temp = 1

这里的Temp就是临时列,这似乎不行吧

这就成了个死循环了。
[此贴子已经被作者于2020/1/11 17:39:31编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/1/11 17:38:00 [只看该作者]

这个没有办法,sql只能使用数据库存在的表和列,除非您自己开发一个数据库,没有任何数据库可以支持。

 回到顶部
帅哥哟,离线,有人找我吗?
chnfo
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
  发帖心情 Post By:2020/1/11 17:41:00 [只看该作者]

是否可以建一个内部表,然后把它与SQL结合使用?

把查询语句形成的数据filler到内部表中去

好象也不行
[此贴子已经被作者于2020/1/11 17:43:21编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
chnfo
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2247 积分:18514 威望:0 精华:0 注册:2011/11/26 20:21:00
  发帖心情 Post By:2020/1/11 18:48:00 [只看该作者]

蓝版,我还是不太死心,应当有办法解决这个问题的,要不然只有牺牲效率了。前提是使用外部数据表

原本的意图举例(只是举例,类比真实的应用场景):例如在界面上选择了一些出货单,针对这些出货单去设置折扣比例(没有选中的单子不折扣)。

当然,用遍历然后去更新也可以实现。
只是真实的应用场景的数据量比较大,考虑到用SQL执行效率会高一些。



 回到顶部
总数 14 1 2 下一页