Hello again guys.
I modified the settings to enable json to load:
"apoc.import.file.enabled=true"
I have downloaded a bibliography result in json format and have stored it in the correct import directory.
this is my code:
//load json table into NEO4j
CALL apoc.load.json('file:///all_works.json') yield value
unwind value.0 as insti
Merge(a:Author) on create
set a.Firstname =insti.author[0].given,
a.Lastname =insti.author[0].family,
a.Sequence =insti.author[0].sequence
MERGE (i:Institution) on CREATE
set i.Name =insti.institution.name
The weird thing is that it only created nodes and links for the first record.
What am i missing here? It did not create the nodes for the other 400K records.
We were able to resolve this by asking the extractor to change the format to something like this:
{items:
[ {"tag1":value},
{"tag2": [
(tag21:value),
(tag22:value),
(tag23:value)
]
}
]
I find that to
However, now im having difficulty referencing nested json elements like tag21 to tag23
I find this works but i have to iterate.
CALL apoc.load.json('file:///all_works.json') yield value
unwind value.items as insti
WITH insti.tag2[0].tag22 as x1, insti.tag2[0].tag23 as x2, inti.tag2[0].tag21 as x0
(some processing code here)
So if tag2 has several occurences (like in authors of a paper)
i need to increment it (ie tag2[1] and so forth...
I tried FOREACH but it doesnt work with WITH.
There is not a clean way to conditionally expand a property. Honestly, I think the first extractor format may have been better, but without a clean sample, I can only guess.
...
CALL apoc.load.json('file:///all_works.json') YIELD value
UNWIND value.items as item
UNWIND keys(item) as tagN
WITH item, tagN, apoc.meta.isType(item.tagN,"LIST OF ANY") as isList
CALL apoc.when(
isList,
' UNWIND item[tagN] as tagNlist
UNWIND keys(tagNlist) as tagNN
// you now have all the data in the list
// ex: tagN = "tag2" and item[tagN][tagNN] will contain all "value2x" entries
',
' // single entry, not a list',
{item: item, tagN: tagN, isList: isList})
YIELD value
RETURN value
Thanks Tony, I learned a lot from your reply. I never even knew about apoc.meta.isType and apoc.when.
I am trying to understand the code, and i tried to run it, but got this error:
"Query cannot conclude with WITH (must be RETURN or an update clause) (line 1, column 2 (offset: 1))
" WITH $item as item , $tagN as tagN , $isList as isList // single entry, not a list"