Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Умножение в БД

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
hrjuka



Зарегистрирован: 18.11.2006
Сообщения: 3

СообщениеДобавлено: Сб Ноя 18 2006 22:01    Заголовок сообщения: Умножение в БД Ответить с цитатой

Люди добрые помогите "пробковому дереву" в области бд создать грамотный SQL запрос.

есть три таблицы A, B, C
В таблице B есть поля bID и ValueB
В таблице С есть поля cID и ValueC
В таблице А есть поля aID, idB, idC, ValueA, Tip, Priznak

// aID, bID, cID, idB, idC, ValueA, ValueB, ValueC - числа
// Tip, Proznak - текст

надо построить запрос в котором будут поля idA и Result
где idA = aID

Result - результат умножения ValueA на ValueB при условии что:
idB <> 0 и Priznak = 'x1',
если Priznak='x2', то тогда Result=ValueA*Result (причем Result тот,
который был получен при Priznak='x1'),
если Priznak = 'x3', то тогда Result=ValueA*Result (причем Result тот,
который был получен при Priznak='x2'),..... и так далее...

если idB=0, то тогда Result= ValueA*ValueC при условии что Priznak = 'x1',
если Priznak='x2', то тогда Result=ValueA*Result (причем Result тот,
который был получен при Priznak='x1'),
если Priznak = 'x3', то тогда Result=ValueA*Result (причем Result тот,
который был получен при Priznak='x2'),..... и так далее...

какая субд не знаю... желательно что то такое, что можно легко переносить.... как вариант можно в акцесе

Помогите пожалуйста. Всю глову себе сломал уже Sad
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Alex_pm



Зарегистрирован: 26.08.2006
Сообщения: 55

СообщениеДобавлено: Пт Дек 29 2006 01:24    Заголовок сообщения: Ответить с цитатой

В стандартном SQL тоесть в любой нормальной СУБД
есть функция IF(условие, выражение, выражение).
Главное не запутаться
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
kin



Зарегистрирован: 07.06.2006
Сообщения: 79

СообщениеДобавлено: Пт Дек 29 2006 10:41    Заголовок сообщения: Ответить с цитатой

или Case

пример из BOL MS SQL:

B. Use a SELECT statement with simple and searched CASE function
Within a SELECT statement, the searched CASE function allows values to be replaced in the result set based on comparison values. This example displays the price (a money column) as a text comment based on the price range for a book.

USE pubs
GO
SELECT 'Price Category' =
CASE
WHEN price IS NULL THEN 'Not yet priced'
WHEN price < 10 THEN 'Very Reasonable Title'
WHEN price >= 10 and price < 20 THEN 'Coffee Table Title'
ELSE 'Expensive book!'
END,
CAST(title AS varchar(20)) AS 'Shortened Title'
FROM titles
ORDER BY price
GO
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...