Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.11.2010, 15:14
Alecsechechel Alecsechechel вне форума
Прохожий
 
Регистрация: 05.11.2010
Сообщения: 12
Репутация: 10
По умолчанию SQL

Привет Всем

Есть три таблицы
Первая customer в ней есть поле discount;
Вторая Avto в ней есть поле Type которое принимает может быть (Легковой, Микроавтобус, Грузовой);
Третья Zakaz в ней есть две дати дата аренды(DateA) и дата возвращение(DateV), а ещё в этой таблице есть поле price(которое пустое).

В таблицу заказ нужно поле price заполнить price=i*200*(DateV-DateA)-discount(i =1 если type=легковой, i =2 если type=микроавтобус,i =3 если type=грузовой ).

Как это можно с помощью SQL реализовать???

За ранее спасибо
Ответить с цитированием
  #2  
Старый 14.11.2010, 16:48
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Либо сделать таблицу соответствия для типов транспорта, либо делать выбор по кейсу. Первый вариант более логичен т.к. справочник этот вам по любому необходим. Тогда с использование справочника будет так:
Код:
Create table TransportType (id int primary key, Context varchar(50))
insert into TransportType (id, Context) Values (1,'Легковой') 
insert into TransportType (id, Context) Values (2,'Микроавтобус') 
insert into TransportType (id, Context) Values (3,'Грузовой') 
update Zakaz
 set Price = TransportType.ID * 200 * (Zakaz.DateV - Zakaz.DateA) - Zakaz.Discount
from Zakaz inner join TransportType on Zakaz.Type=TransportType.Context
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 14.11.2010, 17:01
Alecsechechel Alecsechechel вне форума
Прохожий
 
Регистрация: 05.11.2010
Сообщения: 12
Репутация: 10
По умолчанию

Спасибо я и думал что надо ещё таблицу создать )
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 15:49.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter