首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mySql查询给了我错误的结果

mySql查询给了我错误的结果
EN

Stack Overflow用户
提问于 2016-03-30 11:19:43
回答 1查看 50关注 0票数 0

我有一个名为的下表

代码语言:javascript
复制
  `questionID` int(11) NOT NULL AUTO_INCREMENT,
  `questioncategoryID` int(11) NOT NULL,
  `questionstatusID` int(11) NOT NULL,
  `organizationID` int(11) NOT NULL,
  `legalformID` int(11) DEFAULT NULL,
  `questionProtocolID` varchar(45) DEFAULT NULL,
  `questionDisplayedRecordID` int(11) NOT NULL,
  `questionTitle` text NOT NULL,
  `questionSummary` text,
  `questionText` longtext NOT NULL,
  `questionAnswerSummary` text,
  `questionAnswerText` longtext,
  `questionMetaTags` text,
  `questionAskedBy` int(11) NOT NULL,
  `questionAnsweredBy` int(11) DEFAULT NULL,
  `questionAskedOnDate` datetime NOT NULL,
  `questionAnsweredOnDate` datetime DEFAULT NULL,
  `questionAskedFromIp` varchar(255) NOT NULL

我正在尝试构建条件查询,即用户可以在我的搜索表单中选择搜索:

类别(questioncategoryID)法律形式(legalformID)从日期(questionAnsweredOnDate)到日期(questionAnsweredOnDate)搜索术语

用户可以将所有字段保留为空白,也可以全部使用.

更多解释:

  1. 类别(questioncategoryID) --如果它是空白的,就意味着他想看到所有类别的问题,如果不是,他只想看到特定类别的问题。
  2. 法律形式( legalformID ) -如果它是空白的,这意味着他想看到所有法律形式的问题,否则他只想看到有特定legalformID的问题。
  3. 从日期(questionAnsweredOnDate)开始,只有在此日期之后才能回答的问题(允许他保留此字段为空)
  4. 到目前为止(questionAnsweredOnDate)只回答在此日期之前回答的问题(允许他将此字段保留为空白)
  5. 如果搜索项不是空白,则应该在: questionTitle或in questionSummary或in questionText中找到搜索项(他可以将此字段保留为空白)。

我试图通过以下查询获取数据:

代码语言:javascript
复制
SELECT * FROM (`question`) 
    WHERE `questioncategoryID` = 5
    AND `legalformID` = 16 
    AND `questionTitle` LIKE '%Lorem Ipsum%' 
    OR `questionSummary` LIKE '%Lorem Ipsum%' 
    OR `questionText` LIKE '%Lorem Ipsum%' 
    OR `questionMetaTags` LIKE '%Lorem Ipsum%' 
    ORDER BY `questionAskedOnDate` DESC

但此查询返回属于类别5、10和7的问题,以及具有legalformID 0、3和16.的问题.

正如您所看到的,我甚至没有尝试使用日期,因为即使没有日期,我也无法使查询正确工作。所以请把日期包括在你的解决方案中。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-03-30 11:22:55

想必,你打算:

代码语言:javascript
复制
WHERE `questioncategoryID` = 5 AND
      `legalformID` = 16 AND
      (`questionTitle` LIKE '%Lorem Ipsum%' OR
       `questionSummary` LIKE '%Lorem Ipsum%' OR
       `questionText` LIKE '%Lorem Ipsum%' OR
       `questionMetaTags` LIKE '%Lorem Ipsum%' 
      )

当您将WHEREANDOR混合时,请在OR中使用括号。

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

https://stackoverflow.com/questions/36307262

复制
相关文章

相似问题

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