2013-08-06 41 views
0

在表格的所有列中搜索子字符串。结果按以下顺序显示:
1.以substring开头的第一个结果。
2.然后结果在哪个子字符串中间,而不是最后
3.然后结果子串是最后。
的问题中间,而不是在最后因为像%字符串%搜索字符串时,也将包含%子实际上在最后。所以不保留顺序出现。如何在另一个字符串的中间搜索字符串

foreach($results as $r){ 
$append1 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." like'".$substring."%'union "; 
$query1 = $query1.$append1; 
} 
foreach($results as $r){ 
$append2 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." like'%".$substring."%'union"; 
$query2 = $query2.$append2; 
} 
foreach($results as $r){ 
$append3 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." like'%".$substring."'union"; 
$query3 = $query3.$append3; 
} 
$query4=$query1.$query2.$query3; 
$query4 = substr($query4, 0, -5); 
+0

取决于你真的想要做什么你可能会更好与全文搜索与分数 – cmorrissey

回答

1

LIKE运算符使用两个通配符。你已经知道%,但也有_(基本上意思是“任何角色中的一个”)。

这样你就可以做第二次查询像

$append2 ="SELECT * FROM $tablename WHERE {$r['COLUMN_NAME']} LIKE '_%{$substring}%_' union"; 

,它应该只匹配那里的后$substring和一个前至少一个字符。

0

您需要在WHERE子句中添加一个额外的位以排除字符串在末尾的位置。

$append2 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." like '%".$substring."%' AND ".$r['COLUMN_NAME']." NOT like '%".$substring."' union"; 

另外,不推荐使用mysql_ *函数,而应该真正查看mysqli或PDO。

0

您可以改为使用regular expressions。例如:

$append1 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." REGEXP '".$substring."$' union "; // match ending 

$append1 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." REGEXP '[[:print:]]".$substring."[[:print:]]' union "; // match middle 

$append1 ="select * from ".$tablename." WHERE ".$r['COLUMN_NAME']." REGEXP '^".$substring."' union "; // match beginning 
相关问题