Unknown column ‘xx’ in 'on clause'

这个错误卡住了我很久,,,是写tp3.2的多表查询时报的bug
代码

->join('weibo_userinfo as u ON weibo_comment.uid = weibo_userinfo.uid','LEFT')->field('weibo_comment.*,u.username,u.face50,u.uid')

生成的语句

SELECT weibo_comment.*,u.username,u.face50,u.uid FROM `weibo_comment` LEFT JOIN weibo_userinfo as u ON weibo_comment.uid = weibo_userinfo.uid

报错

 Unknown column ‘weibo_userinfo.uid’ in 'on clause'

???嗯?,这个字段肯定是有的,后来我发现不只是wibo_userinfo.uid,任何一个字段都不行。都不能做为消积条件。。。我又看了表结构,会不会是字段名有空格或者有回车。发现也没有。
这时候我己经蒙逼了。因为我left join weibo_userinfo时给了别名u,然后我就尝试这样

ON weibo_comment.uid=weibo_userinfo.uid//之前的
ON weibo_comment.uid=u.uid//现在的

发现居然没有报错了.
总结在多表连接时用了别名在on时就只能用定义的别名
在使用多表查询时,要注意一点, 两个表的字段如果有重名一定要进行,指定表的操作。where table.column=value
坑。。。。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: "unknown column in where clause" 意思是在 WHERE 子句中找不到指定的列。这通常是因为在 WHERE 子句中使用了一个不存在的表或列名。请检查语句并确保您引用的列存在于相应的表中。 ### 回答2: “where clause”是SQL语句中的一个关键词,用于指定查询条件。在执行SQL语句时,如果where语句中指定的列名在表中不存在,就会出现“unknown column in where clause”的错误提示信息。 这种错误通常发生在SQL语句中指定了不存在的列名,例如:SELECT * FROM table_name WHERE column_name = 'value',如果表“table_name”中不存在“column_name”列,就会出现上述错误。解决此问题的方法是检查SQL语句中的列名是否正确拼写,是否存在于表中。 此外,可能还会出现表或列名拼写相似但不相同的情况,例如:SELECT * FROM users WHERE username='admin',但实际上表名为“user”,列名为“name”,这也会导致相同的错误。解决此问题的方法是查看表名和列名是否正确,或者在SQL语句中使用表名和列名的别名。 最后,还有一种情况是在程序中拼接SQL语句时,由于变量名或字符串没有正确引号或单引号包裹导致“unknown column in where clause”错误。解决此问题的方法是确保SQL语句中所有变量和字符串都正确地包裹。 综上所述,解决“unknown column in where clause”错误的方法就是检查SQL语句中列名或变量名是否正确,避免拼写错误或引号缺失问题的出现。 ### 回答3: "未知的WHERE子句列" 是一个常见的SQL错误信息,它指的是在WHERE子句或HAVING子句中使用了不存在的列,导致无法查询所需的结果。这通常发生在SQL查询语句中,因为查询语句需要将表中的数据进行检索和筛选,但如果查询语句中WHERE或HAVING子句中使用的列名不正确或不存在,则会出现 "未知的WHERE子句列" 的错误信息。 为了解决此问题,我们需要再次检查查询语句并确保每个使用的列名都正确。可以通过以下步骤进行检查: 1. 确认查询语句中所有使用的表名和列名均正确无误; 2. 检查所使用的列名是否存在拼写错误,如大小写不一致或多余的空格等; 3. 确认使用的列名是否存在于数据库中的对应表格中,或者是否存在于视图或存储过程中; 4. 如果在查询中使用了多个表格,则要确保这些表格之间存在正确的关联关系,否则会出现错误。 最后,如果确认了所有使用的列名和表名都是正确的,但仍然出现 “未知的WHERE子句列” 的错误信息,请尝试使用SQL调试工具,在查询语句中逐一排除错误,以确定问题的实际原因。同时也要注意SQL查询语句的安全性,使用正确的查询方式和参数,避免出现SQL注入等安全问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值