BIT_TEST
説明
<x>の値をバイナリ形式に変換し、指定された<bits>位置の値を返します。<bits>は0から開始します(右端のビット)。
<bits>に複数の値が含まれている場合、これらの位置の値はAND演算子を使用して結合され、最終結果が返されます。
<bits>内のいずれかの値が負数であるか、<x>の総ビット数を超える場合、結果は0になります。
<x>でサポートされる整数型:TINYINT、SMALLINT、INT、BIGINT、LARGEINT。
エイリアス
- BIT_TEST_ALL
構文
BIT_TEST(<x>, <bits>[, <bits> ... ])
パラメータ
<x><bits>
戻り値
指定された位置の値を返します。
例
-
例 1
select BIT_TEST(43, 1), BIT_TEST(43, -1), BIT_TEST(43, 2), BIT_TEST(43, 0, 1, 3, 5), BIT_TEST(43, 0, 1, 3, 5, 2);+-----------------+------------------+-----------------+--------------------------+-----------------------------+
| BIT_TEST(43, 1) | BIT_TEST(43, -1) | BIT_TEST(43, 2) | BIT_TEST(43, 0, 1, 3, 5) | BIT_TEST(43, 0, 1, 3, 5, 2) |
+-----------------+------------------+-----------------+--------------------------+-----------------------------+
| 1 | 0 | 0 | 1 | 0 |
+-----------------+------------------+-----------------+--------------------------+-----------------------------+
43の2進表現は"101011"なので、
BIT_TEST(43, 1)は1を返し、BIT_TEST(43, 2)は0を返し、BIT_TEST(43, 0, 1, 3, 5)は1を返します。 >BIT_TEST(43, 0, 1, 3, 5, 2)は0を返します。
-
NULL引数
select BIT_TEST(NULL, 1), BIT_TEST(43, NULL), BIT_TEST(NULL, NULL);+-------------------+--------------------+----------------------+
| BIT_TEST(NULL, 1) | BIT_TEST(43, NULL) | BIT_TEST(NULL, NULL) |
+-------------------+--------------------+----------------------+
| NULL | NULL | NULL |
+-------------------+--------------------+----------------------+