码迷,mamicode.com
首页 > 其他好文 > 详细

clickhouse 复杂查询时嵌套连接join可能存在的异常解决(xjl456852原创)

时间:2020-02-20 09:38:12      阅读:309      评论:0      收藏:0      [点我收藏+]

标签:start   表连接   received   条件   receive   one   存在   提示   rom   

复杂查询可能出现异常类似于,有时你可能是在创建视图,也可能会出现下面的错误:
Code: 352. DB::Exception: Received from localhost:9000. DB::Exception: Cannot refer column ‘表名.字段名‘ to table.

首先clickhouse 在当前版本(version 19.17.4.11)中不支持exists用法,如果遇到了exists用法,应该把它改为in的语法.

因为查询语句比较复杂,这个整体的复杂查询语句可以在mysql中查询, 其中的部分嵌套语句也可以在mysql和clickhouse中查询.
但是整体的复杂查询却不能在clickhouse中查询,会报上面提示的错误.
其中内部的嵌套查询用了多个表的join 和 inner join 条件用的 on (表名.列名 = 表名1.列名1) 等多表连接

最后的解决方案:
将内部的查询单独取出来创建一个单独的小视图.
然后原来的整体的复杂查询中内部嵌套的查询替换为这些小视图,这个整体的复杂查询语句就会变得简单,再运行这个查询,就不会再报这个错误了.

clickhouse 复杂查询时嵌套连接join可能存在的异常解决(xjl456852原创)

标签:start   表连接   received   条件   receive   one   存在   提示   rom   

原文地址:https://www.cnblogs.com/xjl456852/p/12334088.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!