首先,我不是程序员,而是尝试从Google那里学习自己一直在努力完成的项目。

使用的技术: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查询,但这对我所读内容的偏移和限制并不难。

最佳答案

您可能没有注意到,但是查询年份有一个错误,因为您的列名是mysql,而mysql也有一个功能年份,因此如果您不确定列名带有反斜线“`”,它将产生错误。会与任何函数名称冲突,最佳做法是在所有列上添加反斜杠,这样就不会有冲突的机会,因此看起来像这样

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

对于结果的分页,您已经使用了mysql的LIMIT函数,并带有开始索引和结束索引,例如

LIMIT 0 , 10或对于前10个结果,只需指定LIMIT 10保留在我的位置即可,默认情况下,限制将在查询结束时应用,它将按升序对结果集进行排序,但如果需要结果集,则可以指定顺序按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}%'或

关于php - CodeIgniter SQL查询包含撇号并按特定顺序搜索每一列,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/17562730/

10-10 00:31
查看更多