0

更新

我自己解决了这个问题:http: //dev.mysql.com/doc/refman/5.1/en/string-functions.html#function_concat-ws

如果有人需要做同样的事情并登陆这里,我更新了下面的代码。

我有一个小型 MySQL 数据库,我在其中搜索用户

SELECT *, kunde.id as kundeid
FROM kunde
INNER JOIN $bartype ON ($bartype.brugerid = kunde.id)
WHERE  $bartype.barid ='$barid[Barid]' AND
    (email LIKE '%$keyword%') OR
    (fornavn LIKE '%$keyword%') OR
    (efternavn LIKE '%$keyword%') OR
    (CONCAT_WS(' ', fornavn, efternavn) LIKE '%$keyword%')
LIMIT 0, 50;

现在我的搜索功能有效,但仅适用于任何一个'%$keyword%' LIKE fornavn or '%$keyword%' LIKE efternavn or '%$keyword%' LIKE email

所以我想对 LIKE 结果进行分组,以便在一个字符串中搜索“fornavn efternavn”时,它仍然会显示来自同一行的这两列的结果。

这有意义吗?是否可以修改我的 SQL 语句来做到这一点?

提前致谢

4

1 回答 1

1

为了做你想做的事,你可能想尝试一个UNION声明。union 语句将从一个查询中获取结果并将其添加到另一个查询的结果中,同时保留顺序(在我的示例中,具有电子邮件的结果将首先出现,然后是 fornavn,然后是 efternavn)。这样做也将消除您AND/OR可能阻止搜索结果出现的逻辑。

SELECT *, kunde.id as kundeid
FROM kunde
INNER JOIN $bartype ON ($bartype.brugerid = kunde.id)
WHERE  $bartype.barid ='$barid[Barid]' AND
    email LIKE '%$keyword%'
UNION ALL
SELECT *, kunde.id as kundeid
FROM kunde
INNER JOIN $bartype ON ($bartype.brugerid = kunde.id)
WHERE  $bartype.barid ='$barid[Barid]' AND
    fornavn LIKE '%$keyword%'
UNION ALL
SELECT *, kunde.id as kundeid
FROM kunde
INNER JOIN $bartype ON ($bartype.brugerid = kunde.id)
WHERE  $bartype.barid ='$barid[Barid]' AND
    efternavn LIKE '%$keyword%'

另一方面,像这样的动态 SQL 对于 SQL 注入来说已经成熟了。我可以建议你看看PHP PDO

更新

在您发表评论后,这里有一个更新的查询,它可能能够同时为您执行两个搜索:

SELECT *, kunde.id as kundeid
FROM kunde
INNER JOIN $bartype ON ($bartype.brugerid = kunde.id)
WHERE  $bartype.barid ='$barid[Barid]' AND
    email LIKE '%$keyword%'
UNION ALL
SELECT *, kunde.id as kundeid
FROM kunde
INNER JOIN $bartype ON ($bartype.brugerid = kunde.id)
WHERE  $bartype.barid ='$barid[Barid]' AND
    fornavn + ' ' + efternavn LIKE '%$keyword%'
于 2012-11-23T15:42:53.793 回答