Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Хранение баланса пользователей

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: нужен совет, где лучше хранить
Prizma
Отправлено: 25 Февраля, 2016 - 09:23:31
Post Id



Посетитель


Покинул форум
Сообщений всего: 463
Дата рег-ции: Июнь 2012  
Откуда: Санкт-Петербург


Помог: 5 раз(а)




Добрый день,
(сайт пока находится в проектировке)
сайт связан с платежной системой, пользователь обладает своим балансом и может распоряжаться средствами на покупку услуг, товаров на сайте.
Все операции через транзакции, база MySQL.

Как правильно было бы хранить баланс пользователя в общей таблице users?
Или как то иначе? (например вообще не хранить баланс, а хранить только транзакции и рассчитывать баланс исходя из транзакций проведенных этим пользователем, каждая транзакция содержит остаток на счете, а при расчете баланса проверять информацию по 5 последним транзакциям, и в случае любой несостыковки блокировать кошелек)

Реальные деньги подстегивают еще раз подумать о безопасности))
 
My status
 Top
Мелкий Супермодератор
Отправлено: 25 Февраля, 2016 - 10:12:15
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Лог всех транзакций - это вообще без вариантов, обязателен. Желательна бухгалтерская двойная запись.

Вполне обосновано в общей таблице хранить аггрегированное значение баланса. Чтобы не дёргать каждый раз таблицу транзакций.

Prizma пишет:
Все операции через транзакции

Надеюсь, не просто begin/commit, а с пониманием где и что будет на конкурентном доступе?
Я вот тут более подробно писал: https://toster[dot]ru/q/273073#answer_716337


-----
PostgreSQL DBA
 
 Top
Prizma
Отправлено: 25 Февраля, 2016 - 10:56:57
Post Id



Посетитель


Покинул форум
Сообщений всего: 463
Дата рег-ции: Июнь 2012  
Откуда: Санкт-Петербург


Помог: 5 раз(а)




Мелкий пишет:
Надеюсь, не просто begin/commit, а с пониманием где и что будет на конкурентном доступе?
Я вот тут более подробно писал: https://toster[dot]ru/q/273073#answer_716337

Прочитал Ваш пост, да эти грабли я использовал как ключ в одной игрушке к бесконечному балансу))

только там был косяк еще глубже баланс в минус загонялся при небольшом ддосе ну собственно та ситуация которая описана в посте.

Кстате подобную задачку я где то пару лет назад завалил на собеседовании))
(Добавление)
Спасибо за советы
 
My status
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB