Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Лишние цифры в результате MSSQL  (Прочитано 11579 раз)
0 Пользователей и 1 Гость смотрят эту тему.
midex
Гость
« : 06-11-2008 06:10 » 

Здравствуйте!

Имеется следующая проблема: Здесь была моя ладья...

имеется база mssql с данными.. при выборке из базы используются след запросы (см. вложение) 

в итоге на выходе имеем результат, например (Общая Площадь Помещений или Баланс) = 45645,44444444443465465400123 и т.п.  Я шокирован!

какой командой (кодом), можно убрать такое количество цифр после запятой, округлять допустим до 1 десятой.
команда str не подходит, т.к. результат может быть от 0 до 100000000000 допустим, а в этой команде идет заданная длина результата...
помогите пожалуйста! быть может кто сталкивался с данной проблемой.
Буду благодарен за ответ.  Улыбаюсь
 

* 1.rar (7.17 Кб - загружено 851 раз.)
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #1 : 06-11-2008 06:22 » 

что нибудь типа
Код:
... затёрто ...
может, есть и какие то спецфункции, правда
« Последнее редактирование: 06-11-2008 06:49 от Алексей1153++ » Записан

midex
Гость
« Ответ #2 : 06-11-2008 06:36 » 

не получается однако...  Здесь была моя ладья...
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #3 : 06-11-2008 06:47 » 

а, косяк....
Код:
select CAST(  CAST(MyField*10 as bigint)  as float )/10 as TempField from MyTable

ну или не float , а что у тебя там
Записан

midex
Гость
« Ответ #4 : 06-11-2008 06:59 » 

спасибо! будем пробовать!  Улыбаюсь

может кто знает, есть ли спецфункции быть может какие?  Быть такого не может
Записан
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #5 : 06-11-2008 07:09 » 

Алексей1153++, да ты, батенька, извращенец Улыбаюсь

Есть же функция ROUND(<число>, <количество знаков после запятой>)
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #6 : 06-11-2008 07:13 » 

а, вот нашёл чего

Код:
select ROUND(MyField,3) as TempField from MyTable

второй параметр ROUND - количество знаков после запятой
Записан

Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #7 : 06-11-2008 07:14 » 

dimka, ага, уже нашёл )))) Я просто не пользовался никогда
Записан

midex
Гость
« Ответ #8 : 06-11-2008 07:21 » 

супер!!! спасибо большое! Класс!  Улыбаюсь
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines