Documentation ¶
Index ¶
- Variables
- type BaseQuery
- func (q *BaseQuery) AddCriteria(expr bson.M)
- func (q *BaseQuery) GetCriteria() bson.M
- func (q *BaseQuery) GetLimit() int
- func (q *BaseQuery) GetSkip() int
- func (q *BaseQuery) GetSort() Sort
- func (q *BaseQuery) Limit(l int)
- func (q *BaseQuery) Skip(s int)
- func (q *BaseQuery) Sort(s Sort)
- func (q *BaseQuery) String() string
- type Dir
- type Document
- type DocumentBase
- type Field
- type FieldSort
- type Map
- type Query
- type ResultSet
- type Sort
- type Store
- func (s *Store) Delete(doc DocumentBase) error
- func (s *Store) Find(q Query) (*ResultSet, error)
- func (s *Store) Insert(doc DocumentBase) error
- func (s *Store) RawDelete(query Query, multi bool) error
- func (s *Store) RawUpdate(query Query, update interface{}, multi bool) error
- func (s *Store) Save(doc DocumentBase) error
- func (s *Store) Update(doc DocumentBase) error
Constants ¶
This section is empty.
Variables ¶
var ( NonNewDocumentErr = errors.New("Cannot insert a non new document.") NewDocumentErr = errors.New("Cannot updated a new document.") EmptyQueryInRawErr = errors.New("Empty queries are not allowed on raw ops.") EmptyIdErr = errors.New("A document without id is not allowed.") )
var (
IdField = NewField("_id", "bson.ObjectId")
)
var (
ResultSetClosed = errors.New("Cannot close a closed resultset.")
)
Functions ¶
This section is empty.
Types ¶
type BaseQuery ¶
type BaseQuery struct {
// contains filtered or unexported fields
}
func NewBaseQuery ¶
func NewBaseQuery() *BaseQuery
func (*BaseQuery) AddCriteria ¶
AddCriteria adds a new mathing expression to the query, all the expressions are merged on a $and expression.
Use operators package instead of build expresion by hand:
import . "github.com/tyba/storable/operators" func (q *YourQuery) FindNonZeroRecords() { // All the Fields are defined on the Schema generated variable size := NewField("size", "int") q.AddCriteria(Gt(size, 0)) }
func (*BaseQuery) GetCriteria ¶
GetCriteria returns a valid bson.M used internally by Store.
type Document ¶
type Document struct { Id bson.ObjectId `bson:"_id" json:"_id"` // contains filtered or unexported fields }
type DocumentBase ¶
type Field ¶
type Field struct {
// contains filtered or unexported fields
}
type ResultSet ¶
type ResultSet struct { IsClosed bool // contains filtered or unexported fields }
func (*ResultSet) All ¶
All returns all the documents in the ResultSet and close it. Dont use it with large results.
type Store ¶
type Store struct {
// contains filtered or unexported fields
}
func (*Store) Delete ¶
func (s *Store) Delete(doc DocumentBase) error
Delete remove the document from the collection
func (*Store) Insert ¶
func (s *Store) Insert(doc DocumentBase) error
Insert insert the given document in the collection, returns error if no-new document is given. The document id is setted if is empty.
func (*Store) RawDelete ¶
RawDelete performes a direct remove in the collection. If a query without criteria is given EmptyQueryInRawErr is returned
func (*Store) RawUpdate ¶
RawUpdate performes a direct update in the collection, update is wrapped on a $set operator. If a query without criteria is given EmptyQueryInRawErr is returned
func (*Store) Save ¶
func (s *Store) Save(doc DocumentBase) error
Save insert or update the given document in the collection, a document with id should be provided. Upsert is used (http://godoc.org/gopkg.in/mgo.v2#Collection.Upsert)
func (*Store) Update ¶
func (s *Store) Update(doc DocumentBase) error
Update update the given document in the collection, returns error if a new document is given.