Difference between revisions of "Database Server"

From BaseX Documentation
Jump to navigation Jump to search
 
(36 intermediate revisions by 4 users not shown)
Line 1: Line 1:
This step by step tutorial is part of the [[Getting Started]] Guide.
+
This article belongs to the [[Getting Started]] Guide. It tells you how to run BaseX in client-server mode from command-line.
It shows you how to run BaseX in client-server mode from a terminal. You can copy and paste all commands to get them running on your machine. After you finished this tutorial, you will be familiar with the basic administration of BaseX. Visit the [[Commands|commands section]] for a complete list of database commands.
 
  
==Startup==
+
=Startup=
First of all, please launch a '''Server''' and '''Client''' instance of BaseX: double click on the '''BaseX Server/Client''' icons, or run the <code>basexserver</code> and <code>basexclient</code> scripts. [[Startup#BaseX Server|Follow this link]] for more information (or check out the additional [[Command-Line Options#BaseX Server|command-line options]]).
 
  
==Create a database==
+
==Server==
* To create a database you need an XML document, e.g. [http://files.basex.org/xml/factbook.xml factbook.xml].
 
* Save this document to the directory you are working in.
 
* In the client terminal, type in:
 
<code>
 
> [[Commands#CREATE DB|CREATE DB]] factbook factbook.xml
 
</code>
 
  
: '''factbook''' is the name of the database <br/>
+
The database server handles concurrent [[Transaction_Management|read and write transactions]], [[User Management|manages user permissions]] and [[Logging|logs user interactions]]. It can be started as follows:
: '''factbook.xml''' is the xml file, which is used to create the database<br/>     
 
  
If everything works you see the following lines:
+
* Run one of the {{Code|basexserver}} or {{Code|basexserver.bat}} scripts. Use {{Code|basexserverstop}} or {{Code|basexserverstop.bat}} to gracefully shut down the server.
<pre>Database 'factbook' created in 950.83 ms.
+
* If you have installed BaseX on ''Windows'', click on the '''BaseX HTTP Server (Start)''' icon, which will start both the HTTP Server used for [[#Web Application|Web Applications]] and the database server. With '''BaseX HTTP Server (Stop)''', you can shut down the server process.
</pre>
 
 
; Where is the database stored?
 
By default, databases are stored in the <code>BaseXData</code> directory, which is located in your home folder.
 
Depending on your [[Configuration]], the location of your home folder varies. For example, on a Mac it's <code>/Users/John</code>, if your name is John. If you have used the Windows Installer, the directory will be named <code>data</code>, and reside in the application directory.
 
  
==Execute a query==
+
Unless you have already chosen an admin password yet (e.g., via the Windows installer or a previous installation), you can do so by invoking the {{Command|PASSWORD}} command on your terminal:
The [[Commands#XQUERY|XQUERY]] command lets you run a query.
 
* For example, this query returns all country nodes in the currently opened database.
 
<code>
 
> [[Commands#XQUERY|XQUERY]] //country
 
</code>
 
  
* You can also run queries in files:
+
<pre>
<code>
+
basexserver -c PASSWORD
> [[Commands#RUN|RUN]] /Users/John/query.xq
+
BaseX [Server]
</code>
+
Server was started (port: 1984).
 +
Password: _
 +
</pre>
  
==Create a new database==
+
By default, the server listens to the port {{Code|1984}}. Pressing {{Code|Ctrl+c}} will close all connections and databases and gracefully shut down the server process.
Now we will create another database from the [http://files.basex.org/xml/xmark.xml xmark.xml] document.
 
  
* Create the new database, named 'xmark'.
+
Various [[Command-Line_Options#Server|command-line options]] are available to simplify batch processing. The [[Start_Scripts|start script]] can be adjusted for individual purposes (e.g. if the default memory limit is too restrictive).
<code>
 
> [[Commands#CREATE DB|CREATE DB]] xmark xmark.xml
 
</code>
 
  
* Set the new database xmark as the context:
+
==Client==
<code>
 
> [[Commands#OPEN|OPEN]] xmark
 
</code>
 
  
* Now you can easily execute queries on your new database:
+
Database clients are started similarly:
<code>
 
> [[Commands#XQUERY|XQUERY]] //people/person/name
 
</code>
 
  
==Switch the database==
+
* Run one of the {{Code|basexclient}} or {{Code|basexclient.bat}} scripts.
* You can explicitly query the factbook database with the <code>doc(...)</code> funtion, no matter what the current context is.
+
* Execute the following command: {{Code|java -cp BaseX.jar org.basex.BaseXClient}}
<code>
+
* If you have installed BaseX on ''Windows'', click on the '''BaseX Client''' icon.
> [[Commands#XQUERY|XQUERY]] doc("factbook")//country
 
</code>
 
  
* Otherwise, to set factbook as the current context, execute the following:
+
At startup, you need to enter your credentials.
<code>
 
> [[Commands#OPEN|OPEN]] factbook
 
</code>
 
  
* The following command lists all databases than can be opened by the currently logged in users:
+
For further details, have a look at the [[Command-Line_Options#Client|command-line options]] and the [[Start_Scripts|start script]].
<code>
 
> [[LIST]]
 
</code>
 
  
==Close or delete a database==
+
=Introduction=  
* To [[Commands|close]] the current context database, please type:
 
<code>
 
> [[Commands#CLOSE|CLOSE]]
 
</code>
 
  
* Use the [[Commands#DROP DB|DROP DB]] command to delete the xmark database:
+
The BaseX command-line client provides similar features to the [[Command-Line Client|standalone client]]. The major difference is that all commands will be executed by the BaseX server instance. As a consequence, paths/URIs to resources need to be resolvable by the server (file contents will not be transfered to the server).
<code>
 
> [[Commands#DROP DB|DROP DB]] xmark
 
</code>
 
  
==Create a collection==
+
Username and password can also be specified as command-line option. To evaluate commands without entering the console mode, you can use the <code>-c</code> option on the command line:
'''What is a collection?'''
+
With BaseX you can group documents into one logical collection. A collection is a database that contains two or more documents. Collections accept any type of XML documents, regardless of their structure.
+
<pre>
 +
basexclient -V -Uadmin -P... -c "CREATE DB input <example/>; XQUERY /"
  
Let's add the xmark.xml document to the factbook database to create a collection. The name of the original factbook database remains.
+
Database 'input' created in 13.85 ms.
 +
<example/>
 +
Query:
 +
/
  
* First make sure factbook is opened:
+
Parsing: 0.18 ms
<code>
+
Compiling: 0.04 ms
> [[Commands#OPEN|OPEN]] factbook
+
Evaluating: 0.12 ms
</code>
+
Printing: 0.07 ms
 +
Total Time: 0.41 ms
  
* Now add the xmark.xml document:  
+
Hit(s): 1 Item
<code>
+
Updated: 0 Items
> [[Commands#ADD|ADD]] xmark.xml
+
Printed: 10 Bytes
</code>
+
Read Locking: local [input]
 +
Write Locking: none
  
==Delete a document==
+
Query "user" executed in 0.41 ms.
* Deleting a document from a collection is easy:
+
</pre>
<code>
 
> [[Commands#DELETE|DELETE]] xmark.xml
 
</code>
 
 
 
Make sure that the collection, which contains the '''xmark.xml''' document, is opened.
 
 
 
==Delete a collection==
 
Deleting a collection is the same as deleting a database.
 
 
 
* To delete the collection factbook, type:
 
<code>
 
> [[Commands#DROP DB|DROP DB]] factbook
 
</code>
 
 
 
==Get server information==
 
Several commands help to explore the state of a server. For a complete list, please visit the [[Commands]] Section.
 
 
 
* To see all databases on the server, type:
 
<code>
 
> [[Commands#LIST|LIST]]
 
</code>
 
 
 
* To see which database is currently opened:
 
<code>
 
> [[Commands#SHOW DATABASES|SHOW DATABASES]]
 
</code>
 
 
 
* To see the general information of the opened database, type:
 
<code>
 
> [[Commands#INFO|INFO]]
 
</code>
 
 
 
* To see the users in BaseX, type:
 
<code>
 
> [[Commands#SHOW USERS|SHOW USERS]]
 
</code>
 
 
 
==Backup and restore==
 
* To backup your database, type:
 
<code>
 
> [[Commands#CREATE BACKUP|CREATE BACKUP]] factbook
 
</code>
 
  
* To restore your database, type:
+
=Language Bindings=
<code>
 
> [[Commands#RESTORE|RESTORE]] factbook
 
</code>
 
  
'''Where is the backup-file stored?'''
+
If you want to communicate with the database server programmatically, we provide clients for various [[Clients|programming languages]].
  
The backup-file is stored in the database directory.
+
=Changelog=
The file is named <code>factbook-timestamp.zip</code> (<code>db_name-timestamp.zip</code>).
 
To restore the database the file with the newest timestamp is taken.
 
  
==See also ==
+
;Version 10.0
[[Standalone Mode]], [[GUI]], [[Getting Started]], [[Advanced Usage]]
+
* Updated: The default admin password has been removed.
[[Category:Beginner]]
 
[[Category:Server]]
 

Latest revision as of 11:24, 26 October 2023

This article belongs to the Getting Started Guide. It tells you how to run BaseX in client-server mode from command-line.

Startup[edit]

Server[edit]

The database server handles concurrent read and write transactions, manages user permissions and logs user interactions. It can be started as follows:

  • Run one of the basexserver or basexserver.bat scripts. Use basexserverstop or basexserverstop.bat to gracefully shut down the server.
  • If you have installed BaseX on Windows, click on the BaseX HTTP Server (Start) icon, which will start both the HTTP Server used for Web Applications and the database server. With BaseX HTTP Server (Stop), you can shut down the server process.

Unless you have already chosen an admin password yet (e.g., via the Windows installer or a previous installation), you can do so by invoking the PASSWORD command on your terminal:

basexserver -c PASSWORD
BaseX [Server]
Server was started (port: 1984).
Password: _

By default, the server listens to the port 1984. Pressing Ctrl+c will close all connections and databases and gracefully shut down the server process.

Various command-line options are available to simplify batch processing. The start script can be adjusted for individual purposes (e.g. if the default memory limit is too restrictive).

Client[edit]

Database clients are started similarly:

  • Run one of the basexclient or basexclient.bat scripts.
  • Execute the following command: java -cp BaseX.jar org.basex.BaseXClient
  • If you have installed BaseX on Windows, click on the BaseX Client icon.

At startup, you need to enter your credentials.

For further details, have a look at the command-line options and the start script.

Introduction[edit]

The BaseX command-line client provides similar features to the standalone client. The major difference is that all commands will be executed by the BaseX server instance. As a consequence, paths/URIs to resources need to be resolvable by the server (file contents will not be transfered to the server).

Username and password can also be specified as command-line option. To evaluate commands without entering the console mode, you can use the -c option on the command line:

basexclient -V -Uadmin -P... -c "CREATE DB input <example/>; XQUERY /"

Database 'input' created in 13.85 ms.
<example/>
Query:
/

Parsing: 0.18 ms
Compiling: 0.04 ms
Evaluating: 0.12 ms
Printing: 0.07 ms
Total Time: 0.41 ms

Hit(s): 1 Item
Updated: 0 Items
Printed: 10 Bytes
Read Locking: local [input]
Write Locking: none

Query "user" executed in 0.41 ms.

Language Bindings[edit]

If you want to communicate with the database server programmatically, we provide clients for various programming languages.

Changelog[edit]

Version 10.0
  • Updated: The default admin password has been removed.