Bahasa Q - Atribut

Daftar, kamus, atau kolom tabel dapat memiliki atribut yang diterapkan padanya. Atribut memaksakan properti tertentu pada daftar. Beberapa atribut mungkin hilang saat modifikasi.

Jenis Atribut

Diurutkan (`s #)

`s # berarti daftar diurutkan dalam urutan menaik. Jika daftar secara eksplisit diurutkan berdasarkan asc (atau xasc), daftar tersebut secara otomatis akan memiliki set atribut yang diurutkan.

q)L1: asc 40 30 20 50 9 4

q)L1
`s#4 9 20 30 40 50

Daftar yang diketahui diurutkan juga dapat memiliki atribut yang disetel secara eksplisit. Q akan memeriksa apakah daftar tersebut diurutkan, dan jika tidak, sebuah s-fail kesalahan akan terlempar.

q)L2:30 40 24 30 2

q)`s#L2
's-fail

Atribut yang diurutkan akan hilang setelah penambahan yang tidak diurutkan.

Berpisah (`p #)

`p # berarti daftar berpisah dan item identik disimpan berdekatan.

Rentangnya adalah int atau temporal type memiliki nilai int yang mendasarinya, seperti tahun, bulan, hari, dll. Anda juga dapat mempartisi simbol asalkan dicacah.

Menerapkan atribut parted membuat kamus indeks yang memetakan setiap nilai output unik ke posisi kejadian pertama. Ketika daftar dipisahkan, pencarian jauh lebih cepat, karena pencarian linier diganti dengan pencarian hashtable.

q)L:`p# 99 88 77 1 2 3

q)L
`p#99 88 77 1 2 3

q)L,:3

q)L
99 88 77 1 2 3 3

Note −

  • Atribut parted tidak dipertahankan di bawah operasi pada daftar, bahkan jika operasi mempertahankan partisi.

  • Atribut parted harus dipertimbangkan ketika jumlah entitas mencapai satu miliar dan sebagian besar partisi berukuran besar, yaitu ada pengulangan yang signifikan.

Dikelompokkan (`g #)

`g # berarti daftar dikelompokkan. Kamus internal dibuat dan dipelihara yang memetakan setiap item unik ke setiap indeksnya, membutuhkan ruang penyimpanan yang cukup besar. Untuk daftar panjangnyaL mengandung u ukuran barang unik s, ini akan menjadi (L × 4) + (u × s) byte.

Pengelompokan dapat diterapkan ke daftar jika tidak ada asumsi lain tentang strukturnya yang dapat dibuat.

Atribut dapat diterapkan ke semua daftar yang diketik. Itu dipertahankan saat ditambahkan, tetapi hilang saat dihapus.

q)L: `g# 1 2 3 4 5 4 2 3 1 4 5 6

q)L
`g#1 2 3 4 5 4 2 3 1 4 5 6

q)L,:9

q)L
`g#1 2 3 4 5 4 2 3 1 4 5 6 9

q)L _:2

q)L
1 2 4 5 4 2 3 1 4 5 6 9

Unik (`#u)

Menerapkan atribut unik (`u #) ke daftar menunjukkan bahwa item dari daftar itu berbeda. Mengetahui bahwa elemen-elemen dari sebuah daftar itu unik secara dramatis semakin cepatdistinct dan memungkinkan q untuk melakukan beberapa perbandingan lebih awal.

Saat daftar ditandai sebagai unik, peta hash internal dibuat untuk setiap item dalam daftar. Operasi pada daftar harus mempertahankan keunikan atau atributnya hilang.

q)LU:`u#`MSFT`SAMSUNG`APPLE

q)LU
`u#`MSFT`SAMSUNG`APPLE

q)LU,:`IBM                        /Uniqueness preserved

q)LU
`u#`MSFT`SAMSUNG`APPLE`IBM

q)LU,:`SAMSUNG                    / Attribute lost

q)LU
`MSFT`SAMSUNG`APPLE`IBM`SAMSUNG

Note −

  • `u # dipertahankan pada rangkaian yang menjaga keunikan. Itu hilang karena penghapusan dan penggabungan non-unik.

  • Pencarian pada daftar `u # dilakukan melalui fungsi hash.

Menghapus Atribut

Atribut dapat dihapus dengan menerapkan `#.

Menerapkan Atribut

Tiga format untuk menerapkan atribut adalah -

  • L: `s# 14 2 3 3 9/ Tentukan selama pembuatan daftar

  • @[ `.; `L ; `s#]/ Fungsional berlaku, yaitu ke daftar variabel L

    / di namespace default (yaitu `.) berlaku

    / atribut yang diurutkan `s #

  • Update `s#time from `tab

    / Perbarui tabel (tab) untuk menerapkan

    / atribut.

Mari terapkan tiga format berbeda di atas dengan contoh.

q)/ set the attribute during creation

q)L:`s# 3 4 9 10 23 84 90

q)/apply the attribute to existing list data

q)L1: 9 18 27 36 42 54

q)@[`.;`L1;`s#]
`.

q)L1                 / check
`s#9 18 27 36 42 54

q)@[`.;`L1;`#]       / clear attribute
`.

q)L1
9 18 27 36 42 54

q)/update a table to apply the attribute

q)t: ([] sym:`ibm`msft`samsung; mcap:9000 18000 27000)

q)t:([]time:09:00 09:30 10:00t;sym:`ibm`msft`samsung; mcap:9000 18000 27000)

q)t

    time         sym    mcap
---------------------------------
  09:00:00.000   ibm    9000
  09:30:00.000   msft   18000
  10:00:00.000  samsung 27000

q)update `s#time from `t
`t

q)meta t               / check it was applied

    c  | t f a
------ | -----
  time | t s
  sym  | s
  mcap | j
  
Above we can see that the attribute column in meta table results shows the time column is sorted (`s#).