New Database Connection

Users that have the permissions to:

 

Connection Maintenance

 

will get access to maintain connections through the Databases menu in Dynamic AI.

 

Through Databases , connections to databases can be added, modified and deleted. Connection maintenance is a powerful Dynamic AI feature that should be given to administrators and/or developers type of users only.

 

During connection definition it must be decided which user or group of users, should be allowed to explore this database connection, providing that the individual user or user being member of the group have the overall right to Explore Databases .

 

The combination of the two types of rights combined with the user/group assignments gives a wide range of flexibility. Combined with the possibility to separate Dynamic AI administration from database user / password administration allow for further restrictions on security depending on the functionality of the background database.

 

The connection definition can include @aliasn parameters. This can be used to restrict the connection to a specific server depending on the user account details.

 

Connections can be marked READ-ONLY, which will disable Dynamic AI’s standard functionality to list-edit and insert, update and delete records through Dynamic AI forms.

 

It’s possible to divide the development and administration task in Dynamic AI by giving developers access to Reports created as “master Reports” from where new Reports can be developed and distributed – without the developers having a need to explore or administrate Databases . Whether this split of responsibility is efficient depends on the task, organization and sensitivity of information.

Database drivers and the connection architecture

Dynamic AI is using OLEDB or ODBC to connect to background databases. Depending on the database provider some pre-requisites such as installation of database drivers or client software might be necessary in order for Dynamic AI to function.

 

Some functionality might only be available with certain database providers and/or driver versions:

Connection pooling

When using ODBC drivers and connections defined through the 32-bit ODBC administration available in the control panel in Microsoft Windows, drivers can be globally set to allow connection pooling.

 

Connection pooling can speed-up access to background data-sources, as connections can be re-used internally (connections are only re-used if accessed with security settings similar to the existing connection).

Rollback/commit

Specifically for the Microsoft SQL Server and Oracle database connections defined in Dynamic AI, rollback/commit functionality is being utilized to give better control and error-handling to end-users using Dynamic AI list editing functionality.

Performance (Oracle client cursors)

In general OLE-DB connections perform much better than ODBC connections.

 

Therefore it is recommended to use the specific OLE-DB types of connections in Dynamic AI (e.g. Microsoft SQL Server) instead of ODBC definitions whenever possible.

 

As a general rule Dynamic AI use server-side database cursors in order to gain maximum database performance. However for data-entry tasks on Oracle database connections a client side cursor is being used for internal Dynamic AI reasons.

Security

As explained above, Dynamic AI is by default using one central database connection, having one defined user and password as the central database account for all users within Dynamic AI using Reports that uses that particular connection.

 

It is possible to parse username and password from the alias fields on the user account to the username and password fields on the connection ID by specifying e.g.: @alias1 in the username field and e.g.: @alias2 in the password field on the connection definition. As this however will result in eventual differences in terms of available tables and views on the connection, this combination of options must be used carefully. Another disadvantage is that database usernames and passwords will have to be separately maintained on the user account, which normally is not the preferred solution.

Licensing

It’s the responsibility of the organization using Dynamic AI to resolve and adhere to any user licensing issues to back-end database engines.

Connection Definition

From the New Database Connection in the Databases menu, the main screen for connection definition is available:

 

 

 

A connection definition includes the following fields depending on the type of connection:

 

 

Field:

 

Sample value:

 

Description:

Connection ID

MyNewConnection

Dynamic Connection Identification (the ID/name used to refer to this connection in Dynamic AI)

Usergroup

Developers

The group of users that if they have the right to explore connections can see, use and explore this database connection.

Type

Microsoft SQL Database

Oracle Database

Access Database

Excel Spreadsheet

IBM DB2

IBM DB2 OLEDB

My SQL Database

Visual FoxPro OLEDB

Sybase

Borland Interbase

Informix

PostgreSQL

Pervasive SQL

FlexODBC

ODBC Connection

The type of the back-end database

Server

SQLServer1 or 

10.10.11.11

The database server DNS name or the IP address of the database server. Direct IP address is supposed to be the fastest way to lookup the server.

Database Catalog

 

Used to specify database catalogs on database servers that require these (such as Oracle).

TNS name

Locally defined TNS name

TNS name defined on Dynamic AI Server

File or ODBC name

C:\data\mysales.mdb

Used to specify file-based data-sources. Be aware that the path to the file must be from the Dynamic AI server’s point of view, and that access to network drives or NTFS folders might require the Dynamic AI web user account to have access to the path.

Time out

120

In seconds

Username

RepUser

Username that Dynamic AI will use to connect to the back-end data-source

Password

*******

The password that Dynamic AI will use when connecting to the back-end data-source

Read only

Checked

Unchecked

Default unchecked. Check this option if the connection should be a READ ONLY connection from within Dynamic AI.

Allow preview

Checked

Unchecked

Default checked. Normal preview is allowed.

List Style

Standard List 01

The default style used for list and report presentations when browsing data-sources and at the same time the default style selected when Reports are created on the connection.

Form Style

Standard Form 01

The default style used for form and auto-form presentations when browsing data-sources and at the same time the default style selected when Reports are created on the connection.

Specific parameters for certain database providers

The fields included as part of the generic connection definition are used in different ways depending on the type of the data-source:

Microsoft Access Database

A Microsoft Access Database is a file-based database that will be located on a local or shared network drive. If the file is located on a NTFS or other type of drive that require specific user permissions, the user account that is used for the Dynamic AI IIS web must have access permissions to the file.

 

 

Field:

 

Sample value:

 

Description:

File or ODBC name

C:\Program Files\Dynamic AI\DAT\V6_Demo.mdb

Use Browse button to locate file

Password

Database password if used

 

 

It is also possible to connect to Microsoft Access System databases by location the .mdw file in the “System Database (system.mdw) field.

Excel spreadsheet

An Excel spreadsheet can be viewed as a database if the sheet has been defined with range names to data tables. Obviously an Excel file is a file-based database that will be located on a local or shared network drive. If the file is located on a NTFS or other type of drive that require specific user permissions, the user account that is used for the Dynamic AI IIS web must have access permissions to the file.

 

 

Field:

 

Sample value:

 

Description:

File or ODBC name

C:\data\mysales.xls

 

ODBC Connection

 

Field:

 

Sample value:

 

Description:

ODBC name

MyODBC

SYSTEM DSN name defined on Dynamic AI Server

Time out

 

 

Username

 

 

Password

 

 

ODBC for Sybase

 

Field:

 

Sample value:

 

Description:

File or ODBC name

MySybaseODBC

 

Time out

 

 

Username

 

 

Password

 

 

ODBC for Sybase Adaptive Server

 

Field:

 

Sample value:

 

Description:

File or ODBC name

MySybaseODBC

 

Time out

 

 

Username

 

 

Password

 

 

Oracle 8 Database

An Oracle database server is a high performance full-featured database server engine for Dynamic AI. In order for Dynamic AI to connect to the server, separate client software provided by Oracle must be installed on the Dynamic AI server. The requirement is limited to a simple Net8 type of client.

 

 

Field:

 

Sample value:

 

Description:

Database Catalog

Database Catalog name

 

TNS Name

Locally defined TNS name

TNS name defined on Dynamic AI Server

Username

Oracle database user

 

Password

Oracle database user password

 

 

Microsoft SQL Database

A Microsoft SQL Server e.g. version 7 or later is a high performance full-featured database server engine for Dynamic AI. In order for Dynamic AI to connect to the server, the database must accept SQL Server authentication.

 

 

Field:

 

Sample value:

 

Description:

Server

SQLServer1 or 

10.10.11.11

 

Database Catalog

 

Leave Blank

Database name

Database name on the SQL Server

 

Time out

120

In seconds before Dynamic AI will time-out if no response from the server.

Username

Valid SQL Server user name with access to the database

 

Password

SQL Server Password for the user account

 

IBM DB2

 

Field:

 

Sample value:

 

Description:

Database Catalog

 

 

ODBC name

 

 

Time out

 

 

Username

 

 

Password

 

 

IBM DB2 OLEDB

 

Field:

 

Sample value:

 

Description:

Server

DB2Prod

Host Name or IP Address of DB2 Server

Database Catalog

 

 

Database name

Mydb

Name of database

Time out

 

 

Username

 

 

Password

 

 

ODBC for Informix

 

Field:

 

Sample value:

 

Description:

ODBC name

MyInformixODBC

SYSTEM DSN Name defined on Dynamic AI Server

Time out

 

 

Username

 

 

Password

 

 

MY SQL Database

 

Field:

 

Sample value:

 

Description:

Database Catalog

 

 

ODBC name

MyDatabase

Name of the Database on the server

Ttime out

 

 

Username

myUserID

 

Password

Password for the account above

 

Note: Connections to MySQL requires the third party Ole DB provider; “MySQLProv”

BORLAND Interbase

 

Field:

 

Sample value:

 

Description:

File (full-path)

[Servername]:c:\database\

Only use [Servername] (without brackets) if database is stored on a different computer

Time out

 

 

Username

Sysdba

 

Password

Password for the account above

 

Note: Connecting to Interbase requires the third party component; “Easysoft IB7 ODBC”

VISUAL FOXPRO OLEDB

 

Field:

 

Sample value:

 

Description:

File (full-path)

C:\data\mydb.vfp

Use Browse button to locate file

Ttime out

 

 

Username

MyUserID

 

Password

Password for the account above

 

ODBC for Pervasive SQL

 

Field:

 

Sample value:

 

Description:

Database Catalog

 

 

File or ODBC name

PervasiveDSN

System DSN name defined on the Dynamic AI Server

Default time out

 

 

Username

MyUserID

 

Password

Password for the account above

 

Common database tasks

The following will describe how to work with the most common tasks regarding database connectivity.

Add a database connection

To add a new database connection click on the “New Database connection” in the Databases menu.

 

A blank form for data-input will be presented:

 

 

Enter a unique name (ID) for the database connection; select the type of data-source from the drop-down selection list and fill the parameters as described above for the specific data-type.

 

Optionally the connection settings can be tested against the background database by clicking “Test Connection”.

 

Modifying a connection definition

If needed connection settings can be modified, e.g. when the password for the database user is being changed.

 

Click on the connection in the Databases menu under Explore Databases and then click on the Connection name to view the Connection Definition.

 

Change relevant settings and optionally test that the changes will successfully connect to the database.

 

As Dynamic AI references the name of the defined connection and not the specific data-type, back-end system changes can be accommodated very easily simply by changing the data-source type. An example of this is a Dynamic AI application being used with a connection ID PRODDATA connected to a Sybase database installation. A change of environment to, for instance, a Microsoft SQL Server 2000 can be done by modifying the data-source type to Microsoft SQL Server.

 

Even though this functionality makes the back-end transparent to end-users and proves that Dynamic AI applications are true multi-layered client/server applications, it should be noted that compatibility depends on the back-end data-sources for the following items:

 

Dynamic Views defined with specific features that are differently supported by the 2 back-ends.

Free condition filters, where specific back-end notation or functions is being used

Deleting a connection

Before deleting a connection, be aware that all definitions in Dynamic AI, if data-bound, will reference a connection. Deleting a connection will therefore make all related Dynamic Views, Dictionary definitions, Reports and Relationships obsolete. In order to keep integrity in the Dynamic AI application repository, deleting a connection will cascade deletion of all related definitions.

 

Example: 50 report Reports have been defined on Connection ID PRODDATA. Deleting the PRODDATA connection through Connection maintenance will remove the 50 Reports and they will no longer be available in Dynamic AI.

 

In order to get an overview of the impact of deleting a connection ID, the Reports  menu can be set to organize available Reports by DB Connection (Database Connection ID). Be aware however, that Reports might be defined on the connection ID and shared to users and groups that the administrator is not seeing in his navigation menu.

 

If a connection needs to be deleted, click on the connection in the Databases menu under Explore Databases and then click on the Connection name to view the Connection Definition.

 

In order to remove the connection, click on the Delete button at the bottom of the screen.

Impact on Report definitions when deleting connections

Be aware that all Reports using a certain connection will be removed when the connection is deleted.