在Mysql中分组/加入列

时间:2012-11-23 15:00:18

标签: php mysql sql

更新

我用自己解决了以下问题: 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语句来执行此操作?

提前致谢

1 个答案:

答案 0 :(得分: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%'