Database
public final class DatabaseA Couchbase Lite database.
- 
                  
                  Initializes a Couchbase Lite database with a given name and database options. If the database does not yet exist, it will be created, unless the readOnlyoption is used.Throws An error when the database cannot be opened.DeclarationSwift public init(name: String, config: DatabaseConfiguration = DatabaseConfiguration()) throwsParametersnameThe name of the database. configThe database options, or nil for the default options. 
- 
                  
                  The database’s name. DeclarationSwift public var name: String { get }
- 
                  
                  The database’s path. If the database is closed or deleted, nil value will be returned. DeclarationSwift public var path: String? { get }
- 
                  
                  The total numbers of documents in the database. DeclarationSwift public var count: UInt64 { get }
- 
                  
                  The database configuration. DeclarationSwift public var config: DatabaseConfiguration { get }
- 
                  
                  Gets a Document object with the given ID. DeclarationSwift public func document(withID id: String) -> Document?
- 
                  
                  Gets document fragment object by the given document ID. DeclarationSwift public subscript(key: String) -> DocumentFragment { get }
- 
                  
                  Saves a document to the database. When write operations are executed concurrently, the last writer will overwrite all other written values. Calling this function is the same as calling the saveDocument(document, concurrencyControl) function with ConcurrencyControl.lastWriteWins. Throws An error on a failure.DeclarationSwift public func saveDocument(_ document: MutableDocument) throwsParametersdocumentThe document. 
- 
                  
                  Saves a document to the database. When used with lastWriteWins concurrency control, the last write operation will win if there is a conflict. When used with failOnConflict concurrency control, save will fail with ‘false’ value returned. Throws An error on a failure.DeclarationSwift @discardableResult public func saveDocument( _ document: MutableDocument, concurrencyControl: ConcurrencyControl) throws -> BoolParametersdocumentThe document. concurrencyControlThe concurrency control. Return ValueTrue if successful. False if the failOnConflict concurrency control is used, and there is a conflict. 
- 
                  
                  Saves a document to the database. When write operations are executed concurrently and if conflicts occur, the conflict handler will be called. Use the conflict handler to directly edit the document to resolve the conflict. When the conflict handler returns ‘true’, the save method will save the edited document as the resolved document. If the conflict handler returns ‘false’, the save operation will be canceled with ‘false’ value returned as the conflict wasn’t resolved. Throws An error on a failure.DeclarationSwift @discardableResult public func saveDocument( _ document: MutableDocument, conflictHandler: @escaping (MutableDocument, Document?) -> Bool ) throws -> BoolParametersdocumentThe document. conflictHandlerThe conflict handler closure which can be used to resolve it. Return ValueTrue if successful. False if there is a conflict, but the conflict wasn’t resolved as the conflict handler returns ‘false’ value. 
- 
                  
                  Deletes a document from the database. When write operations are executed concurrently, the last writer will overwrite all other written values. Calling this function is the same as calling the deleteDocument(document, concurrencyControl) function with ConcurrencyControl.lastWriteWins. Throws An error on a failure.DeclarationSwift public func deleteDocument(_ document: Document) throwsParametersdocumentThe document. 
- 
                  
                  Deletes a document from the database. When used with lastWriteWins concurrency control, the last write operation will win if there is a conflict. When used with failOnConflict concurrency control, save will fail with ‘false’ value returned. Throws An error on a failure.DeclarationSwift @discardableResult public func deleteDocument( _ document: Document, concurrencyControl: ConcurrencyControl) throws -> BoolParametersdocumentThe document. concurrencyControlThe concurrency control. Return ValueTrue if successful. False if the failOnConflict concurrency control is used, and there is a conflict. 
- 
                  
                  Purges the given document from the database. This is more drastic than deletion: it removes all traces of the document. The purge will NOT be replicated to other databases. Throws An error on a failure.DeclarationSwift public func purgeDocument(_ document: Document) throwsParametersdocumentThe document. 
- 
                  
                  Purges the document for the given documentID from the database. This is more drastic than deletion: it removes all traces of the document. The purge will NOT be replicated to other databases. Throws An error on a failure.DeclarationSwift public func purgeDocument(withID documentID: String) throwsParametersdocumentIDThe document. 
- 
                  
                  Save a blob object directly into the database without associating it with any documents. Note: Blobs that are not associated with any documents will be removed from the database when compacting the database. Throws An error on a failure.DeclarationSwift public func saveBlob(blob: Blob) throwsParametersblobThe blob to save. 
- 
                  
                  Get a blob object using a blob’s metadata. If the blob of the specified metadata doesn’t exist, the nil value will be returned. Throws An error on a failure. Note Note: Key | Value | Mandatory | Description@type | constant string “blob” | Yes | Indicate Blob data type. content_type | String | No | Content type ex. text/plain. length | Number | No | Binary length of the Blob in bytes. digest | String | Yes | The cryptographic digest of the Blob’s content. DeclarationSwift public func getBlob(properties: [String : Any]) throws -> Blob?ParameterspropertiesThe properties for getting the blob object. If dictionary is not valid, it will throw InvalidArgument exception. See the note section 
- 
                  
                  Runs a group of database operations in a batch. Use this when performing bulk write operations like multiple inserts/updates; it saves the overhead of multiple database commits, greatly improving performance. Throws An error on a failure.DeclarationSwift public func inBatch(using block: () throws -> Void) throwsParametersblockThe block to be executed as a batch operations. 
- 
                  
                  Sets an expiration date on a document. After this time the document will be purged from the database. Throws An error on a failure.DeclarationSwift public func setDocumentExpiration(withID documentID: String, expiration: Date?) throwsParametersdocumentIDThe ID of the document to set the expiration date for expirationThe expiration date. Set nil date will reset the document expiration. 
- 
                  
                  Returns the expiration time of a document, if exists, else nil. DeclarationSwift public func getDocumentExpiration(withID documentID: String) -> Date?ParametersdocumentIDThe ID of the document to set the expiration date for. Return Valuethe expiration time of a document, if one has been set, else nil. 
- 
                  
                  Adds a database change listener. Changes will be posted on the main queue. DeclarationSwift @discardableResult public func addChangeListener( _ listener: @escaping (DatabaseChange) -> Void) -> ListenerTokenParameterslistenerThe listener to post changes. Return ValueAn opaque listener token object for removing the listener. 
- 
                  
                  Adds a database change listener with the dispatch queue on which changes will be posted. If the dispatch queue is not specified, the changes will be posted on the main queue. DeclarationSwift @discardableResult public func addChangeListener(withQueue queue: DispatchQueue?, listener: @escaping (DatabaseChange) -> Void) -> ListenerTokenParametersqueueThe dispatch queue. listenerThe listener to post changes. Return ValueAn opaque listener token object for removing the listener. 
- 
                  
                  Adds a document change listener block for the given document ID. DeclarationSwift @discardableResult public func addDocumentChangeListener(withID id: String, listener: @escaping (DocumentChange) -> Void) -> ListenerTokenParametersdocumentIDThe document ID. listenerThe listener to post changes. Return ValueAn opaque listener token object for removing the listener. 
- 
                  
                  Adds a document change listener for the document with the given ID and the dispatch queue on which changes will be posted. If the dispatch queue is not specified, the changes will be posted on the main queue. DeclarationSwift @discardableResult public func addDocumentChangeListener(withID id: String, queue: DispatchQueue?, listener: @escaping (DocumentChange) -> Void) -> ListenerTokenParametersidThe document ID. queueThe dispatch queue. listenerThe listener to post changes. Return ValueAn opaque listener token object for removing the listener. 
- 
                  
                  Removes a change listener with the given listener token. DeclarationSwift public func removeChangeListener(withToken token: ListenerToken)ParameterstokenThe listener token. 
- 
                  
                  Close database synchronously. Before closing the database, the active replicators, listeners and live queries will be stopped. Throws An error on a failure.DeclarationSwift public func close() throws
- 
                  
                  Close and delete the database synchronously. Before closing the database, the active replicators, listeners and live queries will be stopped. Throws An error on a failure.DeclarationSwift public func delete() throws
- 
                  
                  Performs database maintenance. Throws An error on a failureDeclarationSwift public func performMaintenance(type: MaintenanceType) throws
- 
                  
                  Deletes a database of the given name in the given directory. Throws An error on a failure.DeclarationSwift public static func delete(withName name: String, inDirectory directory: String? = nil) throwsParametersnameThe database name. directoryThe directory where the database is located at. 
- 
                  
                  Checks whether a database of the given name exists in the given directory or not. DeclarationSwift public static func exists(withName name: String, inDirectory directory: String? = nil) -> BoolParametersnameThe database name. directoryThe directory where the database is located at. Return ValueTrue if the database exists, otherwise false. 
- 
                  
                  Copies a canned databaes from the given path to a new database with the given name and the configuration. The new database will be created at the directory specified in the configuration. Without given the database configuration, the default configuration that is equivalent to setting all properties in the configuration to nil will be used. Note This method will copy the database without changing the encryption key of the original database. The encryption key specified in the given config is the encryption key used for both the original and copied database. To change or add the encryption key for the copied database, call Database.changeEncryptionKey(key) for the copy. Throws An error on a failure. DeclarationSwift public static func copy(fromPath path: String, toDatabase name: String, withConfig config: DatabaseConfiguration?) throwsParameterspathThe source database path. nameThe name of the new database to be created. configThe database configuration for the new database name. 
- 
                  
                  Log object used for configuring console, file, and custom logger. DeclarationSwift public static let log: Log
- 
                  
                  Creates a Query object from the given query string. DeclarationSwift public func createQuery(query: String) -> QueryReturn ValueQuery created using the given expression string. 
- 
                  
                  ENTERPRISE EDITION ONLY. Changes the database’s encryption key, or removes encryption if the new key is nil. Throws An error on a failure.DeclarationSwift public func changeEncryptionKey(_ key: EncryptionKey?) throwsParameterskeyThe encryption key. 
- 
                  
                  ENTERPRISE EDITION ONLY The predictive model manager for registering and unregistering predictive models. DeclarationSwift public static let prediction: Prediction
- 
                  
                  All index names. DeclarationSwift public var indexes: Array<String> { get }
- 
                  
                  Creates an index which could be a value index or a full-text search index with the given name. The name can be used for deleting the index. Creating a new different index with an existing index name will replace the old index; creating the same index with the same name will be no-ops. Throws An error on a failure.DeclarationSwift public func createIndex(_ index: Index, withName name: String) throwsParametersindexThe index. nameThe index name. 
- 
                  
                  Creates an index using IndexConfiguration, which could be a value index or a full-text search index with the given name. Creating a new different index with an existing index name will replace the old index; creating the same index with the same name will be no-ops. Throws An error on a failure.DeclarationSwift public func createIndex(_ config: IndexConfiguration, name: String) throwsParametersconfigThe index configuration nameThe index name. 
- 
                  
                  Deletes the index of the given index name. Throws An error on a failure.DeclarationSwift public func deleteIndex(forName name: String) throwsParametersnameThe index name. 
 Database Class Reference
        Database Class Reference