OrientDB - Fungsi

Bab ini menjelaskan referensi lengkap dari berbagai jenis fungsi di OrientDB. Tabel berikut menjelaskan daftar fungsi, yang dikategorikan menurut fungsinya.

Fungsi Grafik

Sr.No. Nama & Deskripsi Fungsi
1

Out():

Mendapat simpul keluar yang berdekatan mulai dari rekor saat ini sebagai Vertex.

Syntax - keluar ([<label-1>] [, <label-n>] *)

2

In():

Mendapat simpul masuk yang berdekatan mulai dari catatan saat ini sebagai Vertex.

Syntax - dalam ([<label-1>] [, <label-n>] *)

3

Both():

Mendapat simpul keluar dan masuk yang berdekatan mulai dari catatan saat ini sebagai Vertex.

Syntax - keduanya ([<label1>] [, <label-n>] *)

4

outE():

Mendapat tepi keluar yang berdekatan mulai dari rekor saat ini sebagai Vertex.

Syntax - outE ([<label1>] [, <label-n>] *)

5

inE():

Mendapat tepi masuk yang berdekatan mulai dari rekor saat ini sebagai Vertex.

Syntax - inE ([<label1>] [, <label-n>] *)

6

bothE():

Mendapat tepi keluar dan masuk yang berdekatan mulai dari rekor saat ini sebagai Vertex.

Syntax - keduanyaE ([<label1>] [, <label-n>] *)

7

outV():

Mendapat simpul keluar mulai dari rekor saat ini sebagai Edge.

Syntax - outV ()

8

inV():

Dapatkan simpul masuk dari rekor saat ini sebagai Edge.

Syntax - inV ()

9

traversedElement():

Mengembalikan elemen yang dilintasi dalam perintah Traverse.

Syntax - traversedElement (<index> [, <items>])

10

traversedVertex():

Kembalikan simpul yang dilintasi dalam perintah Traverse.

Syntax - traversedVertex (<index> [, <items>])

11

traversedEdge():

Mengembalikan tepi yang dilintasi dalam perintah Traverse.

Syntax - traversedEdge (<index> [, <items>])

12

shortestPath():

Mengembalikan jalur terpendek antara dua simpul. Arahnya bisa OUT (default), IN atau BOTH.

Synatx - shortestPath (<sourceVertex>, <destinationVertex> [, <direction> [, <edgeClassName>]])

13

dijkstra():

Mengembalikan jalur termurah antara dua simpul menggunakan algoritma Dijkstra.

Syntax - dijkstra (<sourceVertex>, <destinationVertex>, <weightEdgeFieldName> [, <direction>])

Coba beberapa fungsi grafik bersama dengan kueri berikut.

Jalankan kueri berikut untuk mendapatkan semua simpul keluar dari semua simpul kendaraan.

orientdb {db = demo}>SELECT out() from Vehicle

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

---+----------+--------- 
 # | @class   | out 
---+----------+--------- 
 0 | Vehicle  | #11:2 
 1 | Vehicle  | #13:1 
 2 | Vehicle  | #13:4 
---+----------+---------

Jalankan kueri berikut untuk mendapatkan simpul masuk dan keluar dari simpul # 11: 3.

orientdb {db = demo}>SELECT both() FROM #11:3

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

---+----------+--------+------- 
 # | @class   | out    | in  
---+----------+--------+------- 
 0 | Vehicle  | #13:2  | #10:2   
 ---+----------+-------+-------

Fungsi Matematika

Sr.No. Nama & Deskripsi Fungsi
1

eval():

Mengevaluasi ekspresi di antara tanda kutip (atau tanda kutip ganda).

Syntax - eval ('<expression>')

2

min():

Mengembalikan nilai minimum. Jika dipanggil dengan lebih dari satu parameter, maka ia mengembalikan nilai argumen minimum di antara semua argumen.

Syntax - min (<field> [, <field-n>] *)

3

max():

Mengembalikan nilai maksimum. Jika dipanggil dengan lebih dari satu parameter, maka mengembalikan nilai maksimum di antara semua argumen.

Syntax - maks (<field> [, <field-n>] *)

4

sum()

Mengembalikan jumlah dari semua nilai yang dikembalikan.

Syntax - jumlah (<field>)

5

abs():

Mengembalikan nilai absolut. Ia bekerja dengan Integer, Long, Short, Double, Float, BigInteger, BigDecimal, null.

Syntax - abs (<field>)

6

avg():

Mengembalikan nilai rata-rata.

Syntax - rata-rata (<field>)

7

count():

Menghitung rekaman yang cocok dengan kondisi kueri. Jika * tidak digunakan sebagai kolom, maka record akan dihitung hanya jika isinya bukan null.

Syntax - hitung (<field>)

8

mode():

Mengembalikan nilai yang terjadi dengan frekuensi terbesar. Null diabaikan dalam penghitungan.

Syntax - mode (<field>)

9

median():

Mengembalikan nilai tengah atau nilai interpolasi yang mewakili nilai tengah setelah nilai diurutkan. Null diabaikan dalam penghitungan.

Syntax - median (<field>)

10

percentile():

Menampilkan persentil ke-n. Null diabaikan dalam penghitungan.

Syntax - persentil (<field> [, <quantile-n>] *)

11

variance()

Mengembalikan varian tengah: Rata-rata selisih kuadrat dari rata-rata.

Syntax - varians (<field>)

12

stddev()

Mengembalikan simpangan baku: Ukuran sebaran nilai. Null diabaikan dalam penghitungan.

Syntax - stddev (<field>)

Cobalah beberapa fungsi matematika menggunakan kueri berikut.

Jalankan kueri berikut untuk mendapatkan jumlah gaji semua karyawan.

orientdb {db = demo}>SELECT SUM(salary) FROM Employee

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

---+----------+--------- 
 # | @CLASS   | sum 
---+----------+--------- 
 0 | null     | 150000 
---+----------+---------

Jalankan kueri berikut untuk mendapatkan gaji rata-rata dari semua karyawan.

orientdb {db = demo}>SELECT avg(salary) FROM Employee

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

---+----------+--------- 
 # | @CLASS   | avg 
---+----------+--------- 
 0 | null     | 25 
---+----------+---------

Fungsi Koleksi

Sr.No. Nama & Deskripsi Fungsi
1

set():

Menambahkan nilai ke satu set. Jika nilainya adalah sebuah koleksi, maka itu akan digabungkan dengan set, jika tidak, <value> akan ditambahkan.

Syntax - set (<field>)

2

map():

Menambahkan nilai ke peta saat pertama kali peta dibuat. Jika <value> adalah peta, maka itu akan digabungkan dengan peta, jika tidak, pasangan <key> dan <value> ditambahkan ke peta sebagai entri baru.

Syntax - peta (<key>, <value>)

3

ist():

Menambahkan nilai ke daftar pertama kali daftar dibuat. Jika <value> adalah sebuah koleksi, maka itu digabungkan dengan daftar, jika tidak <value> ditambahkan ke daftar.

Syntax - daftar (<field>)

4

difference():

Berfungsi sebagai agregat atau sebaris. Jika hanya satu argumen yang diteruskan maka agregat, jika tidak dijalankan, dan mengembalikan PERBEDAAN antara koleksi yang diterima sebagai parameter.

Syntax - perbedaan (<field> [, <field-n>] *)

5

first():

Mengambil hanya item pertama dari bidang multi-nilai (array, koleksi, dan peta). Untuk tipe non-multi-nilai hanya mengembalikan nilainya.

Syntax - pertama (<field>)

6

intersect():

Berfungsi sebagai agregat atau sebaris. Jika hanya satu argumen yang diteruskan maka agregat, jika tidak dijalankan, dan mengembalikan, INTERACTION dari koleksi yang diterima sebagai parameter.

Syntax - berpotongan (<field> [, <field-n>] *)

7

distinct():

Mengambil hanya entri data unik bergantung pada bidang yang telah Anda tentukan sebagai argumen. Perbedaan utama dibandingkan dengan SQL DISTINCT standar adalah bahwa dengan OrientDB, fungsi dengan tanda kurung dan hanya satu bidang yang dapat ditentukan.

Syntax - berbeda (<field>)

8

expand():

Fungsi ini memiliki dua arti-

  • Saat digunakan di bidang koleksi, itu melepaskan koleksi di bidang dan menggunakannya sebagai hasil.

  • Saat digunakan pada bidang tautan (RID), ini memperluas dokumen yang ditunjukkan oleh tautan itu.

Syntax - luaskan (<field>)

9

unionall():

Berfungsi sebagai agregat atau sebaris. Jika hanya satu argumen yang dilewatkan maka agregat, jika tidak mengeksekusi dan mengembalikan UNION dari semua koleksi yang diterima sebagai parameter. Juga berfungsi tanpa nilai koleksi.

Syntax - unionall (<field> [, <field-n>] *)

10

flatten():

Mengekstrak koleksi di bidang dan menggunakannya sebagai hasil. Ini sudah usang, gunakan expand () sebagai gantinya.

Syntax - ratakan (<field>)

11

last():

Mengambil hanya item terakhir dari bidang multi-nilai (array, koleksi, dan peta). Untuk tipe non-multi-nilai hanya mengembalikan nilainya.

Syntax - terakhir (<field>)

12

symmetricDifference():

Berfungsi sebagai agregat atau sebaris. Jika hanya satu argumen yang dilewatkan maka agregat, jika tidak dijalankan, dan mengembalikan, PERBEDAAN SIMETRIS antara koleksi yang diterima sebagai parameter.

Syntax - perbedaan simetris (<field> [, <field-n>] *)

Coba beberapa fungsi koleksi menggunakan kueri berikut.

Jalankan kueri berikut untuk mendapatkan sekumpulan guru, mengajar kelas 9.

orientdb {db = demo}>SELECT ID, set(teacher.id) AS teacherID from classess where class_id = 9

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

---+----------+--------+-------------------------- 
 # | @CLASS   | id     | TeacherID 
---+----------+--------+-------------------------- 
 0 | null     | 9     |   1201, 1202, 1205, 1208 
---+----------+-------+---------------------------

Fungsi Lain-lain

Sr.No. Nama & Deskripsi Fungsi
1

date():

Mengembalikan tanggal yang memformat string. <date-as-string> adalah tanggal dalam format string, dan <format> adalah format tanggal yang mengikuti aturan ini.

Syntax - tanggal (<date-as-string> [<format>] [, <timezone>])

2

sysdate():

Mengembalikan tanggal dan waktu saat ini.

Syntax - sysdate ([<format>] [, <timezone>])

3

format():

Memformat nilai menggunakan konvensi String.format ().

Syntax - format (<format> [, <arg1>] (, <arg-n>] *. Md)

4

distance():

Mengembalikan jarak antara dua titik di dunia menggunakan algoritme Haversine. Koordinat harus derajat.

Syntax - jarak (<x-field>, <y-field>, <x-value>, <y-value>)

5

ifnull():

Mengembalikan bidang / nilai yang diteruskan (atau parameter opsional return_value_if_not_null). Jika field / nilai bukan null, ia mengembalikan return_value_if_null.

Syntax - ifnull (<field | value>, <return_value_if_null> [, <return_value_if_not_null>] (, <field & .md # 124; value>] *)

6

coalesce():

Mengembalikan bidang / nilai pertama, bukan parameter nol. Jika tidak ada bidang / nilai bukan nol, mengembalikan nol.

Syntax - menyatu (<bidang | nilai> [, <bidang-n | nilai-n>] *)

7

uuid():

Menghasilkan UUID sebagai nilai 128-bit menggunakan varian Leach-Salz.

Syntax - uuid ()

8

if():

Mengevaluasi kondisi (parameter pertama) dan mengembalikan parameter kedua jika kondisinya benar, yang ketiga sebaliknya.

Syntax - if (<expression>, <result-if-true>, <result-if-false>)

Coba beberapa fungsi Misc menggunakan kueri berikut.

Jalankan kueri berikut untuk mempelajari cara mengeksekusi ekspresi if.

orientdb {db = demo}> SELECT if(eval("name = 'satish'"), "My name is satish", 
"My name is not satish") FROM Employee

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

----+--------+----------------------- 
#   |@CLASS  | IF 
----+--------+----------------------- 
0   |null    |My name is satish  
1   |null    |My name is not satish 
2   |null    |My name is not satish  
3   |null    |My name is not satish  
4   |null    |My name is not satish  
----+--------+------------------------

Jalankan kueri berikut untuk mendapatkan tanggal sistem.

orientdb {db = demo}> SELECT SYSDATE() FROM Employee

Jika query di atas berhasil dijalankan, Anda akan mendapatkan output berikut.

----+--------+----------------------- 
#   |@CLASS  | SYSDATE 
----+--------+----------------------- 
0   |null    |2016-02-10 12:05:06 
1   |null    |2016-02-10 12:05:06 
2   |null    |2016-02-10 12:05:06 
3   |null    |2016-02-10 12:05:06 
4   |null    |2016-02-10 12:05:06 
----+--------+------------------------

Dengan menggunakan fungsi ini secara menyeluruh, Anda dapat dengan mudah memanipulasi data OrientDB.