1

検索アプリケーションを実装しています

次のSQLクエリによる正確な単語検索を実装しました

SELECT *
FROM jreviews_content
WHERE jr_produits REGEXP '[[:<:]]ryan[[:>:]]'

ユーザーが ryans または ryan または sryan と入力した場合、システムは上記の実装された正確な結果を維持する結果を与える必要があるように、前部または後部でユーザーに単一の単語の柔軟性を与えたいと思います。単語検索。

4

1 に答える 1

0
set @word='sryan';
SELECT *
FROM (select 'ryan' as a)a
WHERE a like @word
or a like right(@word,length(@word)-1)
or a like left(@word,length(@word)-1)

->「ライアン」

set @word='ryan';
SELECT *
FROM (select 'ryan' as a union all select 'bryan' union all select 'yan' union all select 'yankee')a
WHERE a like @word
or a like right(@word,length(@word)-1)
or a like left(@word,length(@word)-1)

->「ライアン」、「ヤン」

    set @word='ryan';
    SELECT *
    FROM (select 'ryan' as a union all select 'bryan' union all select 'yan' union all select 'yankee')a
where 
a REGEXP concat('[[:<:]]',@word,'[[:>:]]')
or
a REGEXP concat('[[:<:]]',left(@word,length(@word)-1),'[[:>:]]')
or
a REGEXP concat('[[:<:]]',right(@word,length(@word)-1),'[[:>:]]')
于 2013-10-16T12:06:33.893 に答える