Database Functions
This module contains functions for processing databases from within XQuery. Existing databases can be opened and listed, its contents can be directly accessed, documents can be added to and removed, etc.
All functions and errors in this module are assigned to the 
http://basex.org/modules/db namespace, which is statically bound to the 
db prefix.
In BaseX, two internal representations exist for XML nodes:
  - Database nodes are:
    
      - stored in a persistent database on disk,
- nodes of a document that has been generated temporarily with fn:doc,fn:parse-xmland other functions, or
- the result of a main-memory update.
 
- Fragments are similar to DOM structures. They are created when XQuery node constructors are used (<a/>,element a {}, etc.).
Fragments require less memory for small XML structures, but database nodes are more efficient for larger amounts of data. A fragment node can be converted to a database node by applying a main-memory update with an empty body to a node:
<xml>hello world</xml> update { }
Various functions in this module are 
updating. Updating functions will not be immediately executed, but queued on the 
Pending Update List, and processed after the remaining query has been evaluated. This means that the order in which the functions are specified in the query often does not reflect the order in which they will eventually be executed.
| Signature | db:system() as element(system) | 
|---|
| Summary | Returns general information about the database system, the current values of all global and local Options. The INFOcommand produces similar output. | 
|---|
| Signature | db:option(
  $name  as xs:string
) as xs:string | 
|---|
| Summary | Returns the current value (string, integer, boolean, map) of a global or local Option with the specified $name. TheSHOW OPTIONScommand returns similar output. | 
|---|
| Errors | | option | The specified option is unknown. | 
 | 
|---|
| Examples | Return the database path string.db:option('dbpath')
 
 Return a map with the current serialization parameters.db:option('serializer')
 
 Return the locally assigned value.declare option db:stripws 'true';
db:option('stripws')
 | 
|---|
| Signature | db:info(
  $database  as xs:string
) as element(database) | 
|---|
| Summary | Returns meta information on the specified $database. The output is similar to theINFO DBcommand. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Signature | db:property(
  $database  as xs:string,
  $name      as xs:string
) as xs:anyAtomicType | 
|---|
| Summary | Returns the value (string, boolean, integer) of a property with the specified $namein the specified$database. The available properties are the ones returned bydb:info. | 
|---|
| Errors | | property | The specified database property is unknown. | 
 | 
|---|
| Examples | Return the number of bytes occupied by the databasedb:property('db', 'size')
 db.
 Indicate if thedb:property('xmark', 'textindex')
 xmarkdatabase has a text index.
 Indicate if the database statistics and index structures of thedb:property('discogs', 'uptodate')
 discogsdatabase are up-to-date. | 
|---|
| Signature | db:list(
  $database  as xs:string  := (),
  $path      as xs:string  := ()
) as xs:string* | 
|---|
| Summary | Without arguments, the names of all databases are returned that are accessible to the current user. If $databaseis specified, paths to all resources of this database are returned. The results can be restricted to resources starting with the specified$path. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return the names of all documents of a database nameddb:list('docs')
 docs. | 
|---|
| Signature | db:list-details(
  $database  as xs:string  := (),
  $path      as xs:string  := ()
) as element()* | 
|---|
| Summary | Without arguments, an element is returned for each database that is accessible to the current user: IfAn element has a value, which is the name of the database, and several attributes, which contain the number of stored resources, the modification date, the database size on disk (measured in bytes), and a path to the original database input.
 $databaseis specified, an element for each resource in this database is returned:An element has a value, which is the name of the resource, and several attributes, which contain the content type, the modification date, the raw flag (which indicates if the resource is binary or XML), and the size of a resource.The value of the size attribute depends on the resource type: for documents, it represents the number of nodes; for binary data, it represents the file size (measured in bytes).The results can be restricted to resources starting with the specified $path.
 | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return the names plus additional info on all resources of a database nameddb:list-details('shop')
 shop. | 
|---|
| Signature | db:dir(
  $database  as xs:string,
  $path      as xs:string
) as element()* | 
|---|
| Summary | Returns metadata on all directories and resources of a $databasein the specified$path. Two types of elements are returned:The directories are not stored in the internal database layout. Instead, they result implicitly from the paths of stored resources.resourcerepresents a resource. The element value is the directory path; content type, modification date, raw flag (which indicates if the resource is binary or XML), and size of the resource are returned as attributes.dirrepresents a directory. The element value is the directory path; the modification date is returned in an attribute.
 | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. |  | path | The specified database path is invalid. | 
 | 
|---|
| Examples | Return all entries of thedb:dir('shop', 'books')
 booksdirectory of ashopdatabase. | 
|---|
| Signature | db:get(
  $database  as xs:string,
  $path      as xs:string  := ()
) as document-node()* | 
|---|
| Summary | Returns all documents from the specified $database, or only documents matching the specified$path. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return all documents from the database nameddb:get('docs')
 docs.
 Return all documents from the database nameddb:get('db', 'one')
 dblocated in the pathone.
 Return all item elements from the databasesfor $i in 1 to 3
return db:get('db' || $i)//item
 db1,db2anddb3. | 
|---|
| Signature | db:get-pre(
  $database  as xs:string,
  $values    as xs:integer*
) as node()* | 
|---|
| Summary | Returns all nodes from a $databasewith the specified PREvaluesin distinct document order.
    The PRE value provides very fast access to an existing database node, but it will change whenever a node with a smaller pre value is added to or deleted from a database. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. |  | range | The addressed database ID or PRE value is out of range. | 
 | 
|---|
| Examples | Return the first node that is stored in the databasedb:get-pre('docs', 0)
 docs. | 
|---|
| Signature | db:get-id(
  $database  as xs:string,
  $values    as xs:integer*
) as node()* | 
|---|
| Summary | Returns all nodes from a $databasewith the specified ID$valuesin distinct document order.
    Each database node has a persistent ID value. Access to the node ID can be sped up by turning on theUPDINDEXoption. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. |  | range | The addressed database ID or PRE value is out of range. | 
 | 
|---|
| Signature | db:get-binary(
  $database  as xs:string,
  $path      as xs:string
) as (map(*)|xs:base64Binary) | 
|---|
| Summary | Returns a map with the paths and binary items of all resources in the specified $database. A singlexs:base64Binaryitem is returned if a$pathis specified. All items are lazy, i.e., the actual data will only be retrieved if it is processed. | 
|---|
| Errors | | mainmem | The addressed database is not persistent (stored on disk). |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return the specified audio file as raw data.db:get-binary('DB', 'music/01.mp3')
 
 Materialize the streamable result in main-memory before returning it.db:get-binary('DB', 'music/01.mp3'))
=> stream:materialize()
 
 Convert a binary database resource as UTF-8 text and returns a string.db:get-binary('DB', 'info.txt')
=> convert:binary-to-string('UTF-8')
 | 
|---|
| Signature | db:get-value(
  $database  as xs:string,
  $path      as xs:string
) as (map(*)|item()*) | 
|---|
| Summary | Returns a map with the paths and values of all resources in the specified $database. A single value is returned if a$pathis specified. | 
|---|
| Errors | | mainmem | The addressed database is not persistent (stored on disk). |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return the specified sequence.db:get-value('DB', 'sequence')
 | 
|---|
| Signature | db:node-pre(
  $nodes  as node()*
) as xs:integer* | 
|---|
| Summary | Returns the PRE values of the specified $nodes, which must all be Database Nodes.
    The PRE value provides very fast access to an existing database node, but it will change whenever a node with a smaller pre value is added to or deleted from a database. | 
|---|
| Errors |  | 
|---|
| Examples | Returndb:node-pre(doc('input'))
 0if the databaseinputcontains a single document. | 
|---|
| Signature | db:node-id(
  $nodes  as node()*
) as xs:integer* | 
|---|
| Summary | Returns the ID values of the specified $nodes, which must all be Database Nodes.
    Each database node has a persistent ID value. Access to the node id can be sped up by turning on theUPDINDEXoption. | 
|---|
| Errors |  | 
|---|
| Signature | db:export(
  $database  as xs:string,
  $path      as xs:string,
  $options   as (element(output:serialization-parameters)|map(*))?  := ()
) as empty-sequence() | 
|---|
| Summary | Exports the specified $databaseto the specified file$path. Existing files will be overwritten.
    The$optionsargument contains serialization parameters (seefn:serialize). | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Export all files as text.db:export('DB', '/home/john/xml/texts', { 'method': 'text' })
 
 Export parts of the database.let $target := '/home/john/xml/target'
for $doc in db:get('DB', 'collection')
let $path := $target || db:path($doc)
return (
  file:create-dir(file:parent($path)),
  file:write($path, $doc)
)
 | 
|---|
| Signature | db:text(
  $database  as xs:string,
  $values    as xs:string*
) as text()* | 
|---|
| Summary | Returns all text nodes of a $databasethat match one of the specified$valuesand that are stored in the text index. | 
|---|
| Errors | | no-index | The database lacks an index structure required by the called function. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return the parents of all text nodes of the databasedb:text('DB', 'QUERY')/..
 DBthat match the stringQUERY. | 
|---|
| Signature | db:text-range(
  $database  as xs:string,
  $min       as xs:string,
  $max       as xs:string
) as text()* | 
|---|
| Summary | Returns all text nodes of a $databasewhose values are larger than or equal to$minand smaller than or equal to$maxand that are stored in the text index. | 
|---|
| Errors | | no-index | The database lacks an index structure required by the called function. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return all text nodes of the databasedb:text-range('DB', '2000', '2001')
 DBthat are found in between2000and2001. | 
|---|
| Signature | db:attribute(
  $database  as xs:string,
  $values    as xs:string*,
  $name      as xs:string   := ()
) as attribute()* | 
|---|
| Summary | Returns all attribute nodes of a $databasethat match one of the specified$valuesand that are stored in the attribute index.
    If$nameis specified, the resulting attribute nodes are filtered by their attribute name. | 
|---|
| Errors | | no-index | The database lacks an index structure required by the called function. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return the parents of alldb:attribute('DB', 'QUERY', 'id')/..
 idattribute nodes of the databaseDBthat haveQUERYas string value. | 
|---|
| Signature | db:attribute-range(
  $database  as xs:string,
  $min       as xs:string,
  $max       as xs:string,
  $name      as xs:string  := ()
) as attribute()* | 
|---|
| Summary | Returns all attributes of a $databasewhose values are larger than or equal to$minand smaller than or equal to$maxand that are stored in the attribute index. | 
|---|
| Errors | | no-index | The database lacks an index structure required by the called function. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return alldb:attribute-range('DB', 'id456', 'id473', 'id')
 @idattributes of the databaseDBthat have a string value in betweenid456andid473. | 
|---|
| Signature | db:token(
  $database  as xs:string,
  $tokens    as xs:string*,
  $name      as xs:string   := ()
) as attribute()* | 
|---|
| Summary | Returns all attribute nodes of a $databasethe values of which contain one of the specified$tokens.
    If$nameis specified, the resulting attribute nodes are filtered by their attribute name. | 
|---|
| Errors | | no-index | The database lacks an index structure required by the called function. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Return alldb:token('DB', 'row', 'class')/parent::div
 divnodes of databaseDBwith aclassattribute that contains the tokenrow. | 
|---|
All functions in this section are Updating Functions.
| Signature | db:create(
  $database  as xs:string,
  $inputs    as item()*     := (),
  $paths     as xs:string*  := (),
  $options   as map(*)?     := {}
) as empty-sequence() | 
|---|
| Summary | Creates a new $databaseand adds the supplied$inputsto the specified$paths:
      The inputs may be strings or nodes:
        
          nodes may be of any type except for attributesstrings can be a URI pointing to a file/directory or an XML string (which is detected by the leading <character)a path must be specified if the input is not a file or directory referenceThe parsing and indexing behavior can be controlled via $options:An existing database will be overwritten.Database creation takes place after most other update operations (see Pending Update List). As a consequence, a newly created database cannot be addressed in the same query. | 
|---|
| Errors | | args | The number of specified inputs and paths differs. |  | conflict | Multiple update operations point to the same target. |  | lock | A database cannot be updated because it is opened by another process. |  | name | The name of the specified database is invalid. | 
 | 
|---|
| Examples | Create the empty databasedb:create('DB')
 DB.
 Create the databasedb:create('DB', '/home/dir/doc.xml')
 DBand adds the document/home/dir/doc.xmlas initial content.
 Create the databasedb:create('DB', <a/>, 'doc.xml')
 DBand adds the document with rootaunder the namedoc.xml.
 Create the databasedb:create('DB', '/home/dir/', 'docs/dir')
 DBand adds the documents in/home/dirto the database under the pathdocs/dir.
 Add all files of the current working directory to a new database, preserving relative filesystem paths and creating a full-text index.db:create('DB', file:list('.'), (), { 'ftindex': true() })
 | 
|---|
| Signature | db:add(
  $database  as xs:string,
  $input     as item(),
  $path      as xs:string?  := (),
  $options   as map(*)?     := {}
) as empty-sequence() | 
|---|
| Summary | Adds the specified $inputto a$databasewith the specified$path:
      A document with the same path may occur more than once in a database. If you want to enforce single instances, use db:putinstead.See db:createfor more details on the input and path arguments.The parsing behavior can be controlled via $options:
          Allowed options are ADDCACHEand the parsing and XML parsing options, all in lower case.Parsing options will only impact string input (URIs, XML strings) because nodes have already been parsed. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Add the filedb:add("DB", "/home/dir/doc.xml")
 /home/dir/doc.xmlto the databaseDB.
 Add a document node to the databasedb:add('DB', <a/>, 'doc.xml')
 DBunder the namedoc.xml.
 Add all documents indb:add('DB', '/home/dir', 'docs/dir', { 'addcache': true() })
 /home/dirto the databaseDBunder the pathdocs/dir. To reduce memory consumption, the files will be cached before being added to the database. | 
|---|
| Signature | db:put(
  $database  as xs:string,
  $input     as item(),
  $path      as xs:string,
  $options   as map(*)?    := {}
) as empty-sequence() | 
|---|
| Summary | Replaces a resource, specified by $path, in a$databasewith the contents of$input, or adds it as a new resource:
      The parsing behavior can be controlled via $options:
          Allowed options are ADDCACHEand the parsing and XML parsing options, all in lower case.Parsing options will only impact string input (URIs, XML strings), because nodes have already been parsed.See db:createfor more details on the input argument. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. |  | target | Path points to an invalid target. | 
 | 
|---|
| Examples | Replace the content of the documentdb:put('DB', '/home/dir/doc.xml', 'docs/dir/doc.xml')
 docs/dir/doc.xmlin the databaseDBwith the content of the file/home/dir/doc.xml.
 Replace the content of the documentdb:put('DB', <a/>, 'docs/dir/doc.xml')
 docs/dir/doc.xmlin the databaseDB.
 Import files from a directory to a database.let $source := '/home/john/xml/source'
for $file in file:list($source, true())
let $path := $source || $file
where not(file:is-dir($path))
return db:put('db', doc($path), $file)
 | 
|---|
| Signature | db:put-binary(
  $database  as xs:string,
  $input     as item(),
  $path      as xs:string
) as empty-sequence() | 
|---|
| Summary | Stores a binary resource specified by $inputin a$databaseat the specified$path. Existing resources are overwritten. | 
|---|
| Errors | | mainmem | The addressed database is not persistent (stored on disk). |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Store the addressed video file at the specified location.db:put-binary('DB', file:read-binary('video.mov'), 'video/sample.mov')
 
 Copy the binary resources of one database into another.let $db := 'db'
let $src-path := 'src/'
let $trg-path := 'trg/'
for $src in db:list($db, $src-path)
where db:type($db, $src) = 'binary'
let $trg := $trg-path || substring-after($src, $src-path)
return db:put-binary($db, db:get-binary($db, $src), $trg)
 | 
|---|
| Signature | db:put-value(
  $database  as xs:string,
  $input     as item()*,
  $path      as xs:string
) as empty-sequence() | 
|---|
| Summary | Stores an $inputvalue in a$databaseat the specified$path. Existing resources are overwritten. The value can be an arbitrary sequence of atomic items, nodes, maps, and arrays. | 
|---|
| Errors | | mainmem | The addressed database is not persistent (stored on disk). |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Store a numeric range in the database.db:put-value('DB', 1 to 10000, 'sequence')
 
 A map with countries and associated cities is stored in a database. The value resource can e.g. be used as index in future queries.db:put-value(
  'factbook',
  map:merge(
    for $country in db:get('factbook')//country
    return map:entry($country/@name, $country//city/name ! string())),
  'cities'
)
 | 
|---|
| Signature | db:delete(
  $database  as xs:string,
  $path      as xs:string
) as empty-sequence() | 
|---|
| Summary | Deletes resource(s), specified by $path, from the specified$database. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. |  | path | The specified database path is invalid. | 
 | 
|---|
| Examples | Delete the resourcedb:delete('DB', 'docs/dir/doc.xml')
 docs/dir/doc.xmlfromDB.
 Delete all resources fromdb:delete('DB', 'docs/dir')
 DBin the specified pathdocs/dir. | 
|---|
| Signature | db:copy(
  $database  as xs:string,
  $new-name  as xs:string
) as empty-sequence() | 
|---|
| Summary | Creates a copy of $database, which will be called$new-name. | 
|---|
| Errors | | conflict | Multiple update operations point to the same target. |  | lock | A database cannot be updated because it is opened by another process. |  | name | The name of the specified database is invalid. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Signature | db:alter(
  $database  as xs:string,
  $new-name  as xs:string
) as empty-sequence() | 
|---|
| Summary | Renames a $databaseto$new-name. | 
|---|
| Errors | | conflict | Multiple update operations point to the same target. |  | lock | A database cannot be updated because it is opened by another process. |  | name | The name of the specified database is invalid. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Signature | db:optimize(
  $database  as xs:string,
  $all       as xs:boolean?  := false(),
  $options   as map(*)?      := {}
) as empty-sequence() | 
|---|
| Summary | Optimizes the metadata and indexes of a $database:If $allistrue, the complete database will be rebuilt.The $optionsargument can be used to control indexing. The syntax is identical to thedb:createfunction: Allowed options are all indexing and full-text indexing options.UPDINDEXis only supported if$allistrue.
 | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Optimize the database structures of the databasedb:optimize('DB')
 DB.
 Optimize all database structures of the databasedb:optimize('DB', true(), { 'ftindex': true() })
 DBand create a full-text index. | 
|---|
| Signature | db:rename(
  $database  as xs:string,
  $source    as xs:string,
  $target    as xs:string
) as empty-sequence() | 
|---|
| Summary | Moves all resources(s) of a $database, which are found in the supplied$sourcepath, to the supplied$targetpath. The paths may point to single resources or directories. No updates will take place if a non-existing source path is supplied. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. |  | path | The specified database path is invalid. | 
 | 
|---|
| Examples | Rename the resourcedb:rename('DB', 'docs/dir/doc.xml', 'docs/dir/newdoc.xml')
 docs/dir/doc.xmltodocs/dir/newdoc.xmlin the databaseDB.
 Move all resources in the databasedb:rename('DB', 'docs/dir', 'docs/newdir')
 DBfromdocs/dirtodocs/newdir. | 
|---|
| Signature | db:flush(
  $database  as xs:string
) as empty-sequence() | 
|---|
| Summary | Explicitly flushes the buffers of a $database. This command is only useful ifAUTOFLUSHhas been set tofalse. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Signature | db:drop(
  $database  as xs:string
) as empty-sequence() | 
|---|
| Summary | Drops a $databaseand all connected resources. | 
|---|
| Errors | | conflict | Multiple update operations point to the same target. |  | lock | A database cannot be updated because it is opened by another process. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Drop the databasedb:drop('DB')
 DB. | 
|---|
All functions in this section except for db:backups are Updating Functions.
Backups can be created for databases and general data. General data includes:
| Signature | db:create-backup(
  $database  as xs:string,
  $options   as map(*)?    := {}
) as empty-sequence() | 
|---|
| Summary | Creates a backup of a $database. If no name is supplied, general data will be backed up. The following$optionsare available:| option | default | description | 
|---|
 | comment | – | A comment string can be attached to the backup. |  | compress | true() | By disabling compression, the backup will be created faster, but it will take more space on disk. | 
 | 
|---|
| Errors | | conflict | Multiple update operations point to the same target. |  | name | The name of the specified database is invalid. |  | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Create a backup of the databasedb:create-backup('DB', { 'compress': false() })
 DBwithout compressing its entries. | 
|---|
| Signature | db:drop-backup(
  $name  as xs:string
) as empty-sequence() | 
|---|
| Summary | Drops all backups of the database with the specified $name. If the name ends with a timestamp, only the specified backup file will be deleted. If no name is supplied, backups with general data are addressed. | 
|---|
| Errors | | backup |  |  | conflict | Multiple update operations point to the same target. |  | name | The name of the specified database is invalid. | 
 | 
|---|
| Examples | Drop all backups of the databasedb:drop-backup('DB')
 DB.
 Drop the specific backup filedb:drop-backup('DB-2014-03-13-17-36-44')
 DB-2014-03-13-17-36-44.zipof the databaseDB. | 
|---|
| Signature | db:alter-backup(
  $name      as xs:string,
  $new-name  as xs:string
) as empty-sequence() | 
|---|
| Summary | Renames all backups of the database with the specified $nameto$new-name. If the name ends with a date, only the specified backup file will be renamed. | 
|---|
| Errors | | backup |  |  | conflict | Multiple update operations point to the same target. |  | name | The name of the specified database is invalid. | 
 | 
|---|
| Examples | Rename all backups of the databasedb:alter-backup('DB', 'DB2')
 DBtoDB2. | 
|---|
| Signature | db:restore(
  $name  as xs:string
) as empty-sequence() | 
|---|
| Summary | Restores the database with the specified $name. The$namemay include the timestamp of the backup file. If no name is supplied, general data will be restored, and a restart is required to make the restored general data available. | 
|---|
| Errors | | conflict | Multiple update operations point to the same target. |  | lock | A database cannot be updated because it is opened by another process. |  | name | The name of the specified database is invalid. |  | no-backup | No backup exists for a database. | 
 | 
|---|
| Examples | Restore the databasedb:restore('DB')
 DB.
 Restore the databasedb:restore('DB-2014-03-13-18-05-45')
 DBfrom the backup file with the given timestamp. | 
|---|
| Signature | db:backups(
  $database  as xs:string  := ()
) as element(backup)* | 
|---|
| Summary | Returns an element sequence containing all available database backups with timestamp, file size and comment.
    If a $databaseis specified, the sequence will be restricted to the backups matching this database. | 
|---|
| Examples | Return all backups that have been made from thedb:backups('factbook')
 factbookdatabase. | 
|---|
| Signature | db:name(
  $node  as node()
) as xs:string | 
|---|
| Summary | Returns the name of the database in which the specified database node $nodeis stored. | 
|---|
| Errors |  | 
|---|
| Signature | db:path(
  $node  as node()
) as xs:string | 
|---|
| Summary | Returns the path of the database document in which the specified database node $nodeis stored. | 
|---|
| Errors |  | 
|---|
| Signature | db:exists(
  $database  as xs:string,
  $path      as xs:string  := ()
) as xs:boolean | 
|---|
| Summary | Checks if a $databaseexists, or a resource located at$pathin this database. | 
|---|
| Examples | Returndb:exists('DB')
 trueif the databaseDBexists.
 Return true ifdb:exists('DB', 'resource')
 resourceexists in this database. | 
|---|
| Signature | db:type(
  $database  as xs:string,
  $path      as xs:string
) as xs:string | 
|---|
| Summary | Returns the type ( xml,binary,value) of a resource in a$databaseat the specified$path. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Returndb:type('DB', 'factbook.xml')
 xmlif the specified resource is an XML document. | 
|---|
| Signature | db:content-type(
  $database  as xs:string,
  $path      as xs:string
) as xs:string | 
|---|
| Summary | Retrieves the content-type of a resource in a $databaseat the specified$path.
    The file extension is used to recognize the content-type of a resource stored in the database.application/xmlwill be returned for any XML document stored in the database, regardless of its file name extension. | 
|---|
| Errors | | open | The addressed database does not exist or could not be opened. | 
 | 
|---|
| Examples | Returndb:content-type('DB', 'docs/doc01.pdf')
 application/pdf.
 Returndb:content-type('DB', 'docs/doc01.xml')
 application/xml.
 Returndb:content-type('DB', 'docs/doc01')
 application/xmlifdb:is-xml('DB', 'docs/doc01')returnstrue. | 
|---|
| Code | Description | 
|---|
| args | The number of specified inputs and paths differs. | 
| conflict | Multiple update operations point to the same target. | 
| lock | A database cannot be updated because it is opened by another process. | 
| mainmem | The addressed database is not persistent (stored on disk). | 
| name | The name of the specified database is invalid. | 
| no-backup | No backup exists for a database. | 
| no-index | The database lacks an index structure required by the called function. | 
| node | The referenced XML node is no database node. | 
| open | The addressed database does not exist or could not be opened. | 
| option | The specified option is unknown. | 
| path | The specified database path is invalid. | 
| property | The specified database property is unknown. | 
| range | The addressed database ID or PRE value is out of range. | 
| target | Path points to an invalid target. | 
Version 10.0Version 9.2- Added: db:dir
- Updated: db:add:$pathallow empty path argument
Version 9.0Version 8.6Version 8.4Version 8.3- Updated: db:list-details: attributes with name of database and date of backup added to results.
- Updated: db:backupsnow include attributes with name of database and date of backup.
- Updated: Value Indexes: raise error if no index exists.
Version 8.2- Added: db:output-cache
- Removed: db:event
Version 7.9Version 7.8.2Version 7.8Version 7.7Version 7.6- Updated: db:create: allow more than one input and path.
Version 7.5Version 7.3Version 7.2.1Version 7.1Version 7.0
⚡Generated with XQuery