Get one entity from the Datastore. Retrieving an entity by key is the fastest way to read from the Datastore.
This method accepts the following arguments:
const BlogPost = require('./blog-post.model');
// id can be an integer or a string
BlogPost.get({ id: 123 }).then((entity) => {
console.log(entity.plain());
});
// Passing an ancestor path with a Kind and a name
const ancestors = ['Parent', 'parentName'];
BlogPost.get('myEntityId', { ancestors }).then((entity) => { ... });
If you need to retrieve an entity from inside a transaction, you can pass the transaction object as fourth parameter.
const transaction = gstore.transaction();
transaction.run().then(() => {
BlogPost.get({ id: 123 }, { transaction })
.then((blogPost) => {
// blogPost is an instance of the BlogPost model
// with all its properties & methods
transaction.commit().then(() => { ... });
});
});
options properties
ancestors
transaction
namespace
preserveOrder (default: false)
cache (default: true)
ttl (default: the global cache ttl.keys configuration)
> ancestors: Ancestors path for the entity (eg: ['ParentEntity', 'parentName' ])
> transaction: Optional transaction to execute the get request.
> namespace: Optional namespace for the entity.
> cache If you activated the cache on the gstore-node instance, you can override here the global cache configuration. If the cache for keys fetching has been activated (default: true), you can pass false here to bypass the cache. If the cache for keys fetching has been disabled, then you can pass true here to cache specific key(s).
> ttl Overrides the global keys TTL of the cache. If you have multiple cache stores, you can pass an Object with a different value for each store. See in the example below.