Head's Up! These forums are read-only. All users and content have migrated. Please join us at community.neo4j.com.
03-04-2022 02:35 AM
I referred this site to convert my existing mongodb data to neo4j with relationships mappings. I used the following query to fetch data from mongo to neo4j db.
CALL apoc.mongodb.get('connectionString','dbName','TableName',{}) yield value CALL apoc.graph.fromDocument(value, {write: false,skipValidation: true,mappings: {`$`: 'sellers{!_id_,SellerName}', `$.SellerBrandStatistics`: 'brandname{!_id,Brand,ProductCount}', `$.SellerCategoryStatistics`: 'sellerCategory{!_id,CatId,ProductCount,Avg30SalesRank,ProductCountWithAmazonOffer}'}}) YIELD graph AS g1
return g1
but the challenge that I am facing while following this method is that I am not able to map relationship among the documents in the db thus I am stuck with the mapping of relationships only within the document which make me impossible to make product recommendations with cypher query. Can anyone please help me to map relationships among the documents in mongodb?
03-08-2022 07:59 AM
A couple of thoughts which might help:
apoc.graph.fromDocument
probably to do the linking of documents.Normally mongo references look something like this:
{
"_id" : ObjectId("5126bbf64aed4daf9e2ab771"),
// .. application fields
"creator" : {
"$ref" : "creators",
"$id" : ObjectId("5126bc054aed4daf9e2ab772"),
"$db" : "users"
}
}
So let's say we have that document, let's call it "doc". We might do something like this:
WITH doc
MATCH (other:Document { collection: doc.creator.`$ref`, `$id`: doc.creator.`$id` })
CREATE (doc)-[:LINKS_TO]->(other)
Basically, what you do is look up the node referring to the other document by using the fields in the MongoDB reference, and create the relationship that way.
Hope this helps
03-09-2022 01:43 AM
@david.allen thank you for the response, Referring the site I mentioned the topic with the single command I was able to import the document from mongodb to neo4j. As you mentioned to import all the documents seems better solution but the challenge I am facing is to import all the documents from the mongodb to neo4j db. I was planning to use the following code to import document with relationship to neo4j
CALL apoc.mongodb.get('connectionString','dbName','TableName',{}) yield value CALL apoc.graph.fromDocument(value, {write: false,skipValidation: true,mappings: {`$`: 'sellers{!_id_,SellerName}', `$.SellerBrandStatistics`: 'brandname{!_id,Brand,ProductCount}', `$.SellerCategoryStatistics`: 'sellerCategory{!_id,CatId,ProductCount,Avg30SalesRank,ProductCountWithAmazonOffer}'}}) YIELD graph AS g1
return g1
I also tried to make the database in sync using mongo-connector and Neo4j Doc Manager by the following steps
03-16-2022 05:11 AM
Unfortunately I think you're going to need to backtrack and take another approach. The neo4j-doc-manager was an open source project which is no longer maintained (GitHub - neo4j-contrib/neo4j_doc_manager: Doc manager for Neo4j) and probably this is failing because it is not using anything close to a recent software stack for Neo4j.
As a result, I'd consider either leaning on the APOC approach, or exporting MongoDB data to JSON and then using apoc.import.json
All the sessions of the conference are now available online