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

Достаточно сложный вопрос, но может кто поможет. Если кто-то занимается

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

Пусть есть таблица
id, user_id, match_id, bet_id (тип ставки, int), value(float), win(bool, дефолтно Null, тк ставка не рассчитана)

Человек может сделать ставку как на победу первой команды в матче, тогда bet_id (условно, будет 1), а поле value пустое (либо можно 0 вписать). Однако, если юзер ставит на тотал мячей больше (или что-то подобное, например фору, что имеет динамическое значение), то bet_id пусть будет 325, а value может варьироваться в пределах от 0.5 до бесконечности.
Взято специально полуторное значение, чтобы не было возвратов ставки.

Как одним запросом можно сделать update поля win на победу (true) и поражение (false) на основании типа bet_id, и если тип bet_id требует уточнения поля value, то уточнить, сравнить поле value с выданным мной значением и решить true или false

Как лучше такое провернуть? Если одним нельзя, то как лучше?

4 ответов

5 просмотров

case конструкция годится?

Gamer's Diary Project- Автор вопроса
Alexey Erpilev
case конструкция годится?

Я думал над case. Что-то типа Update table SET win=CASE WHEN bet_id in () THEN true WHEN bet_id in () THEN false ELSE null. Но, как сюда ещё внедрить проверку id и заглядывание в value? У меня на один матч могут быть: фора одной из команд, тотал угловых, тотал, мячей, фора по голам итд. Для каждой ставки своё пограничное "победное" значение, как их подставить и заставить проверять? Желательно максимально эффективно

Gamer's Diary Project- Автор вопроса

Ещё рассматриваю такой вариант: у меня 15 типов ставок (bet_id). Можно на каждый матч сделать 15 запросов, где уже добавить CASE, ну и там где надо использовать поле value, где не нужно - не использовать. Не знаю, получится ли так быстрее...

Gamer's Diary Project
Ещё рассматриваю такой вариант: у меня 15 типов ст...

Я считаю, что если есть 15 разных типов сущностей (которым приходится храниться в одной таблице), то для обработки каждого типа сущностей должны быть свои запросы. Есть преимущества: 1) можно в процессе развития системы гибко добавлять/исключать типы сущностей, не боясь нарушить работу остальных 2) можно выборочно обрабатывать сущности каждого типа. 3) Будет много небольших запросов, которые сравнительно проще писать, отлаживать, изменять или переносить, если потребуется.

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

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

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
читать файл максимально быстро? странный вопрос))
zamtmn
53
How to create an OS in C? what to study?
Linus
18
тоесть, указав return eax, сгенерируется никому ненужная инструкция mov eax,eax ?
Aiwan \ (•◡•) / _bot
24
Всем доброго вечера! Хочу поделиться своим злоключением с человеком, который, как оказалось сюда тоже скидывал свое резюме. Жаль, что я вашу группу не нашел раньше… человек ки...
Роман Ахмедзянов
4
а как бы вылезти из ИО, что то типа IO -> Ether или в какую сторону смотреть ? что то туплю
Fedor
8
Компания Elif ищет менеджера проектов, который будет заниматься поиском и ведением новых проектов. Прежде чем приступить к работе, вам нужно пройти наш недельный курс, где вы ...
Elif
5
Привет, кто может сделать юзербота с апи? Задачи: - создавать группы - создавать каналы - задавать для созданных каналов аватарку или эмоджи, имя группы - добавлять в группы...
Lencore
11
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Карта сайта