|
|
|
народ помогите советом
|
|||
|---|---|---|---|
|
#18+
Народ, в SQL я полный профан, но необходимость заставляет с ней работать. Вопрос такой: создаю таблицу create table zzz( id int unsigned auto_increment primary key, a text, b text, c text, ); пользователь на сайте вводит в поле input три слова разделенные пробелом, необходимо создать sql-запрос чтобы отобрать из таблицы те записи вкоторых поле a,b или c содержит хотя бы одно из этих слов. Слышал что сделать это можно с помощью like, но как реализовать не знаю. Буду очень благодарен, если направите в нужном направлении. юзаю mySQL+PHP ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.07.2004, 18:50 |
|
||
|
народ помогите советом
|
|||
|---|---|---|---|
|
#18+
юзай FreeBSD имхо ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 10.07.2004, 19:51 |
|
||
|
народ помогите советом
|
|||
|---|---|---|---|
|
#18+
<? //Входящая строка. Порежем, ибо нефиг. $str=strip_tags(trim($_POST['str'])); //Бьем на части по пробелу $arr = explode(" ", $str); //Посчитаем элементы массива $cou=count($arr); //Распишем столбцы $row[0]="a";$row[1]="b";$row[2]="c"; //Ваяем запрос $query="select * from zzz where "; for($i=0; $i<=$cou; $i++) { for($j=0; $j<3; $j++) { $query=$query.$row[$j]." like '%".$arr[$i]."%' or "; } } //Срежем последний or $query=substr($query, 0, strlen($query)-4); //Подключаемся к SQL внешним файлом include "../connectdb.php"; //Запускаем запрос $result = mysql_query($query) or die(mysql_error()); ?> ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.07.2004, 21:02 |
|
||
|
|

start [/forum/topic.php?fid=47&msg=32587850&tid=1854998]: |
0ms |
get settings: |
9ms |
get forum list: |
12ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
55ms |
get topic data: |
7ms |
get forum data: |
2ms |
get page messages: |
27ms |
get tp. blocked users: |
1ms |
| others: | 291ms |
| total: | 408ms |

| 0 / 0 |
