Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
Este operador é usado para selecionar documentos onde qualquer uma das posições de bit especificadas está definida como 1. É útil para consultar documentos com campos que armazenam valores de máscara de bits. Este operador pode ser útil ao trabalhar com campos que representam vários sinalizadores booleanos em um único inteiro.
Sintaxe
{
<field>: { $bitsAnySet: [ <bit positions> ] }
}
Parâmetros
| Parâmetro | Description |
|---|---|
field |
O campo a consultar. |
<bit positions> |
Uma matriz de posições de bit para verificar se alguma está definida como 1. |
Examples
Considere este documento de exemplo da coleção de lojas.
{
"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4",
"name": "First Up Consultants | Beverage Shop - Satterfieldmouth",
"location": {
"lat": -89.2384,
"lon": -46.4012
},
"staff": {
"totalStaff": {
"fullTime": 8,
"partTime": 20
}
},
"sales": {
"totalSales": 75670,
"salesByCategory": [
{
"categoryName": "Wine Accessories",
"totalSales": 34440
},
{
"categoryName": "Bitters",
"totalSales": 39496
},
{
"categoryName": "Rum",
"totalSales": 1734
}
]
},
"promotionEvents": [
{
"eventName": "Unbeatable Bargain Bash",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 6,
"Day": 23
},
"endDate": {
"Year": 2024,
"Month": 7,
"Day": 2
}
},
"discounts": [
{
"categoryName": "Whiskey",
"discountPercentage": 7
},
{
"categoryName": "Bitters",
"discountPercentage": 15
},
{
"categoryName": "Brandy",
"discountPercentage": 8
},
{
"categoryName": "Sports Drinks",
"discountPercentage": 22
},
{
"categoryName": "Vodka",
"discountPercentage": 19
}
]
},
{
"eventName": "Steal of a Deal Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 9,
"Day": 21
},
"endDate": {
"Year": 2024,
"Month": 9,
"Day": 29
}
},
"discounts": [
{
"categoryName": "Organic Wine",
"discountPercentage": 19
},
{
"categoryName": "White Wine",
"discountPercentage": 20
},
{
"categoryName": "Sparkling Wine",
"discountPercentage": 19
},
{
"categoryName": "Whiskey",
"discountPercentage": 17
},
{
"categoryName": "Vodka",
"discountPercentage": 23
}
]
}
]
}
O storeFeatures campo é um inteiro de máscara de bits que representa vários recursos de armazenamento. Cada bit corresponde a uma característica:
| Pouco | Valor | Característica |
|---|---|---|
| 0 | 1 | In-Store Recolha |
| 1 | 2 | Estacionamento |
| 2 | 4 | Acesso para cadeiras de rodas |
| 3 | 8 | Aberto 24 Horas |
| 4 | 16 | Pet-Friendly |
| 5 | 32 | Wi-Fi Grátis |
| 6 | 64 | Banheiros |
| 7 | 128 | Entrega ao Domicílio |
Exemplo 1: Encontre lojas que tenham retirada na loja ou drive-thru
Esta consulta recupera lojas que oferecem entrega em domicílio OU Wi-Fi grátis (bits 5 e 7)
db.stores.find({
storeFeatures: {
$bitsAnySet: [5, 7]
}
}, {
_id: 1,
name: 1,
storeFeatures: 1
}).limit(5)
Equivalente:
db.stores.find({
storeFeatures: {
$bitsAnySet: 160
}
}, // 32 + 128
{
_id: 1,
name: 1,
storeFeatures: 1
}).limit(5)
Os cinco primeiros resultados retornados por esta consulta são:
[
{
"_id": "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6",
"name": "Lakeshore Retail | Holiday Supply Hub - Marvinfort",
"storeFeatures": 38
},
{
"_id": "44fdb9b9-df83-4492-8f71-b6ef648aa312",
"name": "Fourth Coffee | Storage Solution Gallery - Port Camilla",
"storeFeatures": 222
},
{
"_id": "94792a4c-4b03-466b-91f6-821c4a8b2aa4",
"name": "Fourth Coffee | Eyewear Shop - Lessiemouth",
"storeFeatures": 225
},
{
"_id": "728c068a-638c-40af-9172-8ccfa7dddb49",
"name": "Contoso, Ltd. | Book Store - Lake Myron",
"storeFeatures": 239
},
{
"_id": "e6410bb3-843d-4fa6-8c70-7472925f6d0a",
"name": "Relecloud | Toy Collection - North Jaylan",
"storeFeatures": 108
}
]
Conteúdo relacionado
- Revise as opções para migrar do MongoDB para o Azure DocumentDB.
- Leia mais sobre a compatibilidade de recursos com o MongoDB.