$sql = "select $cols from ".$TableName." where title != '' and (LOCATE(title,'$tagTitle') or ((issystem = 1 or LENGTH(title) <= $titleFeildStrLen) and title like '%".$tagTitle."%' )) order by LENGTH(title) ";
$data =& $db->getAll($sql);
if(DB::isError($data)){
return $this->returnValue($data->getMessage());
}else{
return $data;
}
}
看sql:
select $cols from ".$TableName." where title != '' and (LOCATE(title,'$tagTitle') or ((issystem = 1 or LENGTH(title) <= $titleFeildStrLen) and title like '%".$tagTitle."%' )) order by LENGTH(title)
其实就是两次婚配,一次是正向婚配,就是把提交的标签跟数据库中标签停止婚配,第二次是把数据库中的标签跟提交的标签停止婚配。
关头在LOCATE()函数,同时也限制了长度,由于mysql中的编码是:
set names 'utf8'
就是是utf8的,那末一个汉字要占用3个字节,字符只占用1个字节,所以下面的:
$titleFeildStrLen = 24;
就是8个汉字和24个字符局限那的标签停止婚配。
2. 同类排序
数据库中好比是如许的内容:
北京 1023 1
天津 2301 1
上海 3450 1
天津 4520 1
北京 3902 1
那末我要提取一切的城市数据,而且把每种城市数据的总数跟其余城市总数停止对照后排序。
函数代码以下:
function getMostCity($num)
{
$sql = "select count(id) as num,city from ".$TableName." where city != '' group by city order by num desc limit 0,$num;";
$data =& $db->getAll($sql);
if($db->isError($data))
return false;
else
return $data;
}
咱们存眷一下下面的sql语句:
select count(id) as num,city from ".$TableName." where city != '' group by city order by num desc limit 0,$num
中心就是 group by city 把相似城阛阓中起来后依照多到少排序。