Skip to main content
Skip table of contents

Generic SQL Datasource

JVM AGENT

Overview

The SQL Connector can be configured with a provided JDBC driver. This can be used in situations where Seeq does not have explicit support for a specific database, but it provides a JDBC driver.

Prerequisites

You must gather some information to configure a connection to your database.

Driver Installation

  • If the Seeq Remote Agent is running, stop the service.

  • Copy the JDBC driver into the plugins\lib folder within the Seeq Remote Agent data folder.

  • Start the Seeq Service

If you forget to install the JDBC driver, the connection will fail and you will see errors in the jvm-link logs related to loading the jar file.

Configuration

This is an example configuration template that is displayed in the Additional Configuration box that appears when you click Configure for an existing datasource (or if a new datasource is being created, in the Create new datasource connection modal that appears after clicking Add Datasource) on the Datasources administration page.

CODE
{
    "QueryDefinitions": null,
    "Type": "GENERIC",
    "Hostname": null,
    "Port": 0,
    "DatabaseName": null,
    "Username": "<insert user name>",
    "Password": "<insert user password>",
    "TimeZone": "UTC",
    "GenericDatabaseConfig": {
        "DatabaseJdbcUrl": "<insert jdbc url>",
        "SqlDriverClassName": "<insert sql driver class name"
    }
}
Standard SQL Additional Configuration

Property Name

Default Value

Data Type

Description

QueryDefinitions

null

Array[QueryDefinition]

The definition for how Seeq should query for data. If your hostname is of the form "abc\def", you will have to escape the backslash like so: "abc\\def".

Hostname

null

String

The hostname of your datasource.

QueryDefinitionExpansionLimit

1,000,000

Integer

The maximum number of signals that can be indexed from a single query definition. This value is here to protect against incorrect query definitions producing many millions of invalid signals.

Port

0

Integer

The port for the JDBC Connection.

Database Name

null

String

Optional: Can be defined here or as part of a fully qualified table name in the QueryDefinition.

Username

“"

String

The user name

Password

null

String/SecretFile

The user password.

JdbcConnectionStringOverride

null

String

Optional: Can be specified if you have a known, functioning JDBC connection string. If specified, Hostname, Port and Database Name need not be specified.

InitialSql

null

String

Optional: A SQL command that would be run one upon establishing a connection.

TimeZone

null

String

Optional: The time zone to use for timestamp or datetime columns. For example, to set this to US Pacific Time, you would use America/Los_Angeles.

PrintRows

false

Boolean

The rows from the SQL query will be printed to the jvm-link log. This is for debugging purposes only, and should be set to false in normal operation.

UseWindowsAuth

false

Boolean

Note: This is not available for all Database Types. If you are using a database type that supports Windows Authenication, you will need to ensure that the remote agent is running as the correct user.

JdbcProperties

null

Map<String, String>

A map of key value pairs that are configured as connection properties

Time Zone 

Some SQL date and/or time column types have no zone information. The TimeZone field is available to specify the time zone that Seeq should use for data coming from columns types that have no time zone information of their own. UTC offsets (+01:00, -10:30, etc.) and IANA regions (America/Los_Angeles) are accepted. If no time zone is specified, Seeq defaults to the local region of the Seeq server. If your data was stored in UTC time, set this field to "UTC" or "+00:00". If your data was entered using a "wall clock", set this to the IANA time region of the "wall clock". Note that offsets are constant throughout the year whereas a region may observe daylight savings time. If you used a wall clock in a location that observes daylight savings time, a region is a better choice than an offset for this field. A list of IANA regions (tz database time zones) can be found here.

Property Name

Default Value

Data Type

Description

GenericDatabaseConfig

null

GenericDatabaseConfig

The configuration for the JDBC driver

Property Name

Default Value

Data Type

Description

DatabaseJdbcUrl

null

String

(Required) The JDBC URL used to connect to the database

  • Example: "jdbc:..."

SqlDriverClassName

null

String

(Required) The Java class name of the database JDBC Driver. As noted above, a .jar file containing the class must be available on the Java classpath.

  • Example: "com.mydb.MydbDriver".

ResolutionInNanoseconds

null

Integer

(Required) The resolution in nanoseconds of the database's time-related column types. Note that this value can be overridden for specific column types via the ResolutionInNanosecondsPerColumnType option (see below).

  • Example: 1 if the database supports nanosecond resolution, 1000 if it supports microsecond resolution, etc.

ZonedColumnTypes

Array[String]

(Required) A list of names of the database’s column types that store time zone information. Can be empty if no column types store time zone information.

  • Note: the column type names must be all lower case

  • Example: ["timestamptz", "timestampltz"].

SupportsReadOnlyConnections

true

Boolean

(Optional) Whether this database supports read-only connections

MinimumFetchSizeAllowed

0

Integer

(Optional) The smallest number of rows that queries to this database can be limited to.

QueryQuotationMark

(Optional) A string containing the database’s quotation mark character, used to escape reserved words (see below). Defaults to "\"" (i.e., the double quote character).

ResolutionInNanosecondsPerColumnType

Array[{key,value}]

(Optional) A mapping of column type names to resolution in nanoseconds, used to override ResolutionInNanoseconds (see above) for specific column types. Defaults to [] (i.e., no overrides).

  • Note: the column type names must be all lower case

  • Example: [{"time" : 1000 }, { "date" : 86400000000000 }] declares that columns of type "time" have microsecond resolution, columns of type "date" have day resolution and all other time-related column types have the resolution configured in ResolutionInNanoseconds.

QueryStyle

TIMESTAMP

String

Accepted Values

  • TS

  • TIMESTAMP

  • MS_SQL_SERVER_PRECISE

(Optional) One of "TS", "TIMESTAMP" or "MS_SQL_SERVER_PRECISE", specifying how timestamps should be queried in the database. If "TS", the format {ts 'yyyy-mm-dd hh:mm:ss.f...'} will be used; if "TIMESTAMP", the format timestamp 'yyyy-mm-dd hh:mm:ss.f...' will be used; if "MS_SQL_SERVER_PRECISE", the format 'yyyy-mm-dd hh:mm:ss.f...' will be used. Defaults to "TIMESTAMP".

QueryStylePerSortColumnType

[]

Array[{key,value}]

(Optional) A mapping of column type names to query style, used to override QueryStyle (see above) for specific column types. Defaults to [] (i.e., no overrides).

  • Note: the column type names must be all lower case

  • Example: [{"time" : "TS" }, { "date" : "TS" }] declares that columns of type "time" and "date" should use the "TS" query style and all other column types should use the style configured in QueryStyle.

DateTimeStringSuffixPerColumnType

[]

Array[{key,value}]

(Optional) A mapping of database column type names to suffixes that should be added to date time strings to make them have a format like "2016-08-20 06:00:00.0 America/Los_Angeles" or "2016-08-16 07:00:00.0 -2:00". Defaults to [] (i.e., no suffixes are required for any column type).

  • Note: the column type names must be all lower case

  • Example: consider a database where "date" columns have values like "2022-08-10" and "timestamp" columns have values like "2022-08-10 10:02:00". Neither fit the desired format, but the missing parts can be added configuring DateTimeStringSuffixPerColumnType with the value [{ "date" : " 00:00:00 UTC", "timestamp" : " UTC" }], so "date" values get the missing time and time zone and "timestamp" values get the missing time zone. Note that in both cases we needed to be careful to start the suffixes with a space.

ConnectionConfigurationQueries

[]

Array[String]

(Optional) A list of queries to be executed to configure new connections to the database. Defaults to [] (i.e., no queries need to be executed).

  • Example: a value like ["SET MY_DB_SESSION_TIMEZONE = ‘UTC'"] could be used to configure the session’s time zone.

LimitQueryTemplate

null

String

(Optional) A query template for limiting the number of results of a query to the database, necessarily containing the variables ${QUERY} and ${LIMIT}, which will be replaced by the query to be limited and the limit, respectively. Defaults to null, meaning the built-in generic limiting mechanism should be used.

  • Example: "select * from ( ${QUERY} ) limit result count to ${LIMIT}".

ReservedWords

[]

Array[String]

(Optional) The list of reserved words of the database, that might need to be quoted with QueryQuotationMark depending on where they appear on queries. Defaults to the list of reserved words of ANSI SQL 2003.

  • Note: the reserved words must be all lower case

  • Example: ["select", "from"].

Known Issues

There are no known issues for the SQL Connector. Please report any issues you find to our support portal.

Troubleshooting

Seeq cannot guarantee compatibility with all database dialects.

A couple of errors that you may encounter are:

String-valued samples are prohibited in numeric-valued signal

If the y-axis value of the signal is a string, then the Value Unit Of Measure property is required and must be set to "string". See Example 2. 

Since the Value Unit Of Measure is different for string and numeric signals, it may be easiest to write one query definition for the numeric signals and write another for the string signals. Alternatively, the Value Unit Of Measure property could be set according to an SQL IF statement similar to the technique used in Example 13.

Samples must be ordered by their keys

If this is occurring when trending near the daylight savings transition, this is an indication that the TimeZone is not configured properly. For example, if TimeZone is set to "America/Los_Angeles", this means that the timestamp data in the SQL table was recorded using "America/Los_Angeles" time (Pacific) which observes daylight savings. During the spring daylight savings transition, time skips from 01:59:59.9 to 03:00:00.0 which means that the 02:00 hour doesn't exist and therefore there should be no data in the SQL table during that 02:00 hour. Any data in the 02:00 hour is interpreted as being in the 03:00 hour. If there is also data in the 03:00 hour, the samples will be out of order. 

Original data:

01:15, 01:45, 02:15, 02:45, 03:15

After accounting for non-existent 02:00 hour:

01:15, 01:45, 03:15, 03:45, 03:15

If data exists in the 02:00 hour, it must mean it was either recorded in error or was recorded in a time zone that doesn't observe daylight savings such as UTC or a constant offset from UTC.

For more information, see the TimeZone field in the Configuration section above.

If you are running into issues with connecting to or access data from SQL Connector, view our guide for troubleshooting datasource issues.

Performance considerations

View our guide on optimizing datasource performance for general guidance.

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.