Хотелось бы найти названия продуктов, используя частичные совпадения, например, если имя_продукта — кот в шляпе, а имя — 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
Оператор MySQL LIKE, поддерживающий несколько запросов ⇐ Php
Кемеровские программисты php общаются здесь
-
Anonymous
1728388025
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");
Подробнее здесь: [url]https://stackoverflow.com/questions/49312303/mysql-like-statement-supporting-multiple-queries[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия