with t1 as ( select kh from ic_all ) select kh from ic_all i left join t1 on i.kh = t1.kh 为啥会报错invalid column reference 'kh'
时间: 2024-11-09 11:22:04 浏览: 29
这是一个SQL查询的问题。`with` 子句(也叫 Common Table Expression,CTE)是用来临时创建一个内部表,以便在后续的查询中引用它。在这个例子中,`t1` CTE 选择了 `ic_all` 表中的 `kh` 列。
然而,在第二个 `SELECT` 语句中,试图从原始的 `ic_all` 表 (`i`) 左连接 `t1`,并且直接引用了 `kh`,这里可能会出错。因为在第二次引用时,如果没有明确指定是从 `t1` 这个 CTE 中获取 `kh`,SQL解析器可能会认为 `kh` 是 `ic_all` 表的新列,而不是来自 `t1` 的列。
如果 `kh` 在两个表中都有,那么 `left join` 操作通常不会报错,但如果 `kh` 只存在于 `t1` 而不在 `i` 中,尝试去 `ic_all` 找这个不存在的列就会导致错误,提示 "invalid column reference 'kh'",意思是引用了一个无效的列名。
解决这个问题的方法是在第二个 `SELECT` 语句中加上 `(t1.kh)` 来明确指出你想要的是从 `t1` 中提取的 `kh` 数据:
```sql
select kh from ic_all i
left join t1 on i.kh = t1.kh
```
如果你之前从未使用过 `with` 子句,确保你在连接和引用 `kh` 时指定了正确的来源。如果问题依然存在,检查一下表结构或者确保 `kh` 字段确实存在于 `t1` 中。
阅读全文