Похожие чаты

Hello, I'M working on an app involving money. Every money involving action

creates a record, from which the overall user's balance can be calcuated.
There are many ways for the users to create these records, inside and even outside the application.
I want to make sure the new records won't ever result in negative balance for the user (because that means they used up more than they had, obviously).
If my application gets two requests at the same time, it might allow 2 decreasing records as the balance calculated for both requests was the same.

How do I deal with a problem like this?
I'm aware of the locking, but I feel like it's not reliable enough.
The solution I'm thinking of right now is creating something like a chain of any actions involving money.
Any new action would need to reference the previous action and this reference should stay unique for every user seprately.
If there's an attempt to append 2 records that reference the same previous action, then only one goes through.

However, I'm struggling to think of a solution for such a system.
Can anyone show me how the integrity of any financial data is normally achieved?
Or at least, is there any additional information on the solution I currently have in my head?

2 ответов

8 просмотров

Are you trying to implement a blockchain?

You need to have a database that is transactional and hence allow you to cancel operations if they result in an invalid state. To be precise, they need to be able to consider every balance action as an atomic operation

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

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

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
Hi. Do we have a raid bot? Why nobody doing raids on X? Even RH mentioned this and nobody paying attention...whats the channel for hex memes? If mods cant run raids just insta...
H
31
Подскажите, а есть vault lite или ченить такое?) А то нужен вольт для похода в вольт, но весит он ~500 мб) как-то многовато для парочки запросов ))
Alexandr Orloff
17
блеать, почему так?? где в роутере это исправляется?
Арсен Маньяков 🇦🇲
16
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
🌊 Ocean Nodes Dashboard Update 🚀 Hey, Oceaners! First off, a massive round of applause 👏to all of you for the amazing engagement since we launched Ocean Nodes. In just a few ...
KreigDK | Never DM first🌊
3
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
люди, которые используют flameshot, к вам вопрос. Можно-ли поставить хоткей на создание скриншота? В программе есть отдел "горячие клавиши", но там все для редактирования, скр...
ThunDer104
11
Карта сайта