Changes

Jump to navigation Jump to search
1,031 bytes added ,  16:10, 20 February 2018
=Pragmas=
A ==BaseX Pragmas== Many optimizations in BaseX will only be performed if an expression is ''deterministic'' (i. e., if it always yields the same output and does not have side effects). By flagging an expression as non-deterministic, optimizations and query rewritings can be suppressed: <pre class="brush:xquery">sum( (# basex:non-deterministic #) { 1 to 100000000})</pre> This pragma can be helpful when debugging your code. ==Database Pragmas== All [[Options|local database optionoptions]] can also be assigned locally via pragmas. Some examples: * {{Version|9.0}}: Enforce query to be rewritten for index access. This can e. g. be helpful if the name of a pragmadatabase is not static (see [[Indexes#Enforce Rewritings|Enforce Rewritings]] for more examples):
<pre class="brush:xquery">
(# db:chop false enforceindex #) { doc for $db in ('doc.xmlpersons1', 'persons2', 'persons3') return db:open($db) //name[text() = 'John']}
</pre>
Many optimizations * {{Version|9.0}}: Temporarily disable node copying in node constructors (see {{Option|COPYNODE}} for more details). The following query will be evaluated faster, and query rewritings can take much less memory, than without pragma, because the database nodes will not be disabled by marking an expression as non-deterministicfully copied, but only attached to the new {{Code|xml}} parent element:
<pre class="brush:xquery">
countfile:write( 'wrapped-db-nodes.xml', (# basexdb:non-deterministic copynode false #) { 1 to 10 <xml>{ db:open('huge') }</xml> })
</pre>
Bureaucrats, editor, reviewer, Administrators
13,550

edits

Navigation menu