The Insert command creates a new record into the database. Records can be schema-less.
INSERT INTO [class:]<class>|cluster:<cluster>|index:<index>
[(<field>[,]*) VALUES (<expression>[,]*)[,]*]|
[SET <field> = <expression>|<sub-command>[,]*]|
[CONTENT {<JSON>}]|
[RETURN <expression>]
[FROM <query>]
Where:
CONTENT
, gets a JSON to set fieldsRETURN
, returns an expression instead of the number of inserted records. You can use any valid SQL expression. The most use cases are:@rid
to return the record id of the new record@this
to return the entire new recordFROM
, inserts values from the resulset of a query. Since v1.7.SQL-92 syntax:
insert into Profile (name, surname) values ('Jay', 'Miner' )
OrientDB additional syntax:
insert into Profile SET name = 'Jay', surname = 'Miner'
insert into Profile cluster profile_recent (name, surname) values ('Jay', 'Miner' )
insert into Profile cluster profile_recent set name = 'Jay', surname = 'Miner'
insert into Profile(name,surname) VALUES ('Jay','Miner'),('Frank','Hermier),('Emily','Saut')
insert into Employee (name, boss) values ('jack', #11:99 )
insert into Employee SET name = 'jack', boss = #11:99
insert into Profile (name, friends) values ('Luca', [#10:3, #10:4] )
insert into Profile SET name = 'Luca', friends = [#10:3, #10:4]
insert into Diver SET name = 'Luca', buddy = (select from Diver where name = 'Marko')
insert into Diver SET name = 'Luca', buddy = (insert into Diver name = 'Marko')
This inserts a new document in the cluster 'asiaemployee':
insert into cluster:asiaemployee (name) values ('Mattew')
But note that the document will have no class assigned. To create a document of a certain class but in a different cluster than the default one use:
insert into cluster:asiaemployee (@class, content) values('employee', 'Mattew')
That will insert the document of type 'employee' in the cluster 'asiaemployee'.
insert into Profile (name, address) values ('Luca', { "@type" : "d", "street" : "Melrose Avenue", "@version" : 0 } )
insert into GermanyClient from ( select from Client where country = 'Germany' )
Will insert all the records from Client where the country is "Germany".
insert into GermanyClient from ( select *, true as copied from Client where country = 'Germany' )
Will insert all the records from Client where the country is "Germany" and will add an additional field called "coped" with value true.
To know more about other SQL commands look at SQL commands.