Unknown column 'xxx' in 'where clause'

问题分析:

字段不存在,一般提示为:#1054 - Unknown column 'xxx' in 'where clause'

解决办法:


一般在升级PHPWind论坛过程中,由数据库字段丢失造成。手动添加字段,或者检查程序的查询语句.可能报错的如风格\插件\新增的表字段等, 具体看报错的SQL语句,可以根据错误提示,用sql语句收到添加字段即可解决.
   
若您不熟悉手动操作,可以尝试重升级,或者参看教程"添加字段,执行SQL教程":phpwind.net/show_help.php?help_id=170">http://faq.phpwind.net/show_help.php?help_id=170.

部分出错实例罗列:

实例一、
Unknown column 'special' in 'field list' (1054)

解决方法:

方法1:

数据表pw_attach缺少字段special,类型是tinyint(3),进phpmyadmin添加一下就可以了

方法2:

也可以在数据库运行SQL

ALTER TABLE `pw_attachs` ADD `special` tinyint(3) UNSIGNED NOT NULL AFTER `needrvrc`;

方法3:

如果您不会操作数据库,也可以把这个文件(phpwind.net//upload/techzip/special.zip" target=_self>下载)放到论坛根目录下执行(即跟index.php
global.php这些文件放在一起,域名/special.php就可以执行了)

记得注意备分数据库,运行完请手动删除该文件


实例二、
Unknown column 'aid' in 'field list' ( 1054 )


缺少字段aid

phpmyadmin执行
ALTER TABLE `pw_forumdata` ADD `aid` smallint(6) UNSIGNED NOT NULL AFTER `top2`;

或者把该文件(phpwind.net//upload/techzip/aid.zip" target=_self>下载)放到论坛根目录下运行(域名/aid.php),运行完请手动删除


实例三、
Unknown column 'time' in 'field list' ( 1054 )


phpmyadmin执行
ALTER TABLE `pw_elements` ADD `time` int(10) UNSIGNED NOT NULL;

或者把该文件(phpwind.net//upload/techzip/time.zip" target=_self>下载)放到论坛根目录下执行一下(域名/time.php),然后手动删除即可


实例四、
Unknown column 'p.multiple' in 'field list' ( 1054 )

数据库缺少字段 multiple ,可以phpmyadmin执行以下SQL语句
ALTER TABLE `pw_polls` ADD `multiple` tinyint(1) UNSIGNED NOT NULL;

也可以把该文件(phpwind.net/upload/techzip/multiple.zip" target=_self>下载)放到根目录下运行(域名/multiple.php)即可,运行完请手动删除


实例五、
Unknown column 'p.mostvotes' in 'field list' ( 1054 )


phpmyadmin中执行以下sql语句
ALTER TABLE `pw_polls` ADD `mostvotes` smallint(6) UNSIGNED NOT NULL;

或者把该文件(phpwind.net/upload/techzip/mostvotes.zip" target=_self>下载)放到根目录下运行下(域名/mostvotes.php) 运行成功后记得手动删除该文件

实例六、
Unknown column 'p.voters' in 'field list'

phpmyadmin中执行以下sql语句
ALTER TABLE `pw_polls` ADD `voters` mediumint(8) UNSIGNED NOT NULL
或者把该文件(phpwind.net/upload/techzip/voters.zip" target=_self>下载)放到根目录下运行下(域名/voters.php) 运行成功后记得手动删除该文件

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答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注入等安全问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值