メインコンテンツまでスキップ

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. 例 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を返します。

  1. 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 |
    +-------------------+--------------------+----------------------+