Unknown column 'xx' in 'on clause'

今天在调试代码时发现一个项目历史遗留问题,
老是报Unknown column ‘sign.userid’ in ‘on clause’错误
然后我就将sql语句放入数据库可视化工具中,
发现还是这个错误。
然后就是一顿百度
百度搜索到的问题原因都是:
MySQL5.0 Bug, 要把联合的表用括号包含起来才行:

Sql代码
SELECT (c.id, a.id, b.id) FROM A a, B b LEFT JOIN C c ON c.a_id = a.a_id AND c.b_id = b.b_id
这句话执行应该是没有错误的,但是Mysql 5 下执行则会出错。

因为mysql下有这样一个BUG,要把联合的表用括号包含起来才行:

Sql代码
SELECT (c.id, a.id, b.id) FROM (A a, B b) LEFT JOIN C c ON c.a_id = a.a_id AND c.b_id = b.b_id 。

但发现完全不是这个原因
我粘下我代码

    SELECT
    c. NAME AS companyname,
    ifnull(o. NAME, '暂无部门') AS deptname,
    ifnull(u. NAME, '暂无人员') AS NAME,
    ifnull(signp, 0) AS signp,

    u.id,


    c.id AS companyid
FROM
    sys_user u
LEFT JOIN sys_office o ON u.office_id = o.id
RIGHT JOIN sys_office c ON u.company_id = c.id
LEFT JOIN (
    SELECT
        point_record.userid,
        SUM(point_record.point) AS signp,
        any_value(point_record.createdate)
    FROM
        point_record
    WHERE
        point_record.source = 'user_sign'
    AND date_format(createdate, '%Y-%m-%d') = date_format(
        '2013-05-27','%Y-%m-%d')
        AND (
            point_record.delflag IS NULL
            OR point_record.delflag != '1'
        )
        GROUP BY
            point_record.userid
    )AS SIGN ON u.id = sign.userid

我的报错是
[Err] 1054 - Unknown column ‘sign.userid’ in ‘on clause’

然后在各种尝试后发现给sign.userid加上单引号,错误消失,至于原因我也不懂,望哪位大神看到给解释下
下是我该过后代码

    SELECT
    c. NAME AS companyname,
    ifnull(o. NAME, '暂无部门') AS deptname,
    ifnull(u. NAME, '暂无人员') AS NAME,
    ifnull(signp, 0) AS signp,

    u.id,


    c.id AS companyid
FROM
    sys_user u
LEFT JOIN sys_office o ON u.office_id = o.id
RIGHT JOIN sys_office c ON u.company_id = c.id
LEFT JOIN (
    SELECT
        point_record.userid,
        SUM(point_record.point) AS signp,
        any_value(point_record.createdate)
    FROM
        point_record
    WHERE
        point_record.source = 'user_sign'
    AND date_format(createdate, '%Y-%m-%d') = date_format(
        '2013-05-27','%Y-%m-%d')
        AND (
            point_record.delflag IS NULL
            OR point_record.delflag != '1'
        )
        GROUP BY
            point_record.userid
    )AS SIGN ON u.id = 'sign.userid'
### 回答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注入等安全问题。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值