ClickHouse/docs/tr/sql-reference/functions/array-functions.md
2020-10-13 20:23:29 +03:00

32 KiB
Raw Blame History

machine_translated machine_translated_rev toc_priority toc_title
true 72537a2d52 46 Dizilerle çalışma

Dizilerle çalışmak için işlevler

boş

Boş bir dizi için 1 veya boş olmayan bir dizi için 0 döndürür. Sonuç türü Uint8'dir. İşlev ayrıca dizeler için de çalışır.

notEmpty

Boş bir dizi için 0 veya boş olmayan bir dizi için 1 döndürür. Sonuç türü Uint8'dir. İşlev ayrıca dizeler için de çalışır.

uzunluk

Dizideki öğe sayısını döndürür. Sonuç türü Uint64'tür. İşlev ayrıca dizeler için de çalışır.

emptyArrayUİnt8, emptyArrayUİnt16, emptyArrayUİnt32, emptyArrayUİnt64

emptyArrayİnt8, emptyArrayİnt16, emptyArrayİnt32, emptyArrayİnt64

emptyArrayFloat32, emptyArrayFloat64

emptyArrayDate, emptyArrayDateTime

emptyArrayString

Sıfır bağımsız değişkeni kabul eder ve uygun türde boş bir dizi döndürür.

emptyArrayToSingle

Boş bir dizi kabul eder ve varsayılan değere eşit bir tek öğe dizisi döndürür.

Aralık (bitiş), Aralık(başlangıç, bitiş [, adım])

1 Adım-başından sonuna kadar sayıların bir dizi döndürür. Eğer argüman start belirtilmemiş, varsayılan olarak 0. Eğer argüman step belirtilmemiş, varsayılan olarak 1. Neredeyse pythonic gibi davranışlar range. Ancak fark, tüm argümanların tipinin olması gerektiğidir UInt şiir. Bir veri bloğunda toplam uzunluğu 100.000.000'den fazla öğe olan diziler oluşturulursa, bir istisna atılır.

array(x1, …), operator [x1, …]

İşlev bağımsız değişkenlerinden bir dizi oluşturur. Bağımsız değişkenler sabit olmalı ve en küçük ortak türe sahip türlere sahip olmalıdır. En az bir argüman geçirilmelidir, çünkü aksi takdirde hangi tür dizinin oluşturulacağıık değildir. Yani, boş bir dizi oluşturmak için bu işlevi kullanamazsınız (bunu yapmak için, emptyArray* fonksiyon yukarıda açıklandığı. Ret anur anns an Array(T) sonucu yazın, nerede T geçirilen bağımsız değişkenlerin en küçük ortak türüdür.

arrayConcat

Argüman olarak geçirilen dizileri birleştirir.

arrayConcat(arrays)

Parametre

  • arrays Arbitrary number of arguments of Dizi tür. Örnek
SELECT arrayConcat([1, 2], [3, 4], [5, 6]) AS res
┌─res───────────┐
│ [1,2,3,4,5,6] │
└───────────────┘

arrayElement (arr, n), operatör arr[n]

İnd theex ile eleman alın n diz theiden arr. n herhangi bir tamsayı türü olmalıdır. Bir dizideki dizinler birinden başlar. Negatif dizinler desteklenir. Bu durumda, sondan numaralandırılmış ilgili elemanı seçer. Mesela, arr[-1] dizideki son öğedir.

Dizin bir dizinin sınırlarının dışına düşerse, bazı varsayılan değer döndürür (sayılar için 0, dizeler için boş bir dize vb.).), sabit olmayan bir dizi ve sabit bir dizin 0 olan durum hariç (bu durumda bir hata olacaktır Array indices are 1-based).

has (arr, elem)

Olup olmadığını denetler arr dizi var elem öğe. Öğe dizide değilse 0 veya varsa 1 değerini döndürür.

NULL değer olarak iş islenir.

SELECT has([1, 2, NULL], NULL)
┌─has([1, 2, NULL], NULL)─┐
│                       1 │
└─────────────────────────┘

hasAll

Bir dizi başka bir alt kümesi olup olmadığını denetler.

hasAll(set, subset)

Parametre

  • set Array of any type with a set of elements.
  • subset Array of any type with elements that should be tested to be a subset of set.

Dönüş değerleri

  • 1, eğer set tüm öğeleri içerir subset.
  • 0, başka.

Tuhaf özellikler

  • Boş bir dizi, herhangi bir dizinin bir alt kümesidir.
  • Null bir değer olarak işlenir.
  • Her iki dizideki değerlerin sırası önemli değil.

Örnekler

SELECT hasAll([], []) döner 1.

SELECT hasAll([1, Null], [Null]) döner 1.

SELECT hasAll([1.0, 2, 3, 4], [1, 3]) döner 1.

SELECT hasAll(['a', 'b'], ['a']) döner 1.

SELECT hasAll([1], ['a']) 0 döndürür.

SELECT hasAll([[1, 2], [3, 4]], [[1, 2], [3, 5]]) 0 döndürür.

hasAny

İki dizinin bazı öğelerle kesiştiği olup olmadığını kontrol eder.

hasAny(array1, array2)

Parametre

  • array1 Array of any type with a set of elements.
  • array2 Array of any type with a set of elements.

Dönüş değerleri

  • 1, eğer array1 ve array2 en azından benzer bir öğeye sahip olun.
  • 0, başka.

Tuhaf özellikler

  • Null bir değer olarak işlenir.
  • Her iki dizideki değerlerin sırası önemli değil.

Örnekler

SELECT hasAny([1], []) dönüşler 0.

SELECT hasAny([Null], [Null, 1]) dönüşler 1.

SELECT hasAny([-128, 1., 512], [1]) dönüşler 1.

SELECT hasAny([[1, 2], [3, 4]], ['a', 'c']) dönüşler 0.

SELECT hasAll([[1, 2], [3, 4]], [[1, 2], [1, 2]]) dönüşler 1.

ındexof(arr, x)

İlk dizini döndürür x dizide ise öğe (1'den başlayarak) veya değilse 0.

Örnek:

SELECT indexOf([1, 3, NULL, NULL], NULL)
┌─indexOf([1, 3, NULL, NULL], NULL)─┐
│                                 3 │
└───────────────────────────────────┘

Elem setents set to NULL normal değerler olarak ele alınır.

countEqual(arr, x)

X eşit dizideki öğelerin sayısını döndürür. Arraycount eşdeğer (elem - > elem = x, arr).

NULL öğeler ayrı değerler olarak işlenir.

Örnek:

SELECT countEqual([1, 2, NULL, NULL], NULL)
┌─countEqual([1, 2, NULL, NULL], NULL)─┐
│                                    2 │
└──────────────────────────────────────┘

arrayEnumerate(arr)

Returns the array [1, 2, 3, …, length (arr) ]

Bu işlev normalde ARRAY JOIN ile kullanılır. ARRAY JOİN uyguladıktan sonra her dizi için sadece bir kez bir şey saymaya izin verir. Örnek:

SELECT
    count() AS Reaches,
    countIf(num = 1) AS Hits
FROM test.hits
ARRAY JOIN
    GoalsReached,
    arrayEnumerate(GoalsReached) AS num
WHERE CounterID = 160656
LIMIT 10
┌─Reaches─┬──Hits─┐
│   95606 │ 31406 │
└─────────┴───────┘

Bu örnekte, Reaches dönüşümlerin sayısıdır (ARRAY JOİN uygulandıktan sonra alınan dizeler) ve İsabetler sayfa görüntüleme sayısıdır (ARRAY JOİN önce dizeler). Bu özel durumda, aynı sonucu daha kolay bir şekilde alabilirsiniz:

SELECT
    sum(length(GoalsReached)) AS Reaches,
    count() AS Hits
FROM test.hits
WHERE (CounterID = 160656) AND notEmpty(GoalsReached)
┌─Reaches─┬──Hits─┐
│   95606 │ 31406 │
└─────────┴───────┘

Bu fonksiyon aynı zamanda yüksek mertebeden fonksiyonlarda da kullanılabilir. Örneğin, bir koşulla eşleşen öğeler için dizi dizinleri almak için kullanabilirsiniz.

arrayEnumerateUniq(arr, …)

Kaynak diziyle aynı boyutta bir dizi döndürür ve her öğe için aynı değere sahip öğeler arasında konumunun ne olduğunu gösterir. Örneğin: arrayEnumerateUniq([10, 20, 10, 30]) = [1, 1, 2, 1].

Bu işlev, dizi birleştirme ve dizi öğelerinin toplanmasını kullanırken kullanışlıdır. Örnek:

SELECT
    Goals.ID AS GoalID,
    sum(Sign) AS Reaches,
    sumIf(Sign, num = 1) AS Visits
FROM test.visits
ARRAY JOIN
    Goals,
    arrayEnumerateUniq(Goals.ID) AS num
WHERE CounterID = 160656
GROUP BY GoalID
ORDER BY Reaches DESC
LIMIT 10
┌──GoalID─┬─Reaches─┬─Visits─┐
│   53225 │    3214 │   1097 │
│ 2825062 │    3188 │   1097 │
│   56600 │    2803 │    488 │
│ 1989037 │    2401 │    365 │
│ 2830064 │    2396 │    910 │
│ 1113562 │    2372 │    373 │
│ 3270895 │    2262 │    812 │
│ 1084657 │    2262 │    345 │
│   56599 │    2260 │    799 │
│ 3271094 │    2256 │    812 │
└─────────┴─────────┴────────┘

Bu örnekte, her hedef kimliğinin dönüşüm sayısı (hedefler iç içe geçmiş veri yapısındaki her öğe, bir dönüşüm olarak adlandırdığımız ulaşılan bir hedeftir) ve oturum sayısı Hesaplaması vardır. ARRAY JOİN olmadan, oturum sayısını sum(Sign) olarak sayardık. Ancak bu özel durumda, satırlar iç içe geçmiş hedefler yapısıyla çarpıldı, bu nedenle her oturumu bir kez saymak için arrayenumerateuniq değerine bir koşul uyguluyoruz(Goals.ID) fonksiyonu.

Arrayenumerateuniq işlevi, bağımsız değişkenlerle aynı boyutta birden çok dizi alabilir. Bu durumda, tüm dizilerde aynı konumlardaki elemanların tuplesleri için benzersizlik düşünülür.

SELECT arrayEnumerateUniq([1, 1, 1, 2, 2, 2], [1, 1, 2, 1, 1, 2]) AS res
┌─res───────────┐
│ [1,2,1,1,2,1] │
└───────────────┘

Bu, iç içe geçmiş bir veri yapısı ve bu yapıdaki birden çok öğe arasında daha fazla toplama ile dizi birleşimini kullanırken gereklidir.

arrayPopBack

Son öğeyi diziden kaldırır.

arrayPopBack(array)

Parametre

  • array Array.

Örnek

SELECT arrayPopBack([1, 2, 3]) AS res
┌─res───┐
│ [1,2] │
└───────┘

arrayPopFront

İlk öğeyi diziden kaldırır.

arrayPopFront(array)

Parametre

  • array Array.

Örnek

SELECT arrayPopFront([1, 2, 3]) AS res
┌─res───┐
│ [2,3] │
└───────┘

arrayPushBack

Dizinin sonuna bir öğe ekler.

arrayPushBack(array, single_value)

Parametre

  • array Array.
  • single_value A single value. Only numbers can be added to an array with numbers, and only strings can be added to an array of strings. When adding numbers, ClickHouse automatically sets the single_value dizinin veri türü için yazın. Clickhouse'daki veri türleri hakkında daha fazla bilgi için bkz. “Veri türleri”. Olabilir NULL. Fonksiyon bir ekler NULL bir dizi için öğe ve dizi öğeleri türü dönüştürür Nullable.

Örnek

SELECT arrayPushBack(['a'], 'b') AS res
┌─res───────┐
│ ['a','b'] │
└───────────┘

arrayPushFront

Dizinin başına bir öğe ekler.

arrayPushFront(array, single_value)

Parametre

  • array Array.
  • single_value A single value. Only numbers can be added to an array with numbers, and only strings can be added to an array of strings. When adding numbers, ClickHouse automatically sets the single_value dizinin veri türü için yazın. Clickhouse'daki veri türleri hakkında daha fazla bilgi için bkz. “Veri türleri”. Olabilir NULL. Fonksiyon bir ekler NULL bir dizi için öğe ve dizi öğeleri türü dönüştürür Nullable.

Örnek

SELECT arrayPushFront(['b'], 'a') AS res
┌─res───────┐
│ ['a','b'] │
└───────────┘

arrayResize

Dizinin uzunluğunu değiştirir.

arrayResize(array, size[, extender])

Parametre:

  • array — Array.
  • size — Required length of the array.
    • Eğer size dizinin orijinal boyutundan daha az, dizi sağdan kesilir.
  • Eğer size dizinin başlangıç boyutundan daha büyük, dizi sağa uzatılır extender dizi öğelerinin veri türü için değerler veya varsayılan değerler.
  • extender — Value for extending an array. Can be NULL.

Döndürülen değer:

Bir dizi uzunluk size.

Arama örnekleri

SELECT arrayResize([1], 3)
┌─arrayResize([1], 3)─┐
│ [1,0,0]             │
└─────────────────────┘
SELECT arrayResize([1], 3, NULL)
┌─arrayResize([1], 3, NULL)─┐
│ [1,NULL,NULL]             │
└───────────────────────────┘

arraySlice

Dizinin bir dilimini döndürür.

arraySlice(array, offset[, length])

Parametre

  • array Array of data.
  • offset Indent from the edge of the array. A positive value indicates an offset on the left, and a negative value is an indent on the right. Numbering of the array items begins with 1.
  • length - Gerekli dilimin uzunluğu. Negatif bir değer belirtirseniz, işlev açık bir dilim döndürür [offset, array_length - length). Değeri atlarsanız, işlev dilimi döndürür [offset, the_end_of_array].

Örnek

SELECT arraySlice([1, 2, NULL, 4, 5], 2, 3) AS res
┌─res────────┐
│ [2,NULL,4] │
└────────────┘

Ar arrayray elem toents set to NULL normal değerler olarak ele alınır.

arraySort([func,] arr, …)

Elemanları sıralar arr artan düzende dizi. Eğer... func fonksiyonu belirtilir, sıralama düzeni sonucu belirlenir func fonksiyon dizinin elemanlarına uygulanır. Eğer func birden fazla argüman kabul eder, arraySort fonksiyon argümanları birkaç diziler geçirilir func karşılık gelir. Ayrıntılı örnekler sonunda gösterilir arraySortıklama.

Tamsayı değerleri sıralama örneği:

SELECT arraySort([1, 3, 3, 0]);
┌─arraySort([1, 3, 3, 0])─┐
│ [0,1,3,3]               │
└─────────────────────────┘

Dize değerleri sıralama örneği:

SELECT arraySort(['hello', 'world', '!']);
┌─arraySort(['hello', 'world', '!'])─┐
│ ['!','hello','world']              │
└────────────────────────────────────┘

Aşağıdaki sıralama sırasını göz önünde bulundurun NULL, NaN ve Inf değerler:

SELECT arraySort([1, nan, 2, NULL, 3, nan, -4, NULL, inf, -inf]);
┌─arraySort([1, nan, 2, NULL, 3, nan, -4, NULL, inf, -inf])─┐
│ [-inf,-4,1,2,3,inf,nan,nan,NULL,NULL]                     │
└───────────────────────────────────────────────────────────┘
  • -Inf değerler dizide ilk sırada yer alır.
  • NULL değerler dizideki son değerlerdir.
  • NaN değerler hemen önce NULL.
  • Inf değerler hemen önce NaN.

Not thate that arraySort is a yüksek sipariş fonksiyonu. Bir lambda işlevini ilk argüman olarak iletebilirsiniz. Bu durumda, sıralama sırası, dizinin elemanlarına uygulanan lambda işlevinin sonucu ile belirlenir.

Aşağıdaki örneği ele alalım:

SELECT arraySort((x) -> -x, [1, 2, 3]) as res;
┌─res─────┐
│ [3,2,1] │
└─────────┘

For each element of the source array, the lambda function returns the sorting key, that is, [1 > -1, 2 > -2, 3 > -3]. Since the arraySort fonksiyon tuşları artan sırayla sıralar, sonuç [3, 2, 1]. Böylece, (x) > -x lambda fonksiyonu setleri azalan düzen bir sıralama içinde.

Lambda işlevi birden çok bağımsız değişken kabul edebilir. Bu durumda, geçmek gerekir arraySort işlev lambda işlevinin argümanlarının karşılık geleceği aynı uzunlukta birkaç dizi. Elde edilen dizi ilk giriş dizisinden elemanlardan oluşacaktır; bir sonraki giriş dizilerinden elemanlar sıralama anahtarlarını belirtir. Mesela:

SELECT arraySort((x, y) -> y, ['hello', 'world'], [2, 1]) as res;
┌─res────────────────┐
│ ['world', 'hello'] │
└────────────────────┘

Burada, ikinci dizide ([2, 1]) geçirilen öğeler, kaynak diziden karşılık gelen öğe için bir sıralama anahtarı tanımlar ([hello, world]), bu, [hello > 2, world > 1]. Since the lambda function doesn't use x, kaynak dizinin gerçek değerleri sonuçtaki sırayı etkilemez. Böyle, hello sonuçtaki ikinci eleman olacak ve world ilk olacak.

Diğer örnekler aşağıda gösterilmiştir.

SELECT arraySort((x, y) -> y, [0, 1, 2], ['c', 'b', 'a']) as res;
┌─res─────┐
│ [2,1,0] │
└─────────┘
SELECT arraySort((x, y) -> -y, [0, 1, 2], [1, 2, 3]) as res;
┌─res─────┐
│ [2,1,0] │
└─────────┘

!!! note "Not" Sıralama verimliliğini artırmak için, Schwartzian dönüşümü kullanılır.

arrayReverseSort([func,] arr, …)

Elemanları sıralar arr azalan sırayla dizi. Eğer... func fonksiyon belirtilir, arr sonucuna göre sıra islanır. func işlev dizinin öğelerine uygulanır ve sonra sıralanmış dizi tersine çevrilir. Eğer func birden fazla argüman kabul eder, arrayReverseSort fonksiyon argümanları birkaç diziler geçirilir func karşılık gelir. Ayrıntılı örnekler sonunda gösterilir arrayReverseSortıklama.

Tamsayı değerleri sıralama örneği:

SELECT arrayReverseSort([1, 3, 3, 0]);
┌─arrayReverseSort([1, 3, 3, 0])─┐
│ [3,3,1,0]                      │
└────────────────────────────────┘

Dize değerleri sıralama örneği:

SELECT arrayReverseSort(['hello', 'world', '!']);
┌─arrayReverseSort(['hello', 'world', '!'])─┐
│ ['world','hello','!']                     │
└───────────────────────────────────────────┘

Aşağıdaki sıralama sırasını göz önünde bulundurun NULL, NaN ve Inf değerler:

SELECT arrayReverseSort([1, nan, 2, NULL, 3, nan, -4, NULL, inf, -inf]) as res;
┌─res───────────────────────────────────┐
│ [inf,3,2,1,-4,-inf,nan,nan,NULL,NULL] │
└───────────────────────────────────────┘
  • Inf değerler dizide ilk sırada yer alır.
  • NULL değerler dizideki son değerlerdir.
  • NaN değerler hemen önce NULL.
  • -Inf değerler hemen önce NaN.

Not arrayReverseSort is a yüksek sipariş fonksiyonu. Bir lambda işlevini ilk argüman olarak iletebilirsiniz. Örnek aşağıda gösterilmiştir.

SELECT arrayReverseSort((x) -> -x, [1, 2, 3]) as res;
┌─res─────┐
│ [1,2,3] │
└─────────┘

Dizi aşağıdaki şekilde sıralanır:

  1. İlk başta, kaynak dizi ([1, 2, 3]), dizinin elemanlarına uygulanan lambda işlevinin sonucuna göre sıralanır. Sonuç bir dizidir [3, 2, 1].
  2. Önceki adımda elde edilen dizi tersine çevrilir. Yani, nihai sonuç [1, 2, 3].

Lambda işlevi birden çok bağımsız değişken kabul edebilir. Bu durumda, geçmek gerekir arrayReverseSort işlev lambda işlevinin argümanlarının karşılık geleceği aynı uzunlukta birkaç dizi. Elde edilen dizi ilk giriş dizisinden elemanlardan oluşacaktır; bir sonraki giriş dizilerinden elemanlar sıralama anahtarlarını belirtir. Mesela:

SELECT arrayReverseSort((x, y) -> y, ['hello', 'world'], [2, 1]) as res;
┌─res───────────────┐
│ ['hello','world'] │
└───────────────────┘

Bu örnekte, dizi aşağıdaki şekilde sıralanır:

  1. İlk başta, kaynak dizi ([hello, world]) dizilerin elemanlarına uygulanan lambda işlevinin sonucuna göre sıralanır. İkinci dizide geçirilen öğeler ([2, 1]), kaynak diziden karşılık gelen öğeler için sıralama anahtarlarını tanımlar. Sonuç bir dizidir [world, hello].
  2. Önceki adımda sıralanmış dizi tersine çevrilir. Yani, nihai sonuç [hello, world].

Diğer örnekler aşağıda gösterilmiştir.

SELECT arrayReverseSort((x, y) -> y, [4, 3, 5], ['a', 'b', 'c']) AS res;
┌─res─────┐
│ [5,3,4] │
└─────────┘
SELECT arrayReverseSort((x, y) -> -y, [4, 3, 5], [1, 2, 3]) AS res;
┌─res─────┐
│ [4,3,5] │
└─────────┘

arrayUniq(arr, …)

Bir bağımsız değişken geçirilirse, dizideki farklı öğelerin sayısını sayar. Birden çok bağımsız değişken geçirilirse, birden çok dizideki karşılık gelen konumlardaki farklı öğe kümelerinin sayısını sayar.

Bir dizideki benzersiz öğelerin bir listesini almak istiyorsanız, arrayreduce kullanabilirsiniz(groupUniqArray, arr).

arrayJoin(arr)

Özel bir işlev. Bölümüne bakınız “ArrayJoin function”.

arrayDifference

Bitişik dizi öğeleri arasındaki farkı hesaplar. İlk öğenin 0 olacağı bir dizi döndürür, ikincisi arasındaki farktır a[1] - a[0], etc. The type of elements in the resulting array is determined by the type inference rules for subtraction (e.g. UInt8 - UInt8 = Int16).

Sözdizimi

arrayDifference(array)

Parametre

Döndürülen değerler

Bitişik öğeler arasındaki farklar dizisini döndürür.

Tür: Uİnt*, Tamsayı*, Yüzdürmek*.

Örnek

Sorgu:

SELECT arrayDifference([1, 2, 3, 4])

Sonuç:

┌─arrayDifference([1, 2, 3, 4])─┐
│ [0,1,1,1]                     │
└───────────────────────────────┘

Sonuç türü Int64 nedeniyle taşma örneği:

Sorgu:

SELECT arrayDifference([0, 10000000000000000000])

Sonuç:

┌─arrayDifference([0, 10000000000000000000])─┐
│ [0,-8446744073709551616]                   │
└────────────────────────────────────────────┘

arrayDistinct

Bir dizi alır, yalnızca farklı öğeleri içeren bir dizi döndürür.

Sözdizimi

arrayDistinct(array)

Parametre

Döndürülen değerler

Farklı öğeleri içeren bir dizi döndürür.

Örnek

Sorgu:

SELECT arrayDistinct([1, 2, 2, 3, 1])

Sonuç:

┌─arrayDistinct([1, 2, 2, 3, 1])─┐
│ [1,2,3]                        │
└────────────────────────────────┘

arrayEnumerateDense(arr)

Kaynak diziyle aynı boyutta bir dizi döndürür ve her öğenin kaynak dizide ilk olarak nerede göründüğünü gösterir.

Örnek:

SELECT arrayEnumerateDense([10, 20, 10, 30])
┌─arrayEnumerateDense([10, 20, 10, 30])─┐
│ [1,2,1,3]                             │
└───────────────────────────────────────┘

arrayıntersect(arr)

Birden çok dizi alır, tüm kaynak dizilerde bulunan öğeleri içeren bir dizi döndürür. Elde edilen dizideki öğeler sırası ilk dizideki ile aynıdır.

Örnek:

SELECT
    arrayIntersect([1, 2], [1, 3], [2, 3]) AS no_intersect,
    arrayIntersect([1, 2], [1, 3], [1, 4]) AS intersect
┌─no_intersect─┬─intersect─┐
│ []           │ [1]       │
└──────────────┴───────────┘

arrayReduce

Dizi öğelerine bir toplama işlevi uygular ve sonucunu döndürür. Toplama işlevinin adı, tek tırnak içinde bir dize olarak geçirilir 'max', 'sum'. Parametrik toplama işlevleri kullanıldığında, parametre parantez içinde işlev adından sonra gösterilir 'uniqUpTo(6)'.

Sözdizimi

arrayReduce(agg_func, arr1, arr2, ..., arrN)

Parametre

  • agg_func — The name of an aggregate function which should be a constant dize.
  • arr — Any number of dizi sütunları toplama işlevinin parametreleri olarak yazın.

Döndürülen değer

Örnek

SELECT arrayReduce('max', [1, 2, 3])
┌─arrayReduce('max', [1, 2, 3])─┐
│                             3 │
└───────────────────────────────┘

Bir toplama işlevi birden çok bağımsız değişken alırsa, bu işlev aynı boyuttaki birden çok diziye uygulanmalıdır.

SELECT arrayReduce('maxIf', [3, 5], [1, 0])
┌─arrayReduce('maxIf', [3, 5], [1, 0])─┐
│                                    3 │
└──────────────────────────────────────┘

Parametrik toplama fonksiyonu ile örnek:

SELECT arrayReduce('uniqUpTo(3)', [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
┌─arrayReduce('uniqUpTo(3)', [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])─┐
│                                                           4 │
└─────────────────────────────────────────────────────────────┘

arrayReduceİnRanges

Belirli aralıklardaki dizi öğelerine bir toplama işlevi uygular ve her aralığa karşılık gelen sonucu içeren bir dizi döndürür. Fonksiyon aynı sonucu birden fazla olarak döndürür arrayReduce(agg_func, arraySlice(arr1, index, length), ...).

Sözdizimi

arrayReduceInRanges(agg_func, ranges, arr1, arr2, ..., arrN)

Parametre

  • agg_func — The name of an aggregate function which should be a constant dize.
  • ranges — The ranges to aggretate which should be an dizi -den Demetler indeks ve her aralığın uzunluğunu içeren.
  • arr — Any number of dizi sütunları toplama işlevinin parametreleri olarak yazın.

Döndürülen değer

Örnek

SELECT arrayReduceInRanges(
    'sum',
    [(1, 5), (2, 3), (3, 4), (4, 4)],
    [1000000, 200000, 30000, 4000, 500, 60, 7]
) AS res
┌─res─────────────────────────┐
│ [1234500,234000,34560,4567] │
└─────────────────────────────┘

arrayReverse(arr)

Öğeleri ters sırada içeren orijinal diziyle aynı boyutta bir dizi döndürür.

Örnek:

SELECT arrayReverse([1, 2, 3])
┌─arrayReverse([1, 2, 3])─┐
│ [3,2,1]                 │
└─────────────────────────┘

ters (arr)

Eşanlamlı “arrayReverse”

arrayFlatten

Bir dizi diziyi düz bir diziye dönüştürür.

İşlev:

  • İç içe geçmiş dizilerin herhangi bir derinliği için geçerlidir.
  • Zaten düz olan dizileri değiştirmez.

Düzleştirilmiş dizi, tüm kaynak dizilerdeki tüm öğeleri içerir.

Sözdizimi

flatten(array_of_arrays)

Takma ad: flatten.

Parametre

  • array_of_arraysDizi dizilerin. Mesela, [[1,2,3], [4,5]].

Örnekler

SELECT flatten([[[1]], [[2], [3]]])
┌─flatten(array(array([1]), array([2], [3])))─┐
│ [1,2,3]                                     │
└─────────────────────────────────────────────┘

arrayCompact

Ardışık yinelenen öğeleri bir diziden kaldırır. Sonuç değerlerinin sırası, kaynak dizideki sıraya göre belirlenir.

Sözdizimi

arrayCompact(arr)

Parametre

arr — The dizi incelemek.

Döndürülen değer

Yinelenen olmadan dizi.

Tür: Array.

Örnek

Sorgu:

SELECT arrayCompact([1, 1, nan, nan, 2, 3, 3, 3])

Sonuç:

┌─arrayCompact([1, 1, nan, nan, 2, 3, 3, 3])─┐
│ [1,nan,nan,2,3]                            │
└────────────────────────────────────────────┘

arrayZip

Birden çok diziyi tek bir dizide birleştirir. Elde edilen dizi, listelenen bağımsız değişken sırasına göre gruplandırılmış kaynak dizilerin karşılık gelen öğelerini içerir.

Sözdizimi

arrayZip(arr1, arr2, ..., arrN)

Parametre

İşlev, farklı türde herhangi bir dizi alabilir. Tüm giriş dizileri eşit boyutta olmalıdır.

Döndürülen değer

  • Gruplandırılmış kaynak dizilerden öğelerle dizi Demetler. Veri türleri tuple giriş dizileri türleri ile aynıdır ve diziler geçirilir aynı sırada.

Tür: Dizi.

Örnek

Sorgu:

SELECT arrayZip(['a', 'b', 'c'], [5, 2, 1])

Sonuç:

┌─arrayZip(['a', 'b', 'c'], [5, 2, 1])─┐
│ [('a',5),('b',2),('c',1)]            │
└──────────────────────────────────────┘

arrayAUC

Auc'yi hesaplayın (makine öğreniminde bir kavram olan eğrinin altındaki alan, daha fazla ayrıntıya bakın: https://en.wikipedia.org/wiki/Receiver_operating_characteristic#Area_under_the_curve).

Sözdizimi

arrayAUC(arr_scores, arr_labels)

Parametre

  • arr_scores — scores prediction model gives.
  • arr_labels — labels of samples, usually 1 for positive sample and 0 for negtive sample.

Döndürülen değer Float64 türü ile AUC değerini döndürür.

Örnek Sorgu:

select arrayAUC([0.1, 0.4, 0.35, 0.8], [0, 0, 1, 1])

Sonuç:

┌─arrayAUC([0.1, 0.4, 0.35, 0.8], [0, 0, 1, 1])─┐
│                                          0.75 │
└────────────────────────────────────────---──┘

Orijinal makale