Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Поиск WHERE LIKE по всем полям таблицы
 
 автор: Ruskar   (15.03.2009 в 10:34)   письмо автору
 
 

Мне нужно осуществить поиск по всем полям таблицы базы данных примерно так:

SELECT * FROM table WHERE * LIKE '%search%';


Как правильно мне сформировать запрос, чтобы получить желаемое? Количество полей, их имена, тип заранее неизвестны, нужно просто найти все строки таблиц, содержащие искомое слово. Третий день уже копаю эту тему в интернете, так ничего толкового и не нашёл.

  Ответить  
 
 автор: Ruskar   (15.03.2009 в 11:09)   письмо автору
 
   для: Ruskar   (15.03.2009 в 10:34)
 

В принципе я пришёл к определённому решению в PHP, но мне оно кажется весьма «велосипедным»:

mysql_connect('localhost', 'root', 'ertgERhterth'); 
mysql_select_db('promsvyaz'); 
$result = mysql_list_tables("promsvyaz"); 

while($row = mysql_fetch_row($result)) { 
$fields = mysql_list_fields("promsvyazbank", $row[0]); 
$cols = mysql_num_fields($fields); //Получаем количество полей 
for ($i = 0; $i < $cols; $i++) { 
echo mysql_field_name($fields, $i)."<br />"; //Получаем имена полей 



Ну а дальше обрабатываем запросы примерно так:

SELECT * FROM `table` WHERE `field1` LIKE '%search%' OR `field2` LIKE '%search%' OR `field3` LIKE '%search%';

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования