Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> Непонятки с выборкой из БД., Парадокс, однако.
Bezdna  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Мимо проходил
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1376
Пользователь №: 16492
На форуме: 7 лет, 11 месяцев, 8 дней
Карма: 17




А парадокс сей заключается в следующем:
Простейшая выборка из таблицы:

$query = mysql_query("SELECT * FROM `table1` LEFT JOIN `table2` ON (`type1` = `id2`) ";
while($rows = mysql_fetch_array($query)){
echo $rows['type1'].$rows['id2'];
}


Так вот, по логике значения $rows['type1'] и $rows['id2'] должны быть одинаковыми, а в моём случае почему-то значение $rows['id2'] на единицу больше значения $rows['type1'] (оба значения числовые, тип полей в базе INT).
Посему три ночи не сплю :D в раздумьях - то лыжи не едут, то ли что-то напутал. :D
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
killer8080  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 8737
Пользователь №: 26630
На форуме: 5 лет, 9 месяцев, 5 дней
Карма: 591




может все таки коллизия между именами полей в таблицах? Попробуй явно задать выбираемые поля
SELECT `t1`.`type1`, `t2`.`id2` 
FROM `table1` `t1`
LEFT JOIN `table2` `t2` ON `t1`.`type1` = `t2`.`id2`

PMПисьмо на e-mail пользователю
    1   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Bezdna  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Мимо проходил
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1376
Пользователь №: 16492
На форуме: 7 лет, 11 месяцев, 8 дней
Карма: 17




Как-то руки не доходили (фраза тоже, кстати, парадоксальная biggrin.gif) до поиска разгадки сего явления, сегодня дошли и, оказалось всё проще простого - каюсь, но разгадка в обычной невнимательности: поле id2было не INT, а ENUM со значениями 0,1,2,3, с соответственной "неправильной" выборкой. В связи с чем благодарю всех, потративших время на мою глупость.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса