我是OrientDB的新手。我想知道如何将json文件中的json值插入orientDB。
{ "config": {
"log": "debug" }, "source" : {
"file": { "path": "D:\\New folder\\database.json" } }, "extractor" : {
"json": {} }, "transformers" : [
{ "merge": { "joinFieldName": "id", "lookup": "Account.id" } },
{ "vertex": { "class": "Account"} },
{ "edge": {
"class": "Friend",
"joinFieldName": "friends",
"lookup": "Account.id",
"unresolvedLinkAction": "CREATE"
} },
{ "edge": {
"class": "Enemy",
"joinFieldName": "enemies",
"lookup": "Account.id",
"unresolvedLinkAction": "CREATE"
} } ], "loader" : {
"orientdb": {
"dbURL": "D:\\InstalledSoftwares\\orientdb-3.0.8\\databases\\demodb",
"dbUser": "root",
"dbPassword": "vtg@123",
"dbAutoDropIfExists": true,
"dbAutoCreate": true,
"standardElementConstraints": false,
"tx": false,
"wal": false,
"batchCommit": 1000,
"dbType": "graph",
"classes": [{"name": "Account", "extends":"V"}, {"name": "Friend", "extends":"E"}, {"name": 'Enemy', "extends":"E"}],
"indexes": [{"class":"Account", "fields":["id:integer"], "type":"UNIQUE_HASH_INDEX" }]
} } }
这是我用来从json文件插入json值的代码。如果我运行此代码,则它将引发类似
的错误java.lang.IllegalArgumentException:文本不能为空
您能验证一下并帮助我解决这个问题吗? 在此先感谢
答案 0 :(得分:0)
我尝试了你的案子,结果奏效了
database.json
[
{
"name": "Joe",
"id": 1,
"friends": [2,4,5],
"enemies": [6]
},
{
"name": "Suzie",
"id": 2,
"friends": [1,4,6],
"enemies": [5,2]
}
]
import.json
{
"config": {
"log": "debug"
},
"source" : {
"file": { "path": "database.json" }
},
"extractor" : {
"json": {}
},
"transformers" : [
{ "merge": { "joinFieldName": "id", "lookup": "Account.id" } },
{ "vertex": { "class": "Account"} },
{ "edge": {
"class": "Friend",
"joinFieldName": "friends",
"lookup": "Account.id",
"unresolvedLinkAction": "CREATE"
} },
{ "edge": {
"class": "Enemy",
"joinFieldName": "enemies",
"lookup": "Account.id",
"unresolvedLinkAction": "CREATE"
} } ], "loader" : {
"orientdb": {
"dbURL": "remote:localhost/db_name",
"serverUser": "server_username",
"serverPassword": "server_password",
"dbUser": "db_username",
"dbPassword": "db_password",
"dbAutoDropIfExists": true,
"dbAutoCreate": true,
"standardElementConstraints": false,
"tx": false,
"wal": false,
"batchCommit": 1000,
"dbType": "graph",
"classes": [{"name": "Account", "extends":"V"}, {"name": "Friend", "extends":"E"}, {"name": 'Enemy', "extends":"E"}],
"indexes": [{"class":"Account", "fields":["id:integer"], "type":"UNIQUE_HASH_INDEX" }]
} } }
然后我运行了oetl.bat import.json,这就是我得到的:
select from V
+----+-----+-------+----+-------------+-----+-------+-------+-------------------+-------------+--------+
|# |@RID |@CLASS |id |in_Friend |name |friends|enemies|out_Friend |out_Enemy |in_Enemy|
+----+-----+-------+----+-------------+-----+-------+-------+-------------------+-------------+--------+
|0 |#17:0|Account|2 |[#21:0] |Suzie|[1,4,6]|[5,2] |[#24:0,#21:1,#22:1]|[#26:0,#27:0]|[#27:0] |
|1 |#17:1|Account|6 |[#22:1] | | | | | |[#25:0] |
|2 |#18:0|Account|1 |[#24:0] |Joe |[2,4,5]|[6] |[#21:0,#22:0,#23:0]|[#25:0] | |
|3 |#19:0|Account|4 |[#22:0,#21:1]| | | | | | |
|4 |#20:0|Account|5 |[#23:0] | | | | | |[#26:0] |
+----+-----+-------+----+-------------+-----+-------+-------+-------------------+-------------+--------+
希望有帮助
致谢