0

首先,我不是程序员,我试图在我一直试图为自己完成的项目上向谷歌学习。

使用的技术:CodeIgniter 2.1.2、PHP 5.3、MySQL

我的页面上有一个搜索关键字框,我想做的是搜索整个表格,但按特定顺序显示结果。

我目前有这个 SQL 查询,它不能使用撇号,也不能按列对结果进行排序。

function search($keyword)
 {
  $query="SELECT *
  FROM HWC
  WHERE ModelName LIKE '%{$keyword}%' OR Toy LIKE '%{$keyword}%'OR Year LIKE '%{$keyword}%'
  OR Col LIKE '%{$keyword}%'OR Series LIKE '%{$keyword}%'OR Color LIKE '%{$keyword}%'
  OR Tampo LIKE '%{$keyword}%'OR BaseColor LIKE '%{$keyword}%'OR BaseType LIKE '%{$keyword}%'
  OR WindowColor LIKE '%{$keyword}%'OR InteriorColor LIKE '%{$keyword}%'OR WheelType LIKE '%{$keyword}%'
  OR Country LIKE '%{$keyword}%'OR 'Series#' LIKE '%{$keyword}%'OR Notes LIKE '%{$keyword}%'";

  $result=$this->db->query($query);
  $result=$result->result_array();

  return $result;
}

我知道这是错误的,让某些事情正常工作是暂时的。

老实说,我可以将其分为 3 类进行排序

ModelName
Toy
Other (All the rest)

我还想要我为支持分页而构建的 SQL 查询,但这对于我所读内容的偏移和限制应该不难。

4

1 回答 1

3

您可能没有注意到,但是您的查询中有一个错误year is your column name 并且 mysql 也有一个函数year所以它会生成错误,如果您不确定,它会将您的列名加上反引号“`”将与任何函数名称冲突,最佳做法是在所有列上添加反引号,这样就不会有冲突的机会,所以它看起来像这样

SELECT *
  FROM HWC
  WHERE `ModelName` LIKE '%{$keyword}%' OR `Toy` LIKE '%{$keyword}%' OR `Year` LIKE '%{$keyword}%'
  OR `Col` LIKE '%{$keyword}%'OR `Series` LIKE '%{$keyword}%' OR `Color` LIKE '%{$keyword}%' 
  OR `Tampo` LIKE '%{$keyword}%' OR `BaseColor` LIKE '%{$keyword}%' OR `BaseType` LIKE '%{$keyword}%'
  OR `WindowColor` LIKE '%{$keyword}%' OR `InteriorColor` LIKE '%{$keyword}%' OR `WheelType` LIKE '%{$keyword}%'
  OR `Country` LIKE '%{$keyword}%' OR `Series#` LIKE '%{$keyword}%' OR `Notes` LIKE '%{$keyword}% '

对于order by结果集,您可以使用多个列进行排序,例如

ORDER BY col1,col2,col3

对于结果的分页,您可以使用LIMIT带有起始索引和结束索引的 mysql 函数,例如

LIMIT 0 , 10或者对于前 10 个结果,您可以简单地指定LIMIT 10keep in mine,默认情况下将在查询结束时应用限制,它将按升序对结果集进行排序,但如果您希望结果集按降序排列,您可以指定顺序DESC

SELECT *
  FROM HWC
  WHERE `ModelName` LIKE '%{$keyword}%' OR `Toy` LIKE '%{$keyword}%' OR `Year` LIKE '%{$keyword}%'
  OR `Col` LIKE '%{$keyword}%'OR `Series` LIKE '%{$keyword}%' OR `Color` LIKE '%{$keyword}%' 
  OR `Tampo` LIKE '%{$keyword}%' OR `BaseColor` LIKE '%{$keyword}%' OR `BaseType` LIKE '%{$keyword}%'
  OR `WindowColor` LIKE '%{$keyword}%' OR `InteriorColor` LIKE '%{$keyword}%' OR `WheelType` LIKE '%{$keyword}%'
  OR `Country` LIKE '%{$keyword}%' OR `Series#` LIKE '%{$keyword}%' OR `Notes` LIKE '%{$keyword}% '
ORDER BY `ModelName`, `Toy` LIMIT 0,10'

笔记

如果您没有在列名上添加反引号,请确保它们是唯一的,并在运算符、函数等和列名之间留一个空格,如 LIKE '%{$keyword}%'OR应该使用空格LIKE ' %{$keyword}%' 或

于 2013-07-10T05:23:03.543 回答