Changes

Jump to navigation Jump to search
8 bytes removed ,  17:33, 28 July 2020
* By default, read transactions are favored, and transactions that access no databases can be evaluated even if the transactions limit has been reached. This behavior can be changed via the {{Option|FAIRLOCK}} option.
==XQuery LocksLimitations== ===Commands=== Database locking works with all commands unless the glob syntax is used, such as in the following command call:
By default, access to external resources (files on hard disk, HTTP requests, ...) is not controlled by the transaction monitor of BaseX. You can use custom XQuery locks to do so* {{Code|DROP DB new*}}:drop all databases starting with "new"
===Options, Pragmas, AnnotationsXQuery===
Deciding which databases will be accessed by a complex XQuery expression is a non-trivial task. Database detection works for the following types of queries: * {{Code|//item}}, read-locking of the database opened by a client* You can declare custom {{Code|doc('factbook')}}, read-locking of "factbook"* {{Code|collection('db/path/to/docs')}}, read -locking of "db"* {{Code|fn:sum(1 to 100)}}, locking nothing at all* {{Code|delete nodes db:open('test')//*[string-length(local-name(.)) > 5]}}, write-locking of "test" A global lock will be assigned if the name of the database is not a static string: * {{Code|for $db in ('db1', 'db2') return db:open($db)}}* {{Code|doc(doc('test')/reference/text())}}* <code>let $db := 'test' return insert nodes <test/> into db:open($db)</code> The functions [[Databases#XML Documents|fn:doc]] and write [[Databases#XML Documents|fn:collection]] can also be used to address that are not stored in a database. However, this may lead to unwanted locks via , and you have two optionsto reduce the number of locks: No database lookups will take place if {{Option|WITHDB}} option is disabled, pragmas or function annotationsif {{Function|Fetch|fetch:xml}} is used instead of [[Databases#XML Documents|fn:doc]].* The value You can consult the query info output (which you find in the [[GUI#Visualizations|Info View]] of the lock may contain one GUI or multiple lock keys (separated which you can turn on by setting {{Option|QUERYINFO}} to {{Code|true}}) to find out which databases have been locked by a query. =XQuery Locks= {{Mark|Updated with commas)Version 9. The default value is an empty string4:}} Single lock option for reads and writes.* Similar By default, access to external resources (files on hard disk, HTTP requests, ...) is not controlled by the internal database transaction monitor of BaseX. Custom lockscan be assigned via annotations, write locks block all other operations while read locks allow parallel accesspragmas or options: * A lock string may consist of a single key or multiple keys separated with commas.* The internal Internal locks and XQuery locks can co-exist (there will be no . No conflictsarise, even if your a lock string equals the name of a database that will be is locked by the transaction manager).* The lock is transformed into a write lock by making the corresponding expression updating. ==Annotations==
In the following module, lock annotations are used to prevent concurrent write operations on the same file:
<pre classsyntaxhighlight lang="brush:xquery">
module namespace config = 'config';
declare %basex:read-lock('CONFIG') function config:read() as xs:string {
file:read-text('config.txt')
};
declare %updating %basex:write-lock('CONFIG') function config:write($dataas xs:string) {
file:write-text('config.txt', $data)
};
</presyntaxhighlight>
Some explanations:
* If a query calls the <code>config:read</code> function, a read lock will be acquired for the user-defined {{Code|CONFIG}} lock string before query evaluation.
* If <code>config:write</code> is called by a query, a write lock on this lock string will be set for this queryapplied.* If a another query calls <code>config:write</code>, it will be queued until there is no running query left that has {{Code|CONFIG}} locked.* If the writing first query will be is evaluated, all other queries that will set a {{Code|CONFIG}} lock (reading or writing) will have to wait.
Local locks can also be declared via pragmas:==Pragmas==
Locks can also be declared via pragmas: <pre classsyntaxhighlight lang="brush:xquery">update:output((# basex:write-lock CONFIG #) {
file:write('config.xml', <config/>)
})</presyntaxhighlight>
Locks for The write locks is enforced via the functions of a module can be assigned via option declarations{{Code|Update|update:output}}.
<pre class="brush:xquery">declare option basex:write-lock 'CONFIG';file:write('config.xml', <config/>)</pre>=Options==
===Java Modules===Locks for the functions of a module can also be assigned via option declarations:
Locks can also be acquired on [[Java Bindings#Locking|Java functions]] which are imported and invoked from an XQuery expression. It is advisable to explicitly <syntaxhighlight lang="xquery">declare option basex:lock Java code whenever it performs sensitive read and write operations.'CONFIG';
==Limitations==update:output(file:write('config.xml', <config/>))</syntaxhighlight>
===Commands===Once again, a write lock is enforced.
Database locking works with all commands unless the glob syntax is used, such as in the following command call:==Java Modules==
* {{Code|DROP DB new*}}: drop all databases starting with "new" ===XQuery=== Deciding which databases will Locks can also be accessed by a complex XQuery expression is a non-trivial task. Database detection works for the following types of queries: * {{Code|//item}}, read-locking of the database opened by a client* {{Code|doc('factbook')}}, read-locking of "factbook"* {{Code|collection('db/path/to/docs')}}, read-locking of "db"* {{Code|fn:sum(1 to 100)}}, locking nothing at all* {{Code|delete nodes db:open('test')//*[string-length(local-name(.)) > 5]}}, write-locking of "test" A global lock will be assigned if the name of the database is not a static string: * {{Code|for $db in ('db1', 'db2') return db:open($db)}}* {{Code|doc(doc('test')/reference/text())}}* <code>let $db := 'test' return insert nodes <test/> into db:open($db)</code> The functions acquired on [[DatabasesJava Bindings#XML DocumentsLocking|fn:docJava functions]] which are imported and [[Databases#XML Documents|fn:collection]] can also be used to address that are not stored in a databaseinvoked from an XQuery expression. However, this may lead It is advisable to unwanted locks, explicitly lock Java code whenever it performs sensitive read and you have two options to reduce the number of locks: No database lookups will take place if {{Option|WITHDB}} option is disabled, or if {{Function|Fetch|fetch:xml}} is used instead of [[Databases#XML Documents|fn:doc]]. You can consult the query info output (which you find in the [[GUI#Visualizations|Info View]] of the GUI or which you can turn on by setting {{Option|QUERYINFO}} to {{Code|true}}) to find out which databases have been locked by a querywrite operations.
=File-System Locks=
=Changelog=
 
;Version 9.4
* Updated: Single lock option for reads and writes.
;Version 9.1
Bureaucrats, editor, reviewer, Administrators
13,551

edits

Navigation menu