• 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) 等多表连接

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

  • 相关阅读:
    sed&awk 资料汇总 全是链接
    LeetCode Path 3Sum
    C++ mem_fun
    递归绑定
    查询当天数据
    清除script注入
    防注入查询
    我的最新分页
    群发邮件
    利用缓存
  • 原文地址:https://www.cnblogs.com/xjl456852/p/12334088.html
Copyright © 2020-2023  润新知