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

> Запрос по трем таблицам msql, Помогите написать запрос по трем таблицам msql
apdate  
 ۩  Дата
Цитировать сообщение

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



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

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 297
Пользователь №: 40396
На форуме: 2 года, 1 месяц, 19 дней
Карма: -2




Здравствуйте
помогите написать запрос
есть

таблица товары колонки скажем id- name

таблица продавцов колонки id- name

таблица ассоциаций колонки id- id_product - id_seller - price

сейчас имеется полученные данные по таблице "Товары"

мы имеем значение id товара

теперь необходимо произвести запрос к таблице "ассоциации" и выбрать из нее все == условию

ИдТовара == {prodoct -> id}

если ИдТовара == id_product тогда
выполняем следующий запрос к таблице "Продавцы"
так как мы получили данные из таблицы ассоциации мы можем запросить продавца по идентификатору "id_seller"

Ид_продавца == {assotiations -> id_seller}

теперь необходимо все полученное заполнить в блок
Выводим данные

Наименование продавца: == {seller -> name}
Цена товара: == {assotiations -> price}

КонецЕсли
КонецЕсли

в итоге получаем на один товар список его продавцов

помогите это все реализовать я плохо еще знаю php - msql

в 1с я бы сделал это но на ней же сайт не напишешь а сделать надо

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

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



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

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 297
Пользователь №: 40396
На форуме: 2 года, 1 месяц, 19 дней
Карма: -2




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

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



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

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 297
Пользователь №: 40396
На форуме: 2 года, 1 месяц, 19 дней
Карма: -2




помогите выбрать записи из двух таблиц сразу вот запрос что я написал но не получается (((

$query = $this->db->placehold("SELECT t1.id, t1.product_id, t1.saller_id, t1.price, t1.compare_price, t2.id, t2.name, t2.annotation, FROM __product_assotiation_saller t1 ON __sellers t2 WHERE t2.id = t1.saller_id AND  product_id = $product_id[product_id]");
PMПисьмо на e-mail пользователюСайт пользователяICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
apdate  
 ۩  Дата
Цитировать сообщение

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



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

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 297
Пользователь №: 40396
На форуме: 2 года, 1 месяц, 19 дней
Карма: -2




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

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



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

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 297
Пользователь №: 40396
На форуме: 2 года, 1 месяц, 19 дней
Карма: -2




может я не так получаю данные?

вот код получения (

три файла

1 = сам обработчик где сам запрос


public function get_product_options_assotiations($product_id)
{

$query = $this->db->placehold("SELECT t1.id, t1.product_id, t1.saller_id, t1.price, t1.compare_price, t2.id, t2.name, t2.annotation, FROM __product_assotiation_saller t1 ON __sellers t2 WHERE t2.id = t1.saller_id AND product_id = $product_id[product_id]");

$this->db->query($query);
$res = $this->db->results();

return $res;
}


2 файл запрос к 1 файлу



//выводим ассоциации
$product->assotiations = $this->assotiations->get_product_options_assotiations(array('product_id'=>$product->id));


3 файл сам шаблон



{foreach $product->assotiations as $vs}
<br />
<
br />
Ид магазина
{$vs->saller_id}
<br />
Старая цена магазина
{$vs->compare_price}
<br />
Новая цена магазина
{$vs->price}


но выводить данные не хочет (если по одной таблице то идентификатор магазина получаю а вот если запрос по двум делать но не получает нечего (

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

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



Абориген
*****

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 236
Пользователь №: 27946
На форуме: 5 лет, 6 месяцев, 14 дней
Карма: 11




SELECT
t1.id,
t1.product_id,
t1.saller_id,
t1.price,
t1.compare_price,
t2.id,
t2.name,
t2.annotation
FROM
__product_assotiation_saller t1
LEFT JOIN __sellers t2 ON t2.id = t1.saller_id
WHERE
product_id = $product_id[product_id]
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
jetistyum  
Дата
Цитировать сообщение

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



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

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 2605
Пользователь №: 5568
На форуме: 8 лет, 4 месяца, 25 дней
Карма: 30




Джоин верно написан?
не знаю, есть ли у него краткая версия, всегда писал полную, но вроде нужно так

SELECT ... 
LEFT JOIN tablename2 as t2 on t2.id=t1.foreign_id
WHERE...
PMСайт пользователяICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
apdate  
 ۩  Дата
Цитировать сообщение

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



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

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 297
Пользователь №: 40396
На форуме: 2 года, 1 месяц, 19 дней
Карма: -2




Всем спасибо!
все получилось сделать

вот запрос если Каму понадобится


$query = $this->db->placehold("SELECT * FROM __product_assotiation_saller , __sellers WHERE __sellers.id = __product_assotiation_saller.saller_id AND __product_assotiation_saller.product_id = $product_id[product_id]");
PMПисьмо на e-mail пользователюСайт пользователяICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

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

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