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

Форум MySQL

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

 

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

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: MySQL. Две таблицы. Нужен запрос на выборку.

Сообщения:  [1-9] 

 
 автор: Phantom   (29.06.2008 в 03:18)   письмо автору
 
   для: Trianon   (29.06.2008 в 00:50)
 

Глубочайшие изинения =) Запрос работает. Просто у меня таблица click удаляется и создаётся заново каждый день в 00.00 по Москве =) Я забыл заново её заполнить и проверял запрос, полагая, что ней есть данные =) Сейчас вставил ваш запрос, проверил, вроде, все возможные варианты, которые могут возникнуть при работе скрипта, всё работает как надо. Спасибо. Реально Вы мне помогли, а то я уже отчаялся. Я MySQL недавно только начал осваивать, пока ещё путаюсь. Я пробовал примерно такой запрос, только проверял click.ip на NULL... Ступил =)

   
 
 автор: Phantom   (29.06.2008 в 00:54)   письмо автору
 
   для: Trianon   (29.06.2008 в 00:50)
 

Да, проверил. Всегда возвращает все id-ы.

   
 
 автор: Trianon   (29.06.2008 в 00:50)   письмо автору
 
   для: Phantom   (28.06.2008 в 20:00)
 

Это не лишнее условие. Это условие соединения таблиц согласно Вашему описанию.
Вы проверили запрос?

   
 
 автор: Phantom   (28.06.2008 в 20:00)   письмо автору
 
   для: Trianon   (28.06.2008 в 10:45)
 

В руководстве по MySQL написано, что в части ON не нужно лишних условий пихать, для этого есть WHERE. А ваш запрос в любом случае возвращает все ID-ы, что есть в таблице serf. Не работает.

   
 
 автор: Trianon   (28.06.2008 в 10:45)   письмо автору
 
   для: Phantom   (28.06.2008 в 09:57)
 

SELECT serf.id FROM serf 
  LEFT JOIN click ON serf.id=click.uid AND click.ip=$ip 
  WHERE click.uid IS NULL

   
 
 автор: Phantom   (28.06.2008 в 09:57)   письмо автору
 
   для: а-я   (28.06.2008 в 08:16)
 

Нет, нет. И INET_ATON тут не нужен. IP адрес уже преобразован как надо
Нужно что-то вроде этого:

"SELECT serf.id FROM serf LEFT JOIN click ON serf.id=click.uid WHERE click.ip!=$ip"

или этого:

"SELECT serf.id FROM serf,click WHERE click.ip=$ip and serf.id!=click.uid"

Но оба способа работают не так, как надо. =( *WALL*

   
 
 автор: а-я   (28.06.2008 в 08:16)   письмо автору
 
   для: Phantom   (27.06.2008 в 19:01)
 

что-то не понял....
может так?

$ip = 123; 

$SQL = '
SELECT 
 `tbl1`.`id`
FROM 
 `tbl1`,`tbl2`
WHERE 
 `tbl1`.`id` != `tbl2`.`uid`
 AND
 `tbl2`.`ip`!= INET_ATON("'.$ip.'")';

mysql_query($SQL); 

   
 
 автор: Phantom   (28.06.2008 в 05:03)   письмо автору
 
   для: Phantom   (27.06.2008 в 19:01)
 

Блин, помогите. Уже почти неделю голову ломаю.

   
 
 автор: Phantom   (27.06.2008 в 19:01)   письмо автору
 
 

Здравствуйте. Задача такая. Есть две таблицы. Структура первой в принципе не важна, нужно лишь знать, что в ней есть поле id с цЫферками. Ну например так:

1
2
3
4
5
6

Структура второй примерно такая (строк может и не быть вовсе, а может быть миллион):

id     uid     ip

1      2       123
2      2       456
3      3       456
4      3       789

По идее, в ip будут находиться ip-адреса, переведённые в числовой формат. Но для примера и так сойдёт. Нужно составить такой sql запрос, чтобы он вернул список id-ов первой таблицы, но исключил из него те id-ы, которые присутствуют в uid второй таблицы, ip которых совпадает с ip посетителя.

То есть, если, грубо говоря, ваш ip в данный момент 123, то запрос должен вернуть (см. пример выше) такой список:

1
3
4
5
6

Если ваш ip = 456, то:

1
4
5
6

Если ваш ip = 789, то:

1
2
4
5
6

Если ваш ip = 000 (его нет в таблице вообще), то:

1
2
3
4
5
6

Задача сложнее, чем кажется на первый взгляд. Я уже как только не делал, всё бестолку.

   

Сообщения:  [1-9] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

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