I am still debating which way to go and possibly store certain information in its own doc. so for example the customer can have addresses with each address would be its own doc and then in the customer doc there would be an array of ref keys stored under addresses. The benefit would be i could update these docs simply based on the key value vs having to get the customer doc first, finding the array index of the address and then either modify the whole doc or go and use subdoc to replace the content of the array with the index. Where i am stuck is how to retrieve those referenced subdoc's. is N1QL the only way to go or does the KV API offer a way to do this short of retrieving the whole customer doc, then looping thru address array and retrieving all referenced docs that way. I know Ottoman offers something like that but i am having an issue with the latest version of SDK 2.6 and Ottoman as its not very well maintained. So hopefully someone can share some insight what and why its the best way.
Couchbase retrieving relational docs in nodeJS
129 Views Asked by MisterniceGuy At
1
There are 1 best solutions below
Related Questions in NODE.JS
- Using Puppeteer to scrape a public API only when the data changes
- How to request administrator rights?
- How do I link two models in mongoose?
- Variable inside a Variable, not updating
- Unable to Post Form Data to MongoDB because of picturepath
- Connection terminated unexpectedly while performing multi row insert using pg-promise
- Processing multiple forms in nodejs and postgresql
- Node.js Server + Socket.IO + Android Mobile Applicatoin XHR Polling Error...?
- How to change the Font Weight of a SelectValue component in React when a SelectItem is selected?
- My unban and ban commands arent showing when i put the slash
- how to make read only file/directory in Mac writable
- How can I outsource worker processes within a for loop?
- Get remote MKV file metadata using nodejs
- Adding google-profanity-words to web page
- Products aren't displayed after fetching data from mysql db (node.js & express)
Related Questions in COUCHBASE
- Couchbase Sync Gateway randomly failing to authenticate using mTLS
- how to fetch data when package structure deleted in source, but in couchbase document, _class with old package structure is present
- Recommended way for deleting "_txn" documents from Couchbase?
- How to query an array within an array with couchbase
- Cloudron Custom App (Couchbase) install fails: ECONNREFUSED
- Does couchbase eventing service stores events indefinitely?
- ClassNotFoundException while connecting to Couchbase
- i cannot use let or for clauses in my query, it always says its a reserved keyword
- Couchbase backup to S3 with Kubernetes service account role attachment is possible?
- Flutter & Couchbase in Android Studio: Process 'command 'C:/Program Files/Git/bin/bash'' finished with non-zero exit value 35
- Different Lcb wait3 API flags meaning
- Why is GSI creation so slow?
- Index creation and memory issue on Couchbase version 6.6
- ECS task Failed With couchbase database
- Couchbase Why a simple query is slow on nodejs?
Related Questions in COUCHBASE-OTTOMAN
- Ottoman.js auto create collection and adaptive index
- couchbase, ottoman throw error when I create a new instance?
- How to query a field inside array sub-document using ottomanjs using query builder
- couchbase, how to match the entire sub document
- How to insert a string array values record in couchbase bucket?
- check if a user already exists in database node js using couchbase
- Node Ottoman doesn't validate data type
- Couchbase retrieving relational docs in nodeJS
- Problem with ottoman not resolving the references
- Document update only possible on Model.getById?
- Getting errors while executing lambda function using couchbase / ottoman node-js sdk
- Couchbase find() error
- Couchbase Ottoman nodejs Generic Error, Code:10
- Couchbase Lite - synchronising reference fields
- Bulk insert or update with Couchbase Ottoman
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
If you want to rely on key/value, then you'll need to do the multiple lookup as you've described. I'm not very familiar with Ottoman: it might do this for you, but behind the scenes it will still be multiple key/value operations and/or N1QL.
With N1QL, you can perform JOINs, but again, behind the scenes it's going to eventually be pulling documents out by key/value. It just does those extra steps for you. Direct key/value is always going to be the fastest route.
If you are still in the process of deciding whether to split the data amongst multiple documents or "denormalize" the data into a single doc, one thing you should think about is how often you're going to access customer+addresses together and how often you're going to customer/access separately. If you're reading/writing customer+address often, consider putting it in one document. Otherwise, consider putting it in multiple documents.
The third option is to store it both places, or rather "cache" the address data in the customer document. This is tricky, because it could get out of sync if you're not careful. So make sure it's worth it before you go down that road.