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

Вниз

Округление в InterBase   Найти похожие ветки 

 
ruslan_as ©   (2003-04-01 21:03) [0]

Выручайте -горю. Есть такой запрос
select aa.a, bb.b, cc.c, dd.d
from a aa, B bb, c cc, d dd
where (a*c)/(b*d)<0,75236

но считает он только до 0,75 а остальные знаки отбрасывает.
Как регулировать степень точности работы?


 
zacho ©   (2003-04-01 21:23) [1]

А какие типы у a,b,c,d ? Какой диалект ?
Может поможет приведение (a*c)/(b*d) к нужному типу ? Например, where cast( ((a*c)/(b*d)) as double precision). Или приведение a,b,c,d к нужному типу.
P.S. Использование в запросах из нескольких таблиц имен полей без алиасов таблиц - источник глюков. Так что пиши where (aa.a*cc.c ...


 
ruslan_as ©   (2003-04-02 09:15) [2]

Извините за долгое молчание (был оторван от внешнего мира аж 8 часов).
Диалект у меня 3. a,b,c,d у меня varchar с масштабом 10. Но может быть и другой. В принципе у меня там целые числа. (Пробовал INTEGER - считает совсем без дробных).

Спасибо за совет по последнему пунту.


 
zacho ©   (2003-04-02 09:36) [3]


> ruslan_as © (02.04.03 09:15)
> Но может быть и другой. В принципе у меня там целые числа.

А зачем хранить их в varchar ?

> (Пробовал INTEGER - считает совсем без дробных).

Попробуй снова :) c явным приведением типа.
Т.е. where cast((a*c) as double precision) /cast((b*d) as double precision) <0,75236


 
ruslan_as ©   (2003-04-02 09:48) [4]

Спасибо за помощь zacho! Прошу еще немного помощи:

Переделал:
select aa.a, bb.b, cc.c, dd.d,cast((aa.a*cc.c) as double precision) /cast((bb.b*dd.d) as double precision)
from a aa, B bb, c cc, d dd
where cast((aa.a*cc.c) as double precision) /cast((bb.b*dd.d) as double precision) <0.75236

Все равно считает до 3 знаков после запятой. Можно ли явно указать сколько знаков? (Да и в задаче пользователь будет сам определять точность поиска).


 
ЮЮ ©   (2003-04-02 09:51) [5]

Попробуй преобразовать к double precision сомножители, а не результат


 
zacho ©   (2003-04-02 10:09) [6]

Можешь сделать
cast(cast((aa.a*cc.c) as double precision) /cast((bb.b*dd.d) as double precision) as numeric(scale,precision)) где scale - общее кол-во знаков в числе, precision - нужное тебе кол-во знаков после запятой.


 
zacho ©   (2003-04-02 10:13) [7]

Блин, по-нормальному стоило бы написать наоборот (precision,scale) :-)


 
ruslan_as ©   (2003-04-02 10:16) [8]

Беру строку
select aa.a, bb.b, cc.c, dd.d,cast(aa.a as double precision) as YYY
Результат поля YYY будет число с 3 знаками после запятой, а мне нужно еще и регулирать кол-во знаков.


 
zacho ©   (2003-04-02 10:21) [9]


> ruslan_as © (02.04.03 10:16)

Смотри в сторону NUMERIC и DECIMAL


 
ruslan_as ©   (2003-04-02 10:24) [10]

>>zacho Спасибо!!! Работает!!!



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

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

Наверх




Память: 0.49 MB
Время: 0.02 c
3-54521
baracuda
2003-03-31 18:26
2003.04.17
dbcombobox


1-54619
Alexxxxx
2003-04-07 22:46
2003.04.17
Парсинг *.rtf файла.


3-54438
kie
2003-04-01 23:00
2003.04.17
Добавление данных в DB


1-54662
Furyous
2003-04-03 08:18
2003.04.17
Проблема с эдитами.


1-54707
elf_123
2003-04-01 22:28
2003.04.17
Очень хитрый Эдит