繁体   English   中英

在MySQL中分组/联接列

[英]Grouping/joining columns in Mysql

更新

我用以下方法解决了自己的问题: 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”时,它仍会显示同一行中这2列的结果。

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

提前致谢

要执行您想要的操作,您可能想要尝试使用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%'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM