Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
Sürüm açılan listesini kullanarak hizmetler arasında geçiş yapın. Gezinti hakkında daha fazla bilgi edinin.
Şunlar için geçerlidir: ✅ Microsoft Fabric ✅ Azure Veri Gezgini
Verilen adla yeniden kullanılabilir bir KQL sorgusu olan saklı bir işlev oluşturur. İşlev tanımı veritabanı meta verileriyle kalıcı hale eklenir.
İşlevler diğer işlevleri çağırabilir (özyineleme desteklenmez). Ayrıca, let deyimlere İşlev Gövdesi'nin bir parçası olarak izin verilir. Bkz let . deyimler.
Parametre türleri ve CSL deyimleri için kurallar deyimleriylelet.
İzinler
Bu komutu çalıştırmak için en az Veritabanı Kullanıcısı izinlerine sahip olmanız gerekir.
Sözdizimi
.create
function [ ifnotexists ] [ with(propertyName=propertyValue [, ...]) ] functionName( parameters gövdesi){}
Söz dizimi kuralları hakkında daha fazla bilgi edinin.
Parametreler
| Ad | Tür | Zorunlu | Açıklama |
|---|---|---|---|
ifnotexists |
string |
Belirtilirse, işlev yalnızca işlev henüz mevcut değilse oluşturulur. | |
| functionName | string |
✔️ | Oluşturulacak veya değiştirecek işlevin adı. |
| propertyName, propertyValue | string |
Anahtar-değer özellik çiftlerinin virgülle ayrılmış listesi. Desteklenen özelliklere bakın. | |
| parametreler | string |
İşlev için gereken parametrelerin virgülle ayrılmış listesi. Her parametrenin biçimi ParameterName | |
| gövde | string |
✔️ | Kullanıcı tanımlı işlev ifadesi. |
Desteklenen özellikler
| Ad | Tür | Açıklama |
|---|---|---|
docstring |
string |
Kullanıcı arabirimi amacıyla işlevin açıklaması. |
folder |
string |
KULLANıCı arabirimi işlevleri kategorilere ayırma için kullanılan bir klasörün adı. |
view |
bool |
Bu işlevi depolanmış görünüm olarak gösterir. Depolanan görünümler arama ve birleşim * senaryolarına katılabilir. Daha fazla bilgi için bkz . Görünümler. |
skipvalidation |
bool |
İşlevde doğrulama mantığı çalıştırılıp çalıştırılmayacağını belirler ve işlev geçerli değilse işlem başarısız olur. Varsayılan değer: false. |
İpucu
Bir işlev kümeler arası sorgular içeriyorsa ve bir Kusto Sorgu Dili betiği kullanarak işlevi yeniden oluşturmayı planlıyorsanız olarak ayarlayınskipvalidation.true
Döndürülenler
| Çıkış parametresi | Tür | Açıklama |
|---|---|---|
| Ad | string |
İşlevin adı. |
| Parametreler | string |
İşlevin gerektirdiği parametreler. |
| Gövde | string |
(Sıfır veya daha fazla) let deyimleri ve ardından işlev çağrısı üzerine değerlendirilen geçerli bir CSL ifadesi. |
| Klasör | string |
KULLANıCı arabirimi işlevleri kategorilere ayırma için kullanılan bir klasör. Bu parametre işlevin çağrılma şeklini değiştirmez. |
| DocString | string |
Kullanıcı arabirimi amacıyla işlevin açıklaması. |
Not
- İşlev zaten varsa:
- Bayrak belirtilirse
ifnotexists, komut yoksayılır (değişiklik uygulanmaz). - Bayrak belirtilmezse
ifnotexistsbir hata döndürülür. - Mevcut bir işlevi değiştirmek için bkz.
.alter function
- Bayrak belirtilirse
- Deyimlerde
lettüm veri türleri desteklenmez. Desteklenen türler şunlardır: boole, dize, uzun, tarih saat, zaman aralığı, çift ve dinamik. - İşlevin anlam doğrulamasını atlamak için kullanın
skipvalidation. İşlevler yanlış sırada oluşturulduğunda ve F2 kullanan F1 daha önce oluşturulduğunda bu kullanışlıdır.
Örnekler
Basit işlev
Aşağıdaki örnek, adlı bir klasör MyFunction1olan bir açıklama ()docstring ile işlevi oluşturur Demo ve işlevi tanımlar.
.create function
with (docstring = 'Simple demo function', folder='Demo')
MyFunction1()
{StormEvents | take 100}
| Ad | Parametreler | Gövde | Klasör | DocString |
|---|---|---|---|---|
| MyFunction1 | () | {StormEvents | take 100} | Tanıtım | Basit tanıtım işlevi |
Parametreli işlev
Aşağıdaki örnek, MyFunction2 işlevini docstringadlı bir açıklama (Demo) klasörüyle oluşturur ve Mytimestamp parametresini tanımlar.
.create function with (docstring = "Demo function with date parameter",folder = "Demo")
MyFunction2(Mytimestamp:datetime) {
StormEvents
| where EndTime <= Mytimestamp
}
| Ad | Parametreler | Gövde | Klasör | DocString |
|---|---|---|---|---|
| MyFunction2 | (Mytimestamp:datetime) | {StormEvents | where EndTime <= Mytimestamp} | Tanıtım | Tarih parametresiyle demo işlevi |