OrientDB - Kayıt Ekle
OrientDB, belgeleri ve grafik odaklı verileri depolayabilen bir NoSQL veritabanıdır. NoSQL veritabanı herhangi bir tablo içermez, bu nedenle verileri kayıt olarak nasıl ekleyebilirsiniz. Burada tablo verilerini sınıf, özellik, tepe noktası ve kenar anlam sınıfları biçiminde görebilirsiniz ve özellikler tablolardaki dosyalar gibidir.
Tüm bu varlıkları kullanarak tanımlayabiliriz schemaOrientDB'de. Mülk verileri bir sınıfa eklenebilir. Ekle komutu, veritabanı şemasında yeni bir kayıt oluşturur. Kayıtlar şemasız olabilir veya belirli bazı kuralları takip edebilir.
Aşağıdaki ifade, Kayıt Ekle komutunun temel sözdizimidir.
INSERT INTO [class:]<class>|cluster:<cluster>|index:<index>
[(<field>[,]*) VALUES (<expression>[,]*)[,]*]|
[SET <field> = <expression>|<sub-command>[,]*]|
[CONTENT {<JSON>}]
[RETURN <expression>]
[FROM <query>]
Yukarıdaki sözdizimindeki seçeneklerle ilgili ayrıntılar aşağıdadır.
SET - Her alanı değerle birlikte tanımlar.
CONTENT- Alan değerlerini ayarlamak için JSON verilerini tanımlar. Bu isteğe bağlıdır.
RETURN- Eklenen kayıtların sayısı yerine döndürülecek ifadeyi tanımlar. En yaygın kullanım durumları şunlardır:
@rid - Yeni kaydın Kayıt Kimliğini döndürür.
@this - Yeni kaydın tamamını döndürür.
FROM - Kaydı veya sonuç kümesini eklemek istediğiniz yer.
Misal
Aşağıdaki alan ve türlere sahip bir Müşteri tablosu düşünelim.
Sr.No. | Alan adı | Tür |
---|---|---|
1 | İD | Tamsayı |
2 | İsim | Dize |
3 | Yaş | Tamsayı |
Aşağıdaki komutları uygulayarak Şemayı (tablo) oluşturabilirsiniz.
CREATE DATABASE PLOCAL:/opt/orientdb/databases/sales
CREATE CLASS Customer
CREATE PROPERTY Customer.id integer
CREATE PROPERTY Customer.name String
CREATE PROPERTY Customer.age integer
Tüm komutları yürüttükten sonra, id, isim ve yaş alanlarıyla birlikte Müşteri tablo adını alacaksınız. Müşteri tablosuna seçme sorgusu yürüterek tabloyu kontrol edebilirsiniz.
OrientDB, bir kayıt eklemek için farklı yollar sunar. Örnek kayıtları içeren aşağıdaki Müşteri tablosunu göz önünde bulundurun.
Sr.No. | İsim | Yaş |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
Aşağıdaki komut, ilk kaydı Müşteri tablosuna eklemektir.
INSERT INTO Customer (id, name, age) VALUES (01,'satish', 25)
Yukarıdaki komut başarıyla yürütülürse, aşağıdaki çıktıyı alacaksınız.
Inserted record 'Customer#11:0{id:1,name:satish,age:25} v1' in 0.069000 sec(s).
Aşağıdaki komut, ikinci kaydı Müşteri tablosuna eklemektir.
INSERT INTO Customer SET id = 02, name = 'krishna', age = 26
Yukarıdaki komut başarıyla yürütülürse, aşağıdaki çıktıyı alacaksınız.
Inserted record 'Customer#11:1{id:2,age:26,name:krishna} v1' in 0.005000 sec(s).
Aşağıdaki komut, üçüncü kaydı Müşteri tablosuna eklemektir.
INSERT INTO Customer CONTENT {"id": "03", "name": "kiran", "age": "29"}
Yukarıdaki komut başarıyla yürütülürse, aşağıdaki çıktıyı alacaksınız.
Inserted record 'Customer#11:2{id:3,name:kiran,age:29} v1' in 0.004000 sec(s).
Aşağıdaki komut, sonraki iki kaydı Müşteri tablosuna eklemektir.
INSERT INTO Customer (id, name, age) VALUES (04,'javeed', 21), (05,'raja', 29)
Yukarıdaki komut başarıyla yürütülürse, aşağıdaki çıktıyı alacaksınız.
Inserted record '[Customer#11:3{id:4,name:javeed,age:21} v1,
Customer#11:4{id:5,name:raja,age:29} v1]' in 0.007000 sec(s).
Aşağıdaki komutu uygulayarak tüm bu kayıtların eklenip eklenmediğini kontrol edebilirsiniz.
SELECT FROM Customer
Yukarıdaki komut başarıyla yürütülürse, aşağıdaki çıktıyı alacaksınız.
----+-----+--------+----+-------+----
# |@RID |@CLASS |id |name |age
----+-----+--------+----+-------+----
0 |#11:0|Customer|1 |satish |25
1 |#11:1|Customer|2 |krishna|26
2 |#11:2|Customer|3 |kiran |29
3 |#11:3|Customer|4 |javeed |21
4 |#11:4|Customer|5 |raja |29
----+-----+--------+----+-------+----