Форум: "Базы";
Текущий архив: 2005.06.29;
Скачать: [xml.tar.bz2];
ВнизКак выбрать поле с самой новой датой Найти похожие ветки
← →
yk © (2005-05-18 13:39) [0]Уважаемые Мастера!
Ситуация такая:
В одной таблице
табл1(
ИДтабл1,
ИдТабл2,
цена
)
В другой таблице
Табл2(
ИДтабл2,
Дата
)
Мне нужно выбрать из Табл1 самую новую цену (дата это цены находится в таблице2).
Но я не знаю как поставить условие для выбора самой последней даты
Пример упрощенный.
← →
Johnmen © (2005-05-18 13:44) [1]Самая последняя - это максимальная, т.е MAX(Дата)
Используй вложенный запрос для определения макса...
← →
yk © (2005-05-18 14:09) [2]вроде получилось.
Но похоже на масло масляноеselect идтабл1,цена,идтабл2,дата
from табл1, табл2
where
табл1.ИДтабл2=табл2.ИДтабл2
and
табл2.Дата=(select max(дата)
from табл1, табл2
where
табл1.ИДтабл2=табл2.ИДтабл2
)
Может можно это попроще сделать,
ведь выбор последней цены - это верхушка айсберга :(
← →
Sergey13 © (2005-05-18 14:32) [3]Какая то структура не очень понятная. Что за вторая табла, зачем она? ИДшник и дата - это к чему? Вроде логичнее цену с датой хранить. Нет?
>Может можно это попроще сделать,
>ведь выбор последней цены - это верхушка айсберга :(
Если это надо делать постоянно или очень часто, то почему бы не провести маленькую денормализацию и хранить мах дату там где она нужна. Обновлять по тригеру на исходной таблице.
← →
Johnmen © (2005-05-18 15:20) [4]Зачем в подзапросе обращаться к двум таблицам ?
← →
evvcom © (2005-05-18 15:54) [5]Судя по вопросу, связь таблиц 1 к 1. Если так, то действительно лучше эти таблицы соединить. В противном случае вопрос надо ставить понятнее.
← →
yk © (2005-05-18 16:04) [6]извините, действительно непонятно написала.
Таблица 2 это
Поставка товара за определённое число
В эту поставки может входить много изделий (Таблица 1),
у каждого из них своя цена.
Мне нужно выбрать для конкретного набора изделий
( он может быть иным, чем в поставке) цену.
В качестве цены берется цена, указанная в последней поставке.
Если изделия такого вообще нет в поставках, то цену берем как 0
← →
Sergey13 © (2005-05-18 16:35) [7]2[6] yk © (18.05.05 16:04)
>извините, действительно непонятно написала.
Ты и сейчас не много прояснила. 8-) Для меня по крайней мере.
У тебя или связи какие то странные, или ты про них не все написала.
Я бы наверное попробовал сделать вьюшку поselect идтабл1,цена,идтабл2,дата
from табл1, табл2
where
табл1.ИДтабл2=табл2.ИДтабл2
А потом уже ее соединял с тем "набором изделий" который нужен.
← →
yk © (2005-05-19 14:09) [8]> Ты и сейчас не много прояснила. 8-)
Попробую поподробнее :)
У меня есть таблица
товаров
Tovar(
idTovar,
name
.....
)
есть таблица поставок
Postavka(
idPostavka
Date - дата поставки
....
)
В эту поставку входят как-бы поставляемые единицы:
PostEd(
idPostEd
idPostavka - ИД поставки, в которую входит эта единица
idTovar - ИД поставляемого товара
price - цена единицы товара
.....
)
Дано следующее:
1. Берем некоторый произвольный набор товаров
(напимер для того чтобы посмотреть сколько будет стоить
вся эта куча товара)
2. Для каждого товара надо
взять цену его из самой последней поставки
(если такие товары не поставлялись, то 0)
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2005.06.29;
Скачать: [xml.tar.bz2];
Память: 0.46 MB
Время: 0.039 c