it-roy-ru.com

PHP Подобная вещь, похожая на MySQL Like, для оператора if?

Я хочу оператор if, который использует то же самое, что и mysql something LIKE '%something%'

Я хочу построить оператор if в php.

if ($something is like %$somethingother%)

Является ли это возможным?

Причина, по которой я задаю этот вопрос, заключается в том, что я не хочу менять команду MySQL, это длинная страница со множеством вещей, я не хочу создавать для этого другую функцию. 

Дайте мне знать, если это возможно, если возможно, то как это сделать.

10
friendishan

если ($ что-то похоже на% $ что-то другое%)

Является ли это возможным?

нет.

Я не хочу менять команду MySQL, это длинная страница, на которой много всего

Используйте хороший редактор, который поддерживает регулярные выражения в find & replace, и включите его примерно так:

if(stripos($something, $somethingother) !== FALSE){

}
23
dev-null-dweller

Я знаю, этот вопрос не актуален, но я решил похожую проблему :)

Мое решение:

/**
 * SQL Like operator in PHP.
 * Returns TRUE if match else FALSE.
 * @param string $pattern
 * @param string $subject
 * @return bool
 */
function like_match($pattern, $subject)
{
    $pattern = str_replace('%', '.*', preg_quote($pattern, '/'));
    return (bool) preg_match("/^{$pattern}$/i", $subject);
}

Примеры:

like_match('%uc%','Lucy'); //TRUE
like_match('%cy', 'Lucy'); //TRUE
like_match('lu%', 'Lucy'); //TRUE
like_match('%lu', 'Lucy'); //FALSE
like_match('cy%', 'Lucy'); //FALSE
14
Petr Bugyík

смотреть на strstr функция 

4
Haim Evgi

Используйте функцию, которая ищет строку в другой строке, например: strstr, strpos, substr_count.

2
singles

Используйте эту функцию, которая работает так же, как оператор SQLLIKE, но она будет возвращать логическое значение, и вы можете создать собственное условие с помощью еще одного оператора if

function like($str, $searchTerm) {
    $searchTerm = strtolower($searchTerm);
    $str = strtolower($str);
    $pos = strpos($str, $searchTerm);
    if ($pos === false)
        return false;
    else
        return true;
}
$found = like('Apple', 'app'); //returns true
$notFound = like('Apple', 'lep'); //returns false

if($found){
    // This will execute only when the text is like the desired string
}
0
Bairu

Но вам нужно будет указать строчную строку, чтобы она работала нормально .. Пример функции strstr:

$myString = "Hello, world!";
echo strstr( $myString, "wor" );                    // Displays 'world!'
echo ( strstr( $myString, "xyz" ) ? "Yes" : "No" ); // Displays 'No'
0
Ehsan