Перейти к основному содержимому
Версия: 2.0.x

bit_shift_left

Сдвигает двоичное представление числового выражения влево на указанное количество бит.

Эта функция выполняет арифметический сдвиг влево, при котором длина в битах не изменяется, в конец добавляется 0, а старший бит остается неизменным. Например, сдвиг 10101 влево на один бит дает 11010.

Синтаксис

bit_shift_left(value, shift)

Параметры

value: значение или числовое выражение для сдвига. Поддерживаемые типы данных: TINYINT, SMALLINT, INT, BIGINT и LARGEINT.

shift: количество бит для сдвига. Поддерживаемый тип данных — BIGINT.

Возвращаемое значение

Возвращает значение того же типа, что и value.

Примечания по использованию

  • Если любой входной параметр равен NULL, возвращается NULL.
  • Если shift меньше 0, возвращается 0.
  • Сдвиг value на 0 всегда возвращает исходное значение value.
  • Сдвиг 0 на любое значение shift всегда возвращает 0.
  • Если тип данных value является числовым, но не целым числом, значение будет приведено к целому числу. См. Примеры.
  • Если тип данных value является строкой, значение будет приведено к целому числу, если это возможно. Если значение не может быть приведено к целому числу, оно будет обработано как NULL. См. Примеры.

Примеры

Использование этой функции для сдвига числовых значений.

SELECT bit_shift_left(2, 1);
+----------------------+
| bit_shift_left(2, 1) |
+----------------------+
| 4 |
+----------------------+

SELECT bit_shift_left(2.2, 1);
+------------------------+
| bit_shift_left(2.2, 1) |
+------------------------+
| 4 |
+------------------------+

SELECT bit_shift_left("2", 1);
+------------------------+
| bit_shift_left('2', 1) |
+------------------------+
| 4 |
+------------------------+

SELECT bit_shift_left(-2, 1);
+-----------------------+
| bit_shift_left(-2, 1) |
+-----------------------+
| -4 |
+-----------------------+

См. также