OrientDB-레코드 삽입
OrientDB는 문서와 그래프 지향 데이터를 저장할 수있는 NoSQL 데이터베이스입니다. NoSQL 데이터베이스에는 테이블이 없으므로 어떻게 데이터를 레코드로 삽입 할 수 있습니까? 여기에서 클래스, 속성, 꼭지점 및 가장자리의 형태로 테이블 데이터를 볼 수 있습니다. 클래스는 테이블과 같고 속성은 테이블의 파일과 같습니다.
우리는 schemaOrientDB에서. 속성 데이터를 클래스에 삽입 할 수 있습니다. Insert 명령은 데이터베이스 스키마에 새 레코드를 만듭니다. 레코드는 스키마가 없거나 일부 지정된 규칙을 따를 수 있습니다.
다음 명령문은 레코드 삽입 명령의 기본 구문입니다.
INSERT INTO [class:]<class>|cluster:<cluster>|index:<index>
[(<field>[,]*) VALUES (<expression>[,]*)[,]*]|
[SET <field> = <expression>|<sub-command>[,]*]|
[CONTENT {<JSON>}]
[RETURN <expression>]
[FROM <query>]
다음은 위 구문의 옵션에 대한 세부 정보입니다.
SET − 값과 함께 각 필드를 정의합니다.
CONTENT− 필드 값을 설정하기위한 JSON 데이터를 정의합니다. 이것은 선택 사항입니다.
RETURN− 삽입 된 레코드 수 대신 반환 할 표현식을 정의합니다. 가장 일반적인 사용 사례는 다음과 같습니다.
@rid − 새 레코드의 레코드 ID를 반환합니다.
@this − 전체 새 레코드를 반환합니다.
FROM − 레코드 또는 결과 집합을 삽입하려는 위치.
예
다음 필드와 유형이있는 고객 테이블을 고려해 보겠습니다.
Sr. 아니. | 분야 명 | 유형 |
---|---|---|
1 | 신분증 | 정수 |
2 | 이름 | 끈 |
삼 | 나이 | 정수 |
다음 명령을 실행하여 스키마 (테이블)를 생성 할 수 있습니다.
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
모든 명령을 실행하면 id, name 및 age 필드가있는 테이블 이름 Customer가 표시됩니다. Customer 테이블에 대해 select 쿼리를 실행하여 테이블을 확인할 수 있습니다.
OrientDB는 레코드를 삽입하는 다양한 방법을 제공합니다. 샘플 레코드가 포함 된 다음 고객 테이블을 고려하십시오.
Sr. 아니. | 이름 | 나이 |
---|---|---|
1 | Satish | 25 |
2 | 크리슈나 | 26 |
삼 | Kiran | 29 |
4 | Javeed | 21 |
5 | 라자 | 29 |
다음 명령은 첫 번째 레코드를 Customer 테이블에 삽입하는 것입니다.
INSERT INTO Customer (id, name, age) VALUES (01,'satish', 25)
위의 명령이 성공적으로 실행되면 다음과 같은 출력이 표시됩니다.
Inserted record 'Customer#11:0{id:1,name:satish,age:25} v1' in 0.069000 sec(s).
다음 명령은 두 번째 레코드를 Customer 테이블에 삽입하는 것입니다.
INSERT INTO Customer SET id = 02, name = 'krishna', age = 26
위의 명령이 성공적으로 실행되면 다음과 같은 출력이 표시됩니다.
Inserted record 'Customer#11:1{id:2,age:26,name:krishna} v1' in 0.005000 sec(s).
다음 명령은 세 번째 레코드를 Customer 테이블에 삽입하는 것입니다.
INSERT INTO Customer CONTENT {"id": "03", "name": "kiran", "age": "29"}
위의 명령이 성공적으로 실행되면 다음과 같은 출력이 표시됩니다.
Inserted record 'Customer#11:2{id:3,name:kiran,age:29} v1' in 0.004000 sec(s).
다음 명령은 Customer 테이블에 다음 두 레코드를 삽입하는 것입니다.
INSERT INTO Customer (id, name, age) VALUES (04,'javeed', 21), (05,'raja', 29)
위의 명령이 성공적으로 실행되면 다음과 같은 출력이 표시됩니다.
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).
다음 명령을 실행하여 이러한 모든 레코드가 삽입되었는지 여부를 확인할 수 있습니다.
SELECT FROM Customer
위의 명령이 성공적으로 실행되면 다음과 같은 출력이 표시됩니다.
----+-----+--------+----+-------+----
# |@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
----+-----+--------+----+-------+----