Documentation ¶
Overview ¶
Package memorydb implements the key-value database layer based on memory maps.
Index ¶
- type Database
- func (db *Database) Close() error
- func (db *Database) Compact(start []byte, limit []byte) error
- func (db *Database) Delete(key []byte) error
- func (db *Database) Get(key []byte) ([]byte, error)
- func (db *Database) Has(key []byte) (bool, error)
- func (db *Database) Len() int
- func (db *Database) NewBatch() ctxcdb.Batch
- func (db *Database) NewBatchWithSize(size int) ctxcdb.Batch
- func (db *Database) NewIterator(prefix []byte, start []byte) ctxcdb.Iterator
- func (db *Database) NewSnapshot() (ctxcdb.Snapshot, error)
- func (db *Database) Put(key []byte, value []byte) error
- func (db *Database) Stat(property string) (string, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Database ¶
type Database struct {
// contains filtered or unexported fields
}
Database is an ephemeral key-value store. Apart from basic data storage functionality it also supports batch writes and iterating over the keyspace in binary-alphabetical order.
func New ¶
func New() *Database
New returns a wrapped map with all the required database interface methods implemented.
func NewWithCap ¶
NewWithCap returns a wrapped map pre-allocated to the provided capacity with all the required database interface methods implemented.
func (*Database) Close ¶
Close deallocates the internal map and ensures any consecutive data access op failes with an error.
func (*Database) Compact ¶
Compact is not supported on a memory database, but there's no need either as a memory database doesn't waste space anyway.
func (*Database) Len ¶
Len returns the number of entries currently present in the memory database.
Note, this method is only used for testing (i.e. not public in general) and does not have explicit checks for closed-ness to allow simpler testing code.
func (*Database) NewBatch ¶
NewBatch creates a write-only key-value store that buffers changes to its host database until a final write is called.
func (*Database) NewBatchWithSize ¶ added in v1.10.31
NewBatchWithSize creates a write-only database batch with pre-allocated buffer.
func (*Database) NewIterator ¶
NewIterator creates a binary-alphabetical iterator over a subset of database content with a particular key prefix, starting at a particular initial key (or after, if it does not exist).
func (*Database) NewSnapshot ¶ added in v1.10.31
NewSnapshot creates a database snapshot based on the current state. The created snapshot will not be affected by all following mutations happened on the database.