169 похожих чатов

Коллеги, доброе утро. Подскажите почему при делении decimal(19,4) на decimal(19,4)

получается тип float?
проверил чз SQL_VARIANT_PROPERTY(res, 'BaseType')
В документации нашел что тип с меньшей точностью приводится типу с большей точностью. Но тут типы одинаковые.
Вообще у меня задача перенести такой расчет: decimal(19,4)/decimal(19,4) - decimal(19,4)на c#
если на шарпах произвести расчет без приведения decimal к double, то результат будет в decimal, и не будет совпадать с скл серверным значением.

Я так понимаю сделать нужно так:decimal.ToDouble(a) / decimal.ToDouble(b) - decimal.ToDouble(c)?
Но изначально интересно все же почему сиквел сервер меняет тип, тот же c# тип не меняет.

4 ответов

10 просмотров

Перепроверь, должно быть по идее dec 19.8

Я думаю, это твоя ошибка, всё не так, приведи транскрипт сессии где это проверяешь.

Ilya Zviagin
Перепроверь, должно быть по идее dec 19.8

Странно,- тогда в верхний поедел не влезет если будет что-то длиииинное делиться, например, на 1.01

```````` ```````` В общем, ты где-то ошибаешься. Это не так. create table zivtest ( a decimal (19,4) not null, b decimal (19,4) not null ) go insert into zivtest (a, b) values( 123456789.1234, 2.0), ( 42.4242 * 5, 42.4242) go select a, b, a / b as a_div_b into zivtest2 from zivtest go sp_help zivtest2 go Получается таблица -- DROP TABLE EACCLI.dbo.zivtest2 GO CREATE TABLE EACCLI.dbo.zivtest2 ( a decimal(19,4) NOT NULL, b decimal(19,4) NOT NULL, a_div_b decimal(38,19) NULL ) GO

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта