Cihaz ve modül ikizleri, işler ve mesaj yönlendirmesi için IoT Hub sorgu dili
IoT Hub, cihaz ikizleri, modül ikizleri, işler ve ileti yönlendirme ile ilgili bilgileri almak için güçlü bir SQL benzeri dil sağlar. Bu makale şunları sunar:
- IoT Hub sorgu dilinin temel özelliklerine giriş ve
- Dilin ayrıntılı açıklaması. İleti yönlendirme için sorgu dili hakkında ayrıntılı bilgi için bkz . İleti yönlendirmedeki sorgular.
Belirli örnekler için bkz . Cihaz ve modül ikizleri için sorgular veya İşler için sorgular.
Not
Buluttan cihaza mesajlaşma, cihaz ikizleri ve cihaz yönetimi gibi bu makalede bahsedilen özelliklerden bazıları yalnızca IoT Hub'ın standart katmanında kullanılabilir. Temel ve standart/ücretsiz IoT Hub katmanları hakkında daha fazla bilgi için bkz. Çözümünüz için doğru IoT Hub katmanını seçme.
IoT Hub sorguları çalıştırma
IoT hub'ınıza yönelik sorguları doğrudan Azure portalında çalıştırabilirsiniz.
- Azure portalında oturum açın ve IoT hub'ınıza gidin.
- Gezinti menüsünün Cihaz yönetimi bölümünden Sorgular'ı seçin.
- Metin kutusuna sorgunuzu girin ve Sorguyu çalıştır'ı seçin.
Azure IoT hizmet SDK'larını ve hizmet API'lerini kullanarak uygulamalarınız içinde de sorgu çalıştırabilirsiniz.
Örneğin IoT Hub sorgularını uygulayan kod için Hizmet SDK'ları ile sorgu örnekleri bölümüne bakın.
SDK başvuru sayfalarının ve örneklerinin bağlantıları için bkz . Azure IoT SDK'ları.
IoT Hub sorgusunun temelleri
Her IoT Hub sorgusu, isteğe bağlı WHERE ve GROUP BY yan tümceleriyle SELECT ve FROM yan tümcelerinden oluşur.
Sorgular bir JSON belgeleri koleksiyonu üzerinde çalıştırılır, örneğin cihaz ikizleri. FROM yan tümcesi, üzerinde yinelenecek belge koleksiyonunu gösterir ( cihazlar, devices.modules veya devices.jobs).
Ardından WHERE yan tümcesindeki filtre uygulanır. Toplamalarda, bu adımın sonuçları GROUP BY yan tümcesinde belirtilen şekilde gruplandırılır. Her grup için SELECT yan tümcesinde belirtildiği gibi bir satır oluşturulur.
SELECT <select_list>
FROM <from_specification>
[WHERE <filter_condition>]
[GROUP BY <group_specification>]
SELECT yan tümcesi
SELECT <select_list> yan tümcesi her IoT Hub sorgusunda gereklidir. Sorgudan alınan değerleri belirtir. Yeni JSON nesneleri oluşturmak için kullanılacak JSON değerlerini belirtir. FROM koleksiyonunun filtrelenmiş (ve isteğe bağlı olarak gruplandırılmış) alt kümesinin her öğesi için projeksiyon aşaması yeni bir JSON nesnesi oluşturur. Bu nesne, SELECT yan tümcesinde belirtilen değerlerle oluşturulur.
Örneğin:
Tüm değerleri döndür
SELECT *
Belirli özellikleri döndürme
SELECT DeviceID, LastActivityTime
Sayı döndürmek için sorgunun sonuçlarını toplama
SELECT COUNT() as TotalNumber
Şu anda SELECT'ten farklı seçim yan tümceleri yalnızca cihaz ikizlerindeki toplama sorgularında desteklenmektedir.
Aşağıdaki söz dizimi, SELECT yan tümcesinin dil bilgisidir:
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, FROM koleksiyonundaki JSON belgesinin herhangi bir özelliğine başvurur.
FROM yan tümcesi
FROM <from_specification> yan tümcesi her ioT Hub sorgusunda gereklidir. Üç değerden biri olmalıdır:
- cihaz ikizlerini sorgulamak için cihazlar
- devices.modules to query module twins
- Cihaz başına iş ayrıntılarını sorgulamaya devices.jobs
Örneğin:
Tüm cihaz ikizlerini alma
SELECT * FROM devices
WHERE yan tümcesi
WHERE <filter_condition> yan tümcesi isteğe bağlıdır. FROM koleksiyonundaki JSON belgelerinin sonucun bir parçası olarak eklenmesi için karşılaması gereken bir veya daha fazla koşulu belirtir. Herhangi bir JSON belgesi, sonucun eklenmesi için belirtilen koşulları "true" olarak değerlendirmelidir.
Örneğin:
Belirli bir cihazı hedefleyen tüm işleri alma
SELECT * FROM devices.jobs WHERE devices.jobs.deviceId = 'myDeviceId'
İzin verilen koşullar ifadeler ve koşullar bölümünde açıklanmıştır.
GROUP BY yan tümcesi
GROUP BY <group_specification> yan tümcesi isteğe bağlıdır. Bu yan tümce WHERE yan tümcesinde belirtilen filtreden sonra ve SELECT'de belirtilen projeksiyondan önce yürütülür. Belgeleri bir özniteliğin değerine göre gruplandırıyor. Bu gruplar, SELECT yan tümcesinde belirtildiği gibi toplanmış değerler oluşturmak için kullanılır.
Örneğin:
Her telemetri yapılandırma durumunu bildiren cihazların sayısını döndürme
SELECT properties.reported.telemetryConfig.status AS status, COUNT() AS numberOfDevices FROM devices GROUP BY properties.reported.telemetryConfig.status
Şu anda GROUP BY yan tümcesi yalnızca cihaz ikizleri sorgulanırken desteklenmektedir.
Dikkat
Terim group
şu anda sorgularda özel bir anahtar sözcük olarak ele alınmakta. Özellik adınız olarak kullanıyorsanızgroup
, hataları önlemek için bunu çift köşeli ayraçla çevreleyin, örneğin. SELECT * FROM devices WHERE tags.[[group]].name = 'some_value'
GROUP BY için resmi söz dizimi şöyledir:
GROUP BY <group_by_element>
<group_by_element> :==
attribute_name
| < group_by_element > '.' attribute_name
Attribute_name, FROM koleksiyonundaki JSON belgesinin herhangi bir özelliğine başvurur.
Sorgu sonuçları sayfalaması
Sorgu nesnesi, 100 kayıttan küçük veya buna eşit maksimum sayfa boyutuyla oluşturulur. Birden çok sayfa elde etmek için Node.js SDK'da nextAsTwin veya .Net SDK'da GetNextAsTwinAsync yöntemini birden çok kez çağırın. Sorgu nesnesi, sorgunun gerektirdiği seri durumdan çıkarma seçeneğine bağlı olarak birden çok Sonraki değeri kullanıma açabilir. Örneğin, bir sorgu nesnesi projeksiyonları kullanırken cihaz ikizi veya iş nesneleri ya da düz JSON döndürebilir.
İfadeler ve koşullar
Yüksek düzeyde bir ifade:
- Bir JSON türünün örneğini (Boole, sayı, dize, dizi veya nesne gibi) değerlendirir.
- Cihaz JSON belgesinden gelen veriler ve yerleşik işleçler ve işlevler kullanılarak sabitler kullanılarak tanımlanır.
Koşullar , Boole değeri veren ifadelerdir. Boolean true değerinden farklı sabitler false olarak kabul edilir. Bu kural null, tanımsız, herhangi bir nesne veya dizi örneği, herhangi bir dize ve Boole false içerir.
İfadelerin söz dizimi şöyledir:
<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>]+ ']'
İfade söz dizimindeki her simgenin ne anlama gelir anlamak için aşağıdaki tabloya bakın:
Simge | Tanım |
---|---|
attribute_name | FROM koleksiyonundaki JSON belgesinin herhangi bir özelliği. |
binary_operator | İşleçler bölümünde listelenen herhangi bir ikili işleç . |
function_name | İşlevler bölümünde listelenen herhangi bir işlev. |
decimal_literal | Ondalık gösterimiyle ifade edilen bir float. |
hexadecimal_literal | '0x' dizesiyle ve ardından onaltılık basamak dizesiyle ifade edilen bir sayı. |
string_literal | Sıfır veya daha fazla Unicode karakteri veya kaçış dizisiyle temsil edilen Unicode dizeleri. Dize değişmez değerleri tek tırnak veya çift tırnak içine alınır. İzin verilen çıkışlar: \' \" dört onaltılık basamak tarafından tanımlanan Unicode karakterleri için , , \\ , \uXXXX . |
İşleçler
Aşağıdaki işleçler desteklenir:
Aile | İşleçler |
---|---|
Aritmetik | +, -, *, /, % |
Mantıksal | VE VEYA DEĞİl |
Karşılaştırma | =, !=, <, >, <=, >=, <> |
İşlevler
İkizleri ve işleri sorgularken desteklenen tek işlev:
İşlev | Açıklama |
---|---|
IS_DEFINED(özellik) | Özelliğine bir değer atanıp atanmadığını gösteren bir Boole döndürür (dahil null ). |
Rota koşullarında aşağıdaki matematik işlevleri desteklenir:
İşlev | Açıklama |
---|---|
ABS(x) | Belirtilen sayısal ifadenin mutlak (pozitif) değerini döndürür. |
EXP(x) | Belirtilen sayısal ifadenin (e^x) üstel değerini döndürür. |
POWER(x,y) | Belirtilen ifadenin değerini belirtilen güce (x^y) döndürür. |
KARE(x) | Belirtilen sayısal değerin karesini döndürür. |
TAVANAYUVARLA(x) | Belirtilen sayısal ifadeden büyük veya buna eşit en küçük tamsayı değerini döndürür. |
TABANAYUVARLA(x) | Belirtilen sayısal ifadeden küçük veya buna eşit en büyük tamsayıyı döndürür. |
SIGN(x) | Belirtilen sayısal ifadenin pozitif (+1), sıfır (0) veya negatif (-1) işaretini döndürür. |
KAREKÖK(x) | Belirtilen sayısal değerin karekökünü döndürür. |
Rota koşullarında aşağıdaki tür denetimi ve atama işlevleri desteklenir:
İşlev | Açıklama |
---|---|
AS_NUMBER | Giriş dizesini sayıya dönüştürür. noop giriş bir sayıysa; Undefined dize bir sayıyı temsil etmiyorsa. |
IS_ARRAY | Belirtilen ifadenin türünün bir dizi olup olmadığını belirten bir Boole değeri döndürür. |
IS_BOOL | Belirtilen ifadenin türünün Boole değeri olup olmadığını belirten bir Boole değeri döndürür. |
IS_DEFINED | Özelliğe bir değer atanıp atanmadığını gösteren bir Boole döndürür. Bu işlev yalnızca değer ilkel bir tür olduğunda desteklenir. İlkel türler dize, Boole, sayısal veya null 'dır. DateTime, nesne türleri ve diziler desteklenmez. |
IS_NULL | Belirtilen ifadenin türünün null olup olmadığını belirten bir Boole değeri döndürür. |
IS_NUMBER | Belirtilen ifadenin türünün bir sayı olup olmadığını belirten bir Boole değeri döndürür. |
IS_OBJECT | Belirtilen ifadenin türünün bir JSON nesnesi olup olmadığını belirten bir Boole değeri döndürür. |
IS_PRIMITIVE | Belirtilen ifadenin türünün ilkel (dize, Boole, sayısal veya null ) olup olmadığını belirten bir Boole değeri döndürür. |
IS_STRING | Belirtilen ifadenin türünün bir dize olup olmadığını belirten bir Boole değeri döndürür. |
Yol koşullarında aşağıdaki dize işlevleri desteklenir:
İşlev | Açıklama |
---|---|
ARALIKBİRLEŞTRİ(x, y, ...) | İki veya daha fazla dize değerini birleştirmenin sonucu olan bir dize döndürür. |
UZUNLUK(x) | Belirtilen dize ifadesinin karakter sayısını döndürür. |
LOWER(x) | Büyük harf karakter verilerini küçük harfe dönüştürdükten sonra bir dize ifadesi döndürür. |
UPPER(x) | Küçük harf karakter verilerini büyük harfe dönüştürdükten sonra bir dize ifadesi döndürür. |
SUBSTRING(dize, start [, length]) | Belirtilen karakter sıfır tabanlı konumdan başlayarak dize ifadesinin bir bölümünü döndürür ve belirtilen uzunluğa veya dizenin sonuna kadar devam eder. |
INDEX_OF(dize, parça) | belirtilen ilk dize ifadesinde ikinci dize ifadesinin ilk oluşumunun başlangıç konumunu veya dize bulunamazsa -1 döndürür. |
STARTSWITH(x, y) | İlk dize ifadesinin ikincisiyle başlayıp başlamadığını gösteren bir Boole döndürür. |
ENDSWITH(x, y) | İlk dize ifadesinin ikincisiyle bitip bitmediğini belirten bir Boole döndürür. |
CONTAINS(x,y) | İlk dize ifadesinin ikincisini içerip içermediğini belirten bir Boole döndürür. |
Hizmet SDK'ları ile sorgu örnekleri
C# örneği
Sorgu işlevi, RegistryManager sınıfında C# hizmet SDK'sı tarafından kullanıma sunulur.
Basit bir sorgu örneği aşağıda verilmişti:
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
}
}
Sorgu nesnesi, sorgu sonuçları sayfalandırma bölümünde belirtilen parametrelerle oluşturulur. GetNextAsTwinAsync yöntemleri birden çok kez çağrılarak birden çok sayfa alınır.
Node.js örnek
Sorgu işlevi, Kayıt Defteri nesnesindeki Node.js için Azure IoT hizmet SDK'sı tarafından kullanıma sunulur.
Basit bir sorgu örneği aşağıda verilmişti:
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);
Sorgu nesnesi, sorgu sonuçları sayfalandırma bölümünde belirtilen parametrelerle oluşturulur. nextAsTwin yöntemi birden çok kez çağrılarak birden çok sayfa alınır.
Sonraki adımlar
- IoT Hub ileti yönlendirme sorgusu söz dizimi ile ileti özelliklerine veya ileti gövdesine göre iletileri yönlendirme hakkında bilgi edinin.
- Cihaz ve modül ikizleri için sorgular veya İşler için sorgular ile ilgili belirli örnekleri alın.