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 の結果をグループ化して、1 つの文字列で「fornavn efternavn」を検索すると、同じ行にあるこれら 2 つの列の結果が引き続き表示されるようにしたいと考えています。

これは理にかなっていますか?これを行うために SQL ステートメントを変更することは可能ですか?

前もって感謝します

4

1 に答える 1

1

やりたいことを実行するには、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 に答える