Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Битовая сумма id (https://javascript.ru/forum/misc/80370-bitovaya-summa-id.html)

Bond 28.05.2020 16:41

Битовая сумма id
 
Всем привет.
Подключаюсь к одной апишке и есть такая тема - есть пост запрос с формы - в форме есть мультиселект - Тип кузова - отправлять нужно id кузовов - но не в массиве а битовую сумму id кузовов и тип int64
Что это значит и зачем так сделано, почему не массив?

laimas 28.05.2020 17:17

Цитата:

Сообщение от Bond
Что это значит

Нахождение суммы битов числа (одного). Например, 45 = 101101 = 4 бита в числе.

Цитата:

Сообщение от Bond
зачем так сделано, почему не массив?

Трудно сказать зачем, а тем более для множества значений. Что из себя представляют эти id, можете их перечислить?

PS. Я могу и ошибаться, но скорее вы не так трактуете задачу и речь идет не о сумме бит, а побитовом ИЛИ, то есть сложении. При этом значения списка, это не id, а значения поля типа SET, которые представляют бит с шагом степени 2, то есть 1, 2, 4, 8, .... К примеру если будут выбраны 2 и 3 опции, то результат будет:

0010
0100
------
0110 = 6

что и требуется для записи в базу.

Bond 28.05.2020 17:30

laimas,
id - обычное число - например 1, 2, 54, 63 и даже такие 131072 - это чисто их внутренний учет айдишек. Вот несколько таких значений нужно отправлять, или одно значение если выбран один тип кузова.

laimas 28.05.2020 17:35

Цитата:

Сообщение от Bond
id - обычное число - например 1, 2, 54, 63

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

Например, в базе будет так

1 - Первый
2 - Второй
......

Также хранится и ENUM, но в нем можно выбрать одно значение из множества, а в SET многое из множества, поэтому и сумма. Сделайте побитое ИЛИ над значениями выбранных опций, получится то, что требуется.

Vlasenko Fedor 28.05.2020 17:57

если там тип int то значит сложить их вместе

laimas 28.05.2020 18:07

Цитата:

Сообщение от Vlasenko Fedor
если там тип int

Конечно он, о чем и речь, что это сумма чисел, просто каждое число представлено одним битом. То есть проще (упрощаем):

var sum = [...document.querySelectorAll('[selected]')].reduce((a, b) => a | b.value, 0)

нежели
var sum = [...document.querySelectorAll('[selected]')].reduce((a, b) => a += +b.value, 0)

Bond 28.05.2020 18:11

Vlasenko Fedor,
int64 - и в описании просто написано без примера - Битовая сумма id кузовов
а сложить вместе тоже есть такое поле - тип загрузки вот там тип int
Вот его описание из документации
Битовая сумма id типов загрузки. Например: только "Верхняя" будет иметь значение 1; "Верхняя", "Боковая" и "Со снятием стоек" имеют значение 67 (1 + 2 + 64)
Вот там айдишки идут - 1 2 4 8 16 32 64 128 и т.д

Bond 28.05.2020 18:15

Впрочем в типе кузова то же самое, сразу не обратил внимание - они просто перемешанные.

laimas 28.05.2020 18:22

Цитата:

Сообщение от Bond
Битовая сумма id типов загрузки. Например: только "Верхняя" будет иметь значение 1; "Верхняя", "Боковая" и "Со снятием стоек" имеют значение 67 (1 + 2 + 64)

Это не битовая сумма, это сумма всех значений. Например, чтобы получить из базы не "Верхняя", "Боковая" и "Со снятием стоек", а сумму их, то в запросе к базе делают так: field_name+0. Если же нужно текстовое, то field_name.

http://www.mysql.ru/docs/man/SET.html

А битовая сумма, это сумма бит в числе, есть такое понятие, посмотреть можно например тут https://neerc.ifmo.ru/wiki/index.php...ераци - Подсчет количества единичных битов

Bond 28.05.2020 18:33

Цитата:

Сообщение от laimas
Это не битовая сумма

Да, но это я цитировал описание из документации этого АПИ.


Часовой пояс GMT +3, время: 23:53.