Оператор MySQL LIKE, поддерживающий несколько запросовPhp

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Оператор MySQL LIKE, поддерживающий несколько запросов

Сообщение Anonymous »

Хотелось бы найти названия продуктов, используя частичные совпадения, например, если имя_продукта — кот в шляпе, а имя — cat , то будет возвращен идентификатор. В настоящее время требуется точное совпадение, т. е. частичное совпадение невозможно.

Оператор LIKE обычно работает, но мы используем оператор IN для поддержки различного количества входных данных. Для MySQL LIKE IN()? REGEXP также должен работать, но, как уже упоминалось, количество входных данных варьируется. Каков был бы идеальный способ поиска совпадений для каждого экземпляра имени?

function woo_products_by_name_shortcode( $atts, $content = null ) {

// Get attribuets
extract(shortcode_atts(array(
'name' => ''
), $atts));

if( empty($name) ) return;

// Format product slugs string
$name = str_replace(",", "','", $name);

global $wpdb;
// Get the corresponding products ids for each name
$ids = $wpdb->get_col( "SELECT ID FROM {$wpdb->prefix}posts
WHERE post_type = 'product' AND post_name IN('$name')" );

ob_start();

// Define Query Arguments
$loop = new WP_Query( array(
'post_type' => 'product',
'posts_per_page' => -1,
'post__in' => $ids
));

// Get products number
$product_count = $loop->post_count;

echo ''; print_r($loop->posts); echo '';

return ob_get_clean();
}
add_shortcode("woo_products_by_name", "woo_products_by_name_shortcode");


Подробнее здесь: https://stackoverflow.com/questions/493 ... le-queries
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»