2020-04-04 09:15:31 +00:00
---
machine_translated: true
2020-05-15 04:34:54 +00:00
machine_translated_rev: 72537a2d527c63c07aa5d2361a8829f3895cf2bd
2020-04-04 09:15:31 +00:00
toc_priority: 48
toc_title: "\u30D3\u30C3\u30C8"
---
2020-05-15 04:34:54 +00:00
# ビット関数 {#bit-functions}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
ビット関数は、UInt8、UInt16、UInt32、UInt64、Int8、Int16、Int32、Int64、Float32、Float64のいずれかの型のペアに対しても機能します。
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
結果の型は、引数の最大ビットに等しいビットを持つ整数です。 引数のうち少なくともいずれかが署名されている場合、結果は符号付き番号になります。 引数が浮動小数点数の場合は、Int64にキャストされます。
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
## ビタン(a,b) {#bitanda-b}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
## ビター(a,b) {#bitora-b}
2020-04-04 09:15:31 +00:00
## bitXor(a,b) {#bitxora-b}
## bitNot(a) {#bitnota}
## ビットシフトレフト(a,b) {#bitshiftlefta-b}
## ビットシフトライト(a,b) {#bitshiftrighta-b}
2020-05-15 04:34:54 +00:00
## ビットロタテレフト(a,b) {#bitrotatelefta-b}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
## ビットロータライト(a,b) {#bitrotaterighta-b}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
## bitTest {#bittest}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
間の任意の整数に換算しています。 [バイナリ形式 ](https://en.wikipedia.org/wiki/Binary_number ),指定された位置にあるビットの値を返します。 カウントダウンは右から左に0から始まります。
2020-04-04 09:15:31 +00:00
**構文**
``` sql
SELECT bitTest(number, index)
```
**パラメータ**
- `number` – integer number.
- `index` – position of bit.
**戻り値**
指定された位置にあるbitの値を返します。
タイプ: `UInt8` .
2020-05-15 04:34:54 +00:00
**例**
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
たとえば、基数43-2(二進数)の数値システムでは101011です。
2020-04-04 09:15:31 +00:00
クエリ:
``` sql
SELECT bitTest(43, 1)
```
結果:
``` text
┌─bitTest(43, 1)─┐
│ 1 │
└────────────────┘
```
別の例:
クエリ:
``` sql
SELECT bitTest(43, 2)
```
結果:
``` text
┌─bitTest(43, 2)─┐
│ 0 │
└────────────────┘
```
2020-05-15 04:34:54 +00:00
## ビッテスタール {#bittestall}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
の結果を返します [論理結合 ](https://en.wikipedia.org/wiki/Logical_conjunction ) 指定された位置にあるすべてのビットの(and演算子)。 カウントダウンは右から左に0から始まります。
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
ビットごとの演算のための結合:
2020-04-04 09:15:31 +00:00
0 AND 0 = 0
0 AND 1 = 0
1 AND 0 = 0
1 AND 1 = 1
**構文**
``` sql
SELECT bitTestAll(number, index1, index2, index3, index4, ...)
```
**パラメータ**
- `number` – integer number.
2020-05-15 04:34:54 +00:00
- `index1` , `index2` , `index3` , `index4` – positions of bit. For example, for set of positions (`index1`, `index2` , `index3` , `index4` )は、すべての位置が真である場合にのみtrueです (`index1` ⋀ `index2` , ⋀ `index3` ⋀ `index4` ).
2020-04-04 09:15:31 +00:00
**戻り値**
2020-05-15 04:34:54 +00:00
論理結合の結果を返します。
2020-04-04 09:15:31 +00:00
タイプ: `UInt8` .
2020-05-15 04:34:54 +00:00
**例**
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
たとえば、基数43-2(二進数)の数値システムでは101011です。
2020-04-04 09:15:31 +00:00
クエリ:
``` sql
SELECT bitTestAll(43, 0, 1, 3, 5)
```
結果:
``` text
┌─bitTestAll(43, 0, 1, 3, 5)─┐
│ 1 │
└────────────────────────────┘
```
別の例:
クエリ:
``` sql
SELECT bitTestAll(43, 0, 1, 3, 5, 2)
```
結果:
``` text
┌─bitTestAll(43, 0, 1, 3, 5, 2)─┐
│ 0 │
└───────────────────────────────┘
```
2020-05-15 04:34:54 +00:00
## ビッテスタニ {#bittestany}
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
の結果を返します [論理和 ](https://en.wikipedia.org/wiki/Logical_disjunction ) 指定された位置にあるすべてのビットの(または演算子)。 カウントダウンは右から左に0から始まります。
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
ビットごとの演算の分離:
2020-04-04 09:15:31 +00:00
0 OR 0 = 0
0 OR 1 = 1
1 OR 0 = 1
1 OR 1 = 1
**構文**
``` sql
SELECT bitTestAny(number, index1, index2, index3, index4, ...)
```
**パラメータ**
- `number` – integer number.
- `index1` , `index2` , `index3` , `index4` – positions of bit.
**戻り値**
2020-05-15 04:34:54 +00:00
論理解釈の結果を返します。
2020-04-04 09:15:31 +00:00
タイプ: `UInt8` .
2020-05-15 04:34:54 +00:00
**例**
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
たとえば、基数43-2(二進数)の数値システムでは101011です。
2020-04-04 09:15:31 +00:00
クエリ:
``` sql
SELECT bitTestAny(43, 0, 2)
```
結果:
``` text
┌─bitTestAny(43, 0, 2)─┐
│ 1 │
└──────────────────────┘
```
別の例:
クエリ:
``` sql
SELECT bitTestAny(43, 4, 2)
```
結果:
``` text
┌─bitTestAny(43, 4, 2)─┐
│ 0 │
└──────────────────────┘
```
## ビット数 {#bitcount}
2020-05-15 04:34:54 +00:00
数値のバイナリ表現で一つに設定されたビット数を計算します。
2020-04-04 09:15:31 +00:00
**構文**
``` sql
bitCount(x)
```
**パラメータ**
2020-05-15 04:34:54 +00:00
- `x` — [整数 ](../../sql-reference/data-types/int-uint.md ) または [浮動小数点数 ](../../sql-reference/data-types/float.md ) 番号 この関数は、メモリ内の値表現を使用します。 浮動小数点数をサポートできます。
2020-04-04 09:15:31 +00:00
**戻り値**
2020-05-15 04:34:54 +00:00
- 入力番号の一つに設定されたビット数。
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
この関数は、入力値をより大きな型に変換しません ([符号拡張](https://en.wikipedia.org/wiki/Sign_extension)). 例えば, `bitCount(toUInt8(-1)) = 8` .
2020-04-04 09:15:31 +00:00
タイプ: `UInt8` .
2020-05-15 04:34:54 +00:00
**例**
2020-04-04 09:15:31 +00:00
2020-05-15 04:34:54 +00:00
たとえば、数333を取る。 そのバイナリ表現: 00000000101001101。
2020-04-04 09:15:31 +00:00
クエリ:
``` sql
SELECT bitCount(333)
```
結果:
``` text
┌─bitCount(333)─┐
│ 5 │
└───────────────┘
```
2021-09-19 20:05:54 +00:00
[元の記事 ](https://clickhouse.com/docs/en/query_language/functions/bit_functions/ ) <!--hide-->