Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Соответствие одного значения в таблице, другому, значению, другой, таблице 
V
    Опции темы
Litovast
Дата 19.12.2008, 16:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.12.2008

Репутация: нет
Всего: нет



Код

<?
$settings['maxrow']=15;
$settings['params']='pif=comments&user='.$user.'';
$settings['pagelim']=5;//лимит страниц
$page=(int)$_GET['page'];
if ($page=="")$page=1;
$offset=($page-1)*$settings['maxrow'];

$start = $offset; //см
$limit = $settings['maxrow'];
if ($user!="")
{
    $r=mysql_query("SELECT * FROM books ");
$q2=mysql_query("SELECT * FROM comments WHERE `userid`='".addslashes($user)."'");
$q=mysql_query("SELECT * FROM comments WHERE `userid`='".addslashes($user)."' ORDER BY id DESC LIMIT $start,$limit");
}
else
{
    $r=mysql_query("SELECT * FROM books ");
$q2=mysql_query("SELECT * FROM comments ");
$q=mysql_query("SELECT * FROM comments ORDER BY id DESC LIMIT $start,$limit");
}

$count_row=mysql_num_rows($q2);
$count=1*$start+1;

while ($row=mysql_fetch_array($q) and $ro=mysql_fetch_array($r)){
    $r1=mysql_query("SELECT count(*) FROM comments where tema='$ro[name]'");
$spisoks .="<div  class=news><B>$count</B>. ".checkuser($row[userid])."$ktouser :: $row[data]<A HREF=\"?pif=view&id=".$row['tema']."#".$row['id']."\"><div style='padding:10px;border:1px solid #aaa;background-color: #ecffe9;margin:2px 20px 20px 0px;'>".$row['text']."<br><br><div style='padding:5px;border:1px dashed #aaa;background-color: #FFFFFF;position:absolute;cursor:pointer;'>Тема:$ro[name]</div></div></a></div><br>";
++$count;
}
if ($skoka==0)
{
    $spisok .="Нет результатов";
}


?>


Уважаемые знатоки, доброго всем здоровья!
Подскажите пожалуйста: Вот у меня есть такой код (написан выше). Есть две таблице в БД. В первой таблице(books) есть параметр (name) - текстовый (например:id "1" = name "книга о книге"). Во второй таблице(comments) есть параметр id, параметр "tema" - цифровой (например: id "1"=tema "1") и (text) - текстовый (хранятся комментарии к книгам). Сейчас при составлении запроса в БД выводится список комментариев, имена людей их публикующие, дата и название книги. Проблема в том, что названия книг выводятся тупо по порядку, а не соответственно комментарию. 
если поставить вместо
Код

Тема:$ro[name]

Код

Тема:$row[name]

То каждый комментарий соответствует книги, но только выводится не название книги, а ее ID, который записан во второй таблице в параметре (tema).Как в этом случае сделать соответствие этого ID реальному названию книги, которое хранится в параметре name второй таблицы (books)?
Помогите пожалуйста. Если можно исправьте мой пример..Заранее огромнейшее спасибо!
PM MAIL   Вверх
Litovast
Дата 19.12.2008, 21:03 (ссылка)    | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.12.2008

Репутация: нет
Всего: нет



Ау, народ, есть кто?Или все заняты уничтожением вируса на своем компеsmile? Помогите пожалуйста!
PM MAIL   Вверх
Litovast
Дата 21.12.2008, 19:31 (ссылка)    | (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.12.2008

Репутация: нет
Всего: нет



Ни один порядочный человек не помог :(
Выход из сложившейся ситуации был таким:
Код

$r=mysql_query("SELECT  comments.tema,books.name FROM comments inner join books on books.id=comments.tema ORDER BY comments.id DESC  LIMIT 0,15");

Все работает как часики!
PM MAIL   Вверх
LSD
Дата 22.12.2008, 14:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Цитата(Litovast @  21.12.2008,  19:31 Найти цитируемый пост)
Ни один порядочный человек не помог :(

Это потому, что никому было не охота заниматься отделением мух от котлет (SQL запросов, от PHP кода).


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Akella
Дата 27.12.2008, 00:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 3
Всего: 329



Цитата(Litovast @  21.12.2008,  19:31 Найти цитируемый пост)
Ни один порядочный человек не помог :(

а что, были обязаны?
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0588 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.