Database Server
Reference documentation for Database Server object
Overview
A Database Server represents a connection to a data source object. It consists of connection parameters, various configurations to control behavior and metadata.
File Structure
The properties for Database Server connections are stored under the installation folder in servoy.properties file.
Properties Summary
The following properties can be configured for a Database Server object:
The identifying name of the Database Server connection.
The host name where your database server can be found.
Postgres database name to connect to.
User name for connecting to the database.
Password to use when connecting to the database.
URL of the JDBC connection to the DB.
JDBC driver to use.
The specific catalog to connect to. Not all databases support this option.
The specific schema to connect to. Not all databases suuport this option.
Determines the maximum number of connections that will be made to the database simultaneously.
Determines the maximum number of unused connections that are in the pool.
Idle connections from the connection pool will be disposed of if they are not used for this given amount of time (minutes).
This setting determines how many prepared statements are kept in cache.
Specifies a way to determine if a DB idle connection leased from the connection pool is valid or not.
The query that must run successfully in order for the connection to be considered valid.
This setting allows marking a Database Server as a clone of another Database Server.
Specifies whether or not the database is enabled.
Specifies whether or not System Tables and Views from the database are to be exposed in Servoy.
Servoy will prefix the table in the sql when needed.
This setting defines if the Database Server is the Log server.
Log table name.
Specifies whether server should expose stored procedures from the database.
Enabling this will set this server to only have client defined connections.
Options for ignoring case when sorting.
Options for setting sorting of null values.
Properties Details
The following properties can be configured for a Database Server object:
Server name
The identifying name of the Database Server connection. This name will be used in various bindings and programmatically, so it should not change. It does not need to match the name of the underlying database.
Type String
Required: true
Sample
Host Name
The host name where your database server can be found.
Type String
Required: true
Sample
Database Name
Postgres database name to connect to.
Type String
Required: true
Sample
User Name
User name for connecting to the database.
Type String
Required: true
Sample
Password
Password to use when connecting to the database.
Type String
Required: true
Sample
URL
The JDBC URL through which the database can be accessed.
Type String
Required: true
Sample
Driver
JDBC driver to use. Each DB type has a different driver. For some DB types there are multiple drivers available. This is the name of a driver class that is located in the driver directory's jar files.
Type String
Required: true
Sample
Catalog
The specific catalog to connect to. Not all databases support this option.
Type String
Required: true
Sample
Schema
The specific schema to connect to. Not all databases support this option.
Catalog & Schema: JDBC defines that a database may have a set of catalog and each catalog may have a set of schema's. However, each database/JDBC driver vendor has interpreted this differently. In general a Catalog contains all the system/metadata tables/views, while the schema contains all the "user" defined tables, views, triggers etc. Within the context of Servoy, the Catalog is hardly used, while the schema setting is used when connection to Oracle.
Type String
Required: true
Sample
Max Active Connections
Determines the maximum number of connections that will be made to the database simultaneous. If set too low, handling requests towards the database might slow down, as one request needs to wait until another request is processed and the connection is returned to the pool. If set too high, the exceptions might occur if the database cannot handle that many concurrent connections or if more memory is required than is available.
Type Number
Required: true
Sample
Max Idle Connections
Active connections that are done processing a request are returned to the connection pool as idle connections. If the number of idle connections goes over the maximum, the connections are removed. As instantiating new connections takes time, the value shouldn't be too low. On the other side idle connections take up resources, so the number shouldn't be too high either. Must be lower that the 'Maximum connections active' setting.
Type Number
Required: true
Sample
Connection Idle Timeout
Idle connections from the connection pool will be disposed of if they are not used for this given amount of time (minutes).
Type Number
Required: true
Sample
Max Idle Prepared Statements
All Servoy generated SQL statements are in the form of Prepared Statements, to increase the performance of statement execution. This setting determines how many prepared statements are kept in cache.
Type Number
Required: true
Sample
Connection Validation Type
Some databases automatically end connections when they have been idle for a certain period of time. This setting controls if and how Servoy validates a connection leased from the connection pool, before using it. There are three variations:
exception validation (value = 0, default): With exception validation no validation occurs before using the connection. When a exception occurs, the connection is destroyed. While this method has no overhead, the downside of this method is that the user is presented with the exception.
query validation (value = 1): With query validation, each connection is validated by executing a validation query upon leasing the idle connection from the pool. If the execution of the validation query results in an exception, the connection is destroyed and a new connection is leased from the pool. This process continues, until a connection correctly handles the validation query. The actual validation query can be set using the 'Validation query' setting (see below). This method has the greatest overhead of the three options, because the validation query is fired for every request towards the database.
metadata validation (value = 2): With meta data validation the JDBC driver is asked for some metadata about the connection. This method is not as useful on all databases, as some JDBC driver cache the meta data, so they return their result without actual communication with the database itself. In most scenario's the exception validation will be sufficient, as the Servoy Application Server and the Database Server are connected via a reliable network connection (or are hosted on the same machine). Instead of opting in for any of the other validation types, it is advised to solve any connection issues between the Application Server and the Database Server, instead of changing the validation type. Changing the validation type should be the last resort.
driver based validation (value= 3, since 8.4): With driver based validation, the connection validation mechanism of the JDBC driver is used; note that this method may send a query to the database server, depending on the driver implementation.
In case of an old (JDBC3) driver the validation will fall back to exception validation.
Type Number
Required: true
Sample
Connection Validation Query
The SQL statement fired at the database if the 'Query validation type' is set to 'Query validation'. The SQL statement used should be a statement with as little overhead as possible.
Type String
Required: true
, if Connection Validation Type is set as "query validation"
Sample
Data Model Clone From
This setting allows marking a Database Server as a clone of another Database Server. When marked as such, if a Solution is imported on the Servoy Application Server, any updates to the datamodel of the master Database Server are also applied to the Database Servers that are marked as a clone of the master Database Server.
Type String
Required: true
Sample
Enabled
Specifies whether or not the database is enabled.
Type Boolean
Required: true
Sample
Skip System Tables
When tables are defined in multiple schemas, whith this option set to 'true', Servoy will prefix the table in the sql when needed.
Type Boolean
Required: true
Sample
Prefix Tables
Specifies whether or not System Tables and Views from the database are to be exposed in Servoy.
Type Boolean
Required: true
Sample
Log Server
Servoy has functionality that allows to automatically track all insert/updates/deletes on tables. This functionality can be enabled through the Security layer inside the Solution. This functionality relies on one of the enabled Database Servers configured on the Servoy Application Server being marked at 'Log server'. This setting defines if the Database Server is the Log server.
Type Boolean
Required: false
Sample
Log Table Name
Log table name.
Type String
Required: true
Sample
Enable Procedures
Specifies whether server should expose stored procedures from the database. Default value is false except for Progress database where value is true. If set to true, will show stored procedures in solution explorer view and in code completion under datasources. From datasources node can call a stored procedure.
Type Boolean
Required: false
Sample
Client-Only Connections
Enabling this will set this server to only have client defined connections (datasources.db.server.defineDatasource()). This tries to postpone also the loading of the tables (only do that with a client connection).
Type Boolean
Required: false
Sample
Sort Ignoring Case
Options for ignoring case when sorting, this can be overridden at column level (in the table editor).
Type Boolean
Required: false
Sample
Sorting Null-Precedence
Options for setting sorting of null values, this can be overridden at column level (in the table editor). There are 3 options for this setting:
Database default
Nulls first on sort asc
Nulls last on sort asc
Type Number
Required: true
Sample
Last updated