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

Ребят, это какой-то сюр, какие инты когда речь о деньгах?

😁 Я по основному профилю - базовик. За 10 лет ни разу не видел в базе деньги ни в интах ни тем более в строках! Если в строках то как выборку делать? По строкам 9 рублей больше чем 10 😁
Кастомить каждую запись при каждом селекте? Так и мэйнфрейм сбера влегкую уложишь! 😆

8 ответов

23 просмотра

Теоретически мне кажется, что можно хранить и копейки) Мы так не делаем. А есть ведь кто работает в баксах, но нужно и в рублях рассчитываться

На интах делается «фиксированная запятая». Можно на рекордах «навалить» имитацию нового типа. Но проще взять currency который буквально для этого и создан

Я объясню в каких ситуациях, я например, хранил прямо в строках. Есть у меня поле в одной базе, которые хранит некую переменную структуру в JSON формате, полученной от API. Не было смысла ее стримить в конкретные поля и переменные, тем более структура может быть абсолютно разной. Так вот появляющиеся там поля получается хранятся как строки. А так, я за использование currency. Но, хочу заметить, что в базе, к примеру, SQLIte реальные данные хранятся все равно не в Currency. Ну, верее по ситуации может хранится как Float или как бигинт и т.д.

Renat Suleymanov
Я объясню в каких ситуациях, я например, хранил пр...

Я только про реальное, про свой хлеб в MsSql, он храниться в currency. Весь)))

Я изначально хранил деньги в intеger и по сей день есть еще много мест в базе где так осталось. Но в какой-то момент мне нужно было повысить точность меньше копейки, и пришлось перейти на numeric(18,4), который как раз совпадает с currency. Где не нужно именно .4 там использую .2 Еще есть косяк с весом - внедрил поле weight integer, в граммах, считал что этого достаточно. Пока товар был книги - хватало. Когда дошло до открыток - начались проблемы. Умножаем вес открытки в граммах на количество в пачке - и периодически получаем дичайшее расхождение по весу, ибо полграмма на одной открытке - это очень много в процентах. Так что тут так же лучше было заводить что-то дробное, чтобы при необходимости можно было повысить точность не переделывая все места где это поле используется.

Владимир Аксенов
Я изначально хранил деньги в intеger и по сей день...

Мы вес во float, обычно это кг. Бывает сколько - то грамм на несколько кг

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

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

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
Мне тут приспичило встроить в программу форматировние текста SQL, расставить переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых сл...
Sergey Bodrov
11
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Добрый день. Опять снова хочу обратиться к вам за помощью. После создания проэкта stack new, lazy.nvim + nvim-lspconfig/haskell-tools + hlint, ormolu из mason + hls из ghcup ...
Nannk
8
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
Карта сайта