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

复杂查询可能出现异常类似于,有时你可能是在创建视图,也可能会出现下面的错误:
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) 等多表连接

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

posted @ 2020-02-20 00:32  三杯两盏淡酒  阅读(5646)  评论(0编辑  收藏  举报