首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >这个SQL查询有什么问题?(MySQL错误)

这个SQL查询有什么问题?(MySQL错误)
EN

Stack Overflow用户
提问于 2013-03-09 14:19:42
回答 2查看 166关注 0票数 1

我这里的问题出什么问题了?

代码语言:javascript
复制
mysql_query("SELECT * FROM admin_nav1 WHERE Active = 'YES' AND WHERE LinkedID = '$WID' ORDER by 'OrderSet' ASC") or die(mysql_error());

我一直在犯这个错误:

您的SQL语法出现了错误;请检查与您的MySQL服务器版本对应的手册,以获得在第1行“OrderSet‘ASC”中使用“WHERE LinkedID =’6”顺序的正确语法

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-03-09 14:20:30

您应该只有一个WHERE子句。AND运算符足以将这两个条件分开。

代码语言:javascript
复制
SELECT  * 
FROM    admin_nav1 
WHERE   Active = 'YES' AND LinkedID = '$WID'  // <<== one WHERE clause
ORDER   by OrderSet ASC

还有一件事是,您的查询不会正确地ORDER行,因为您已经用单引号包装了列名OrderSet,从而将其转换为字符串。如果列名是保留关键字,则当您关注它们时,可以使用回勾符将其包装,也可以在表上提供别名,并使用带有该别名的列名来分隔列,但不能用单引号分隔而不是

作为sidenote,如果变量的值来自外部,则SQL Injection会使查询易受攻击。请看下面的文章,了解如何防止它发生。通过使用PreparedStatements,您可以避免在值周围使用单引号。

票数 5
EN

Stack Overflow用户

发布于 2013-03-09 14:21:26

你需要用一次

代码语言:javascript
复制
SELECT * FROM admin_nav1 
WHERE Active = 'YES' AND  .....

然后使用和操作更多的条件。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15311704

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档