forked from GNUsocial/gnu-social
[SEARCH][PostgreSQL] Make LIKE search case-insensitive
This commit is contained in:
parent
afd18db381
commit
5c21816b22
@ -196,30 +196,40 @@ class SQLLikeSearch extends SearchEngine
|
|||||||
{
|
{
|
||||||
public function query($q)
|
public function query($q)
|
||||||
{
|
{
|
||||||
|
$q_escaped = $this->target->escape(mb_strtolower($q), true);
|
||||||
|
$cols = [];
|
||||||
|
|
||||||
if ($this->table === 'profile') {
|
if ($this->table === 'profile') {
|
||||||
$qry = sprintf(
|
$cols = ['nickname', 'fullname', 'location', 'bio', 'homepage'];
|
||||||
'( %2$s.nickname LIKE \'%%%1$s%%\' ' .
|
|
||||||
' OR %2$s.fullname LIKE \'%%%1$s%%\' ' .
|
|
||||||
' OR %2$s.location LIKE \'%%%1$s%%\' ' .
|
|
||||||
' OR %2$s.bio LIKE \'%%%1$s%%\' ' .
|
|
||||||
' OR %2$s.homepage LIKE \'%%%1$s%%\')',
|
|
||||||
$this->target->escape($q, true),
|
|
||||||
$this->table
|
|
||||||
);
|
|
||||||
} elseif ($this->table === 'notice') {
|
} elseif ($this->table === 'notice') {
|
||||||
// Don't show direct messages.
|
// Don't show direct messages.
|
||||||
$this->target->whereAdd('notice.scope <> ' . Notice::MESSAGE_SCOPE);
|
$this->target->whereAdd('notice.scope <> ' . Notice::MESSAGE_SCOPE);
|
||||||
// Don't show imported notices
|
// Don't show imported notices
|
||||||
$this->target->whereAdd('notice.is_local <> ' . Notice::GATEWAY);
|
$this->target->whereAdd('notice.is_local <> ' . Notice::GATEWAY);
|
||||||
|
|
||||||
$qry = sprintf(
|
$cols = ['content'];
|
||||||
'notice.content LIKE \'%%%1$s%%\'',
|
|
||||||
$this->target->escape($q, true)
|
|
||||||
);
|
|
||||||
} else {
|
} else {
|
||||||
throw new ServerException('Unknown table: ' . $this->table);
|
throw new ServerException('Unknown table: ' . $this->table);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$conds = [];
|
||||||
|
foreach ($cols as $col) {
|
||||||
|
switch (common_config('db', 'type')) {
|
||||||
|
case 'pgsql':
|
||||||
|
// Faster than with the LOWER function
|
||||||
|
$cond = "{$this->table}.{$col} ILIKE";
|
||||||
|
break;
|
||||||
|
case 'mysql':
|
||||||
|
// Case-insensitive collation
|
||||||
|
$cond = "{$this->table}.{$col} LIKE";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$cond = "LOWER({$this->table}.{$col}) LIKE";
|
||||||
|
}
|
||||||
|
$conds[] = $cond . " '%" . $q_escaped . "%'";
|
||||||
|
}
|
||||||
|
|
||||||
|
$qry = '(' . implode(' OR ', $conds) . ')';
|
||||||
$this->target->whereAdd($qry);
|
$this->target->whereAdd($qry);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user