Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.07.04;
Скачать: CL | DM;

Вниз

Рубли без копеек   Найти похожие ветки 

 
Explorer ©   (2002-06-10 14:35) [0]

Добрый день, мастера!

Есть две таблицы. В первую заношу какие-то денежные данные
(money). При просмотре данные отображаются корректно, т.е.
рубли с копейками (Ex.: 14.50).
В приложении некоторые поля первой таблицы приравниваю второй и
получаю только рубли (14). Тип данных в обеих таблицах одинаковый.
Где я мог напортачить?


 
TSV ©   (2002-06-10 14:59) [1]

Покажи код, как ты это (приравнивание) делаешь.


 
Explorer ©   (2002-06-10 15:12) [2]

TSV ©
Код:

StoredProcChangeNewDogovor.ParamByName("@CostPerDayDogovor").AsCurrency:=
QueryFreeCells.FieldByName("CostPerDayFiz").AsCurrency;

А пытался вывести данные в DBEdit и просто просмотреть. Но та же проблема!


 
Explorer ©   (2002-06-11 06:27) [3]

Ну подкиньте, хоть какие-нибудь еще идеи?


 
Explorer ©   (2002-06-11 07:43) [4]

Блин, а вот когда пишу вот так в запросе для Query

rtrim(convert(varchar(20),t2.CostPerDayFiz)) as CostPerDayFiz

то все правильно выводиться, с "копейками".

Но когда пишу
t2.CostPerDayFiz , то только "рубли"!

Почему так?


 
Johnmen ©   (2002-06-11 09:13) [5]

А выводится в дбгрид ? И если есть копейки, то они просто не показываются ? Если да - то округляются, отсекаются ?



 
Explorer ©   (2002-06-11 10:18) [6]

когда пишу t2.CostPerDayFiz
В дбгрид тоже не выводятся полностью. Отсекаются!

Но, когда пишу так
rtrim(convert(varchar(20),t2.CostPerDayFiz)) as CostPerDayFiz
то все нормально! Не могу понять почему?!
Так бы и оставил, но мне просто надо в дальнейшем с этими "деньгами" работать (разные операции над ними проводить).
Еще поднял мануал, так там пишут, что если использовать тип данных money, то "надо перед значещей цифрой ставить знак доллара или другой валюты, определенной для вышего региона".
Это обязательно?
Если, да, то как это воплотить в процедурах?


 
Johnmen ©   (2002-06-11 10:23) [7]

А если попробовать работать с полем как AsFloat ?
Какого типа поле в таблице ?


 
Explorer ©   (2002-06-11 10:47) [8]

Johnmen ©
1)потытаюсь конечно
2)поле - money


 
Johnmen ©   (2002-06-11 10:55) [9]

Не знаю особенностей типа поля money в MSSQL.
Предпочитаю для денег всегда использовать FLOAT"о-подобные типы полей - так меньше вероятность нарваться на непредвиденные особенности реализации типа...



 
Explorer ©   (2002-06-11 11:08) [10]

Спасибочки! Попробую!


 
Explorer ©   (2002-06-11 12:02) [11]

Johnmen ©
почему когда пишу в Query, такой запрос на проверку

declare @m float set @m = 1.22
select mom = @m


выдается ошибка: Error creating cursor handle

Тоже самое пишу в SQL Query Analyzer, то все нормально



 
Johnmen ©   (2002-06-11 12:23) [12]

К сожалению я не специалист по MSSQL (патологическая нелюбовь :))
И соответственно не знаком с синтаксисом при работе с курсорами...


 
Explorer ©   (2002-06-11 12:36) [13]

>Johnmen ©
Все равно спасибо!



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

Текущий архив: 2002.07.04;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.011 c
3-9729
voland_s
2002-06-10 15:14
2002.07.04
SQL временные таблички


3-9737
lak_b
2002-06-11 23:57
2002.07.04
IB


1-9833
AMQ
2002-06-14 17:26
2002.07.04
JPEG in EXE


1-9784
valerchik
2002-06-20 00:48
2002.07.04
Как скопировать файл...


8-9928
QueenOfRain
2002-02-27 12:06
2002.07.04
Scanline