Главная страница
    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.007 c
1-4372
chak
2002-11-22 12:29
2002.12.02
Копирование файлов+ProgressBar


3-4229
iva
2002-11-14 11:08
2002.12.02
Как добавить в BDE новый Database Driver Name


3-4263
skirdov
2002-11-12 14:47
2002.12.02
Выборка данных с SQL Server


1-4433
XDefender
2002-11-19 16:01
2002.12.02
Проблма при создании компонента Delphi!! (HELP!!)


3-4183
REP
2002-11-13 10:11
2002.12.02
Открытие в TQuery таблицы с другим расширением (Не DBF)





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский