Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.12.02;
Скачать: [xml.tar.bz2];

Вниз

Изменить значение во время ввода   Найти похожие ветки 

 
ruslan_as   (2002-11-14 12:45) [0]

Дан DBGrid, куда напрямую пользователи вводят значения (цену).
Как можно сделать, чтобы они вводили свою цену, а в базу записывалось эта цена умноженная на 1,1. Вроде просто, а сообразить не могу.


 
iNew   (2002-11-14 12:52) [1]

В какое-нибудь событие (Типа OnDataChange) засунь это самое умножение.


 
ЮЮ   (2002-11-14 12:58) [2]

А разницу в ценах на личный счёт переводить будешь?
Интересный клиент получится: пользователь вводит 1, а получает 1.1 ! А что он должен увидеть в поле редактирования, когда захочет его исправить? 1.1 или опять 1?


 
KoluChi   (2002-11-14 13:03) [3]

Нужно использовать 2 разных поля в dataset - одно для отображения и ввода, другое реальное для записи в базу данных.
при чтении из базы - select field, field/1.1 as view-field from ...
В программе при изменении view_field менять field.
В базу записать соответственно field.



 
ЮЮ   (2002-11-14 13:19) [4]

>Как можно сделать, чтобы они вводили свою цену, а в базу записывалось эта цена умноженная на 1,1

Почему же они сразу не вводят цену, умноженную на 1.1? Наверное, потому, что вводимая цена есть какое-то реальное свойствою Не с потолка же они её берут. Вопрос в другом. Почему тебя не устраивает введённая цена, зачем её тут же менять? Если где-то в другом месте, при рассчётах, должна использоваться не сама она, а умноженная на 1.1, во там и умножай, не меняя при этом значение в базе.


 
Roma111   (2002-11-14 13:32) [5]

Есть очень ценное предложение:
В таблицу базы записывай нормальное число, сделай вьюер который умножает на 1.1. Можно, конечно, и триггер написать на события INSERT, UPDATE, который умножает, но это неправильно с точки зрения нормальной логики.


 
Виталий Панасенко   (2002-11-14 13:33) [6]

BeforePost - > Tbl1Field1.AsFloat := Tbl1Field1.AsFloat * 1.1;


 
Виталий Панасенко   (2002-11-14 13:35) [7]

Или добавь в таблицу вычисляемое поле: Field2 computed by(Field1*1.1)



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2002.12.02;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.008 c
3-4238
pivo_est
2002-11-13 23:43
2002.12.02
Сеть и PARADOX


3-4207
Antey
2002-11-13 16:10
2002.12.02
SQL- запрос


3-4195
Pegas
2002-11-13 15:12
2002.12.02
InterBase после удаления даных база не уменьшается!


14-4620
Undert
2002-11-09 21:43
2002.12.02
Кто-нибуть с НН или Оперой!!!!


1-4351
KLEVO
2002-11-21 23:00
2002.12.02
Пару вопросов





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский