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

Товарищи, нужен совет профессионалов: Мой бот рассылает сообщения пользователям по принципу

всё и всем, а я хочу реализовать следующее:

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

Но как лучше реализовать такой фильтр, где не один вариант, а сразу можно выбрать любое множество?
Т.е. пользователь может указать один или несколько городов, или регионов из которых он будет получать сообщения

Я планировал сделать это в одной ячейке БД с помощью словаря, т.е. указать ключом к каждому региону - цифру, и сохранять в БД только цифры выбранных пользователем регионов, причем сохранять их списком.
Может вы уже сталкивались с такой проблемой и моё решение дурацкое и есть другие варианты?

4 ответов

6 просмотров

Храни отдельную таблицу вида #пользователь + #тип селектора (оба primary key) -> выбранное значение

Засирать JSON не очень хорошая затея. По идее у тебя должен быть users, в котором все параметры созданы. Возможно в помощь - https://habr.com/ru/company/pgdayrussia/blog/331460/

только что пришел вариант в голову через двоичное представление чисел. Принцип следующий Допустим, есть 8 городов. Пользователь выбирает 2, 5 и 6. Тогда мы получим 01100010, что переводя в десятичную систему, получается число 98. И хранить просто и конвертировать быстро. Так работают, если я не ошибаюсь, разрешения в линухе, но я точно не знаю

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

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

Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
А чем вам питонисты не угодили?😂
.
79
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
Всем здравствуйте! Я хотел узнать сколько стоит средняя месячная зарплата у Electron js разработчиков? Мне очень это важно и нужно, плиз помогите узнать эту инфу! Для Джунио...
U.K.
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
77
А дин типизация это хорошо или плохо?
Alexey
12
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Hello. Could you please help me with finding all coordinates within a radius using a spatial index, given that I have a table with coordinates? SET @lng = 37.57925; SET @lat ...
Rinchin G
7
Карта сайта