IoT Hub-frågespråk för enhet och modultvillingar, jobb och meddelanderedigering
IoT Hub tillhandahåller ett kraftfullt SQL-liknande språk för att hämta information om enhetstvillingar, modultvillingar, jobb och meddelanderoutning. I den här artikeln beskrivs:
- En introduktion till de viktigaste funktionerna i IoT Hub-frågespråket och
- Den detaljerade beskrivningen av språket. Mer information om frågespråk för meddelanderoutning finns i frågor i meddelanderoutning.
Specifika exempel finns i Frågor för enhets- och modultvillingar eller Frågor för jobb.
Kommentar
Några av de funktioner som nämns i den här artikeln, t.ex. moln till enhet-meddelanden, enhetstvillingar och enhetshantering, är bara tillgängliga på IoT Hubs standardnivå. Mer information om de grundläggande och standard-/kostnadsfria IoT Hub-nivåerna finns i Välj rätt IoT Hub-nivå för din lösning.
Köra IoT Hub-frågor
Du kan köra frågor mot din IoT-hubb direkt i Azure Portal.
- Logga in på Azure Portal och gå till din IoT-hubb.
- Välj Frågor i avsnittet Enhetshantering i navigeringsmenyn.
- Ange din fråga i textrutan och välj Kör fråga.
Du kan också köra frågor i dina program med hjälp av Azure IoT-tjänst-SDK:er och tjänst-API:er.
Exempel på kod som implementerar IoT Hub-frågor finns i avsnittet Frågeexempel med tjänst-SDK:er .
Länkar till SDK-referenssidor och exempel finns i Azure IoT SDK:er.
Grunderna i en IoT Hub-fråga
Varje IoT Hub-fråga består av SELECT- och FROM-satser med valfria WHERE- och GROUP BY-satser.
Frågor körs på en samling JSON-dokument, till exempel enhetstvillingar. FROM-satsen anger den dokumentsamling som ska itereras på (antingen enheter, enheter.moduler eller devices.jobs).
Sedan tillämpas filtret i WHERE-satsen. Med aggregeringar grupperas resultatet av det här steget enligt beskrivningen i GROUP BY-satsen. För varje grupp genereras en rad enligt beskrivningen i SELECT-satsen.
SELECT <select_list>
FROM <from_specification>
[WHERE <filter_condition>]
[GROUP BY <group_specification>]
SELECT-satsen
SELECT-select_list-satsen <> krävs i varje IoT Hub-fråga. Den anger vilka värden som hämtas från frågan. Den anger de JSON-värden som ska användas för att generera nya JSON-objekt. För varje element i den filtrerade (och eventuellt grupperade) delmängden av FROM-samlingen genererar projektionsfasen ett nytt JSON-objekt. Det här objektet konstrueras med de värden som anges i SELECT-satsen.
Till exempel:
Returnera alla värden
SELECT *
Returnera specifika egenskaper
SELECT DeviceID, LastActivityTime
Aggregera resultatet av en fråga för att returnera ett antal
SELECT COUNT() as TotalNumber
För närvarande stöds bara urvalssatser som skiljer sig från SELECT i aggregerade frågor på enhetstvillingar.
Följande syntax är grammatiken i SELECT-satsen:
SELECT [TOP <max number>] <projection list>
<projection_list> ::=
'*'
| <projection_element> AS alias [, <projection_element> AS alias]+
<projection_element> :==
attribute_name
| <projection_element> '.' attribute_name
| <aggregate>
<aggregate> :==
count()
| avg(<projection_element>)
| sum(<projection_element>)
| min(<projection_element>)
| max(<projection_element>)
Attribute_name refererar till alla egenskaper för JSON-dokumentet i FROM-samlingen.
FROM-sats
FROM-from_specification-satsen <> krävs i varje ioT Hub-fråga. Det måste vara ett av tre värden:
- enheter för att fråga enhetstvillingar
- devices.modules för att fråga modultvillingar
- devices.jobs fråga efter jobbinformation per enhet
Till exempel:
Hämta alla enhetstvillingar
SELECT * FROM devices
WHERE-satsen
WHERE-filter_condition-satsen> <är valfri. Den anger ett eller flera villkor som JSON-dokumenten i FROM-samlingen måste uppfylla för att inkluderas som en del av resultatet. Alla JSON-dokument måste utvärdera de angivna villkoren till "true" för att inkluderas i resultatet.
Till exempel:
Hämta alla jobb som riktar sig mot en specifik enhet
SELECT * FROM devices.jobs WHERE devices.jobs.deviceId = 'myDeviceId'
De tillåtna villkoren beskrivs i avsnittet uttryck och villkor .
GROUP BY-sats
GROUP BY-group_specification-satsen <> är valfri. Den här satsen körs efter filtret som anges i WHERE-satsen och före den projektion som anges i SELECT. Den grupperar dokument baserat på värdet för ett attribut. Dessa grupper används för att generera aggregerade värden enligt vad som anges i SELECT-satsen.
Till exempel:
Returnera antalet enheter som rapporterar varje telemetrikonfigurationsstatus
SELECT properties.reported.telemetryConfig.status AS status, COUNT() AS numberOfDevices FROM devices GROUP BY properties.reported.telemetryConfig.status
För närvarande stöds GROUP BY-satsen endast vid frågor mot enhetstvillingar.
Varning
Termen group
behandlas för närvarande som ett särskilt nyckelord i frågor. Om du använder group
som egenskapsnamn bör du överväga att omge den med dubbla hakparenteser för att undvika fel, t.ex. SELECT * FROM devices WHERE tags.[[group]].name = 'some_value'
.
Den formella syntaxen för GROUP BY är:
GROUP BY <group_by_element>
<group_by_element> :==
attribute_name
| < group_by_element > '.' attribute_name
Attribute_name refererar till alla egenskaper för JSON-dokumentet i FROM-samlingen.
Sidnumrering av frågeresultat
Ett frågeobjekt instansieras med en maximal sidstorlek på mindre än eller lika med 100 poster. Om du vill hämta flera sidor anropar du nextAsTwin på Node.js SDK eller GetNextAsTwinAsync på .Net SDK-metoden flera gånger. Ett frågeobjekt kan exponera flera Nästa-värden, beroende på vilket deserialiseringsalternativ som krävs av frågan. Ett frågeobjekt kan till exempel returnera enhetstvillingar eller jobbobjekt eller oformaterad JSON när du använder projektioner.
Uttryck och villkor
På hög nivå är ett uttryck:
- Utvärderar till en instans av en JSON-typ (till exempel boolesk, tal, sträng, matris eller objekt).
- Definieras genom att manipulera data som kommer från enhetens JSON-dokument och konstanter med hjälp av inbyggda operatorer och funktioner.
Villkor är uttryck som utvärderas till ett booleskt värde. Alla konstanter som skiljer sig från boolesk true anses vara falska. Den här regeln innehåller null, odefinierad, objekt- eller matrisinstanser, valfri sträng och boolesk false.
Syntaxen för uttryck är:
<expression> ::=
<constant> |
attribute_name |
<function_call> |
<expression> binary_operator <expression> |
<create_array_expression> |
'(' <expression> ')'
<function_call> ::=
<function_name> '(' expression ')'
<constant> ::=
<undefined_constant>
| <null_constant>
| <number_constant>
| <string_constant>
| <array_constant>
<undefined_constant> ::= undefined
<null_constant> ::= null
<number_constant> ::= decimal_literal | hexadecimal_literal
<string_constant> ::= string_literal
<array_constant> ::= '[' <constant> [, <constant>]+ ']'
Information om vad varje symbol i uttryckssyntaxen står för finns i följande tabell:
Symbol | Definition |
---|---|
attribute_name | Alla egenskaper för JSON-dokumentet i FROM-samlingen. |
binary_operator | Alla binära operatorer som anges i avsnittet Operatorer . |
function_name | Alla funktioner som visas i avsnittet Funktioner . |
decimal_literal | Ett flyttal uttryckt i decimal notation. |
hexadecimal_literal | Ett tal som uttrycks av strängen "0x" följt av en sträng med hexadecimala siffror. |
string_literal | Unicode-strängar som representeras av en sekvens med noll eller fler Unicode-tecken eller escape-sekvenser. Strängliteraler omges av enkla citattecken eller dubbla citattecken. Tillåtna escapes: \' , \" , \\ , \uXXXX för Unicode-tecken som definierats av fyra hexadecimala siffror. |
Operatorer
Följande operatorer stöds:
Familj | Operatorer |
---|---|
Aritmetisk | +, -, *, /, % |
Logiskt | AND, OR, NOT (och, eller, inte) |
Jämförelse | =, !=, <, >, <=, >=, <> |
Funktioner
När du frågar efter tvillingar och jobb är den enda funktion som stöds:
Function | beskrivning |
---|---|
IS_DEFINED(egenskap) | Returnerar ett booleskt värde som anger om egenskapen har tilldelats ett värde (inklusive null ). |
I vägförhållanden stöds följande matematiska funktioner:
Function | beskrivning |
---|---|
ABS(x) | Returnerar det absoluta (positiva) värdet för det angivna numeriska uttrycket. |
EXP(x) | Returnerar exponentiellt värde för det angivna numeriska uttrycket (e^x). |
POWER(x,y) | Returnerar värdet för det angivna uttrycket till den angivna kraften (x^y). |
SQUARE(x) | Returnerar kvadraten för det angivna numeriska värdet. |
CEILING(x) | Returnerar det minsta heltalsvärdet som är större än eller lika med det angivna numeriska uttrycket. |
FLOOR(x) | Returnerar det största heltalsvärdet som är mindre än eller lika med det angivna numeriska uttrycket. |
SIGN(x) | Returnerar det positiva (+1), noll (0) eller negativa (-1) tecknet för det angivna numeriska uttrycket. |
SQRT(x) | Returnerar kvadratroten för det angivna numeriska värdet. |
I vägförhållanden stöds följande typkontroll- och gjutningsfunktioner:
Function | beskrivning |
---|---|
AS_NUMBER | Konverterar indatasträngen till ett tal. noop om indata är ett tal; Undefined om strängen inte representerar ett tal. |
IS_ARRAY | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är en matris. |
IS_BOOL | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är booleskt. |
IS_DEFINED | Returnerar ett booleskt värde som anger huruvida egenskapen har tilldelats ett värde. Den här funktionen stöds endast när värdet är en primitiv typ. Primitiva typer är sträng, boolesk, numerisk eller null . DateTime, objekttyper och matriser stöds inte. |
IS_NULL | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är null. |
IS_NUMBER | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är ett tal. |
IS_OBJECT | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är ett JSON-objekt. |
IS_PRIMITIVE | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är en primitiv (sträng, boolesk, numerisk eller null ). |
IS_STRING | Returnerar ett booleskt värde som anger om typen av det angivna uttrycket är en sträng. |
I vägförhållanden stöds följande strängfunktioner:
Function | beskrivning |
---|---|
CONCAT(x, y, ...) | Returnerar en sträng som är resultatet av en sammanfogning av två eller fler strängvärden. |
LENGTH(x) | Returnerar antalet tecken i det angivna stränguttrycket. |
LOWER(x) | Returnerar ett stränguttryck efter att teckendata med versaler har konverterats till gemener. |
UPPER(x) | Returnerar ett stränguttryck efter att teckendata med gemener har konverterats till versaler. |
SUBSTRING(string, start [, length]) | Returnerar en del av ett stränguttryck som börjar vid det angivna tecknet nollbaserad position och fortsätter till den angivna längden, eller till slutet av strängen. |
INDEX_OF(sträng, fragment) | Returnerar startpositionen för den första förekomsten av det andra stränguttrycket i det första angivna stränguttrycket, eller -1 om strängen inte hittas. |
STARTS_WITH(x, y) | Returnerar ett booleskt värde som anger om det första stränguttrycket börjar med det andra. |
ENDS_WITH(x, y) | Returnerar ett booleskt värde som anger om det första stränguttrycket slutar med det andra. |
CONTAINS(x,y) | Returnerar ett booleskt värde som anger huruvida det första stränguttrycket innehåller det andra. |
Frågeexempel med tjänst-SDK:er
C#-exempel
Frågefunktionen exponeras av C#-tjänst-SDK:t i klassen RegistryManager .
Här är ett exempel på en enkel fråga:
var query = registryManager.CreateQuery("SELECT * FROM devices", 100);
while (query.HasMoreResults)
{
var page = await query.GetNextAsTwinAsync();
foreach (var twin in page)
{
// do work on twin object
}
}
Frågeobjektet instansieras med parametrarna som nämns i sidnumreringsavsnittet för frågeresultat. Flera sidor hämtas genom att anropa metoderna GetNextAsTwinAsync flera gånger.
Node.js exempel
Frågefunktionen exponeras av Azure IoT Service SDK för Node.js i registry-objektet .
Här är ett exempel på en enkel fråga:
var query = registry.createQuery('SELECT * FROM devices', 100);
var onResults = function(err, results) {
if (err) {
console.error('Failed to fetch the results: ' + err.message);
} else {
// Do something with the results
results.forEach(function(twin) {
console.log(twin.deviceId);
});
if (query.hasMoreResults) {
query.nextAsTwin(onResults);
}
}
};
query.nextAsTwin(onResults);
Frågeobjektet instansieras med parametrarna som nämns i sidnumreringsavsnittet för frågeresultat. Flera sidor hämtas genom att anropa metoden nextAsTwin flera gånger.
Nästa steg
- Lär dig mer om routning av meddelanden baserat på meddelandeegenskaper eller meddelandetext med frågesyntaxen för IoT Hub-meddelanderoutning.
- Få specifika exempel på frågor för enhets- och modultvillingar eller Frågor för jobb.