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.
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:
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).
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.
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.
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.
It’s the responsibility of the organization using Dynamic AI to resolve and adhere to any user licensing issues to back-end database engines.
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. |
The fields included as part of the generic connection definition are used in different ways depending on the type of the data-source:
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.
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 |
|
Field: |
Sample value: |
Description: |
ODBC name |
MyODBC |
SYSTEM DSN name defined on Dynamic AI Server |
Time out |
|
|
Username |
|
|
Password |
|
|
Field: |
Sample value: |
Description: |
File or ODBC name |
MySybaseODBC |
|
Time out |
|
|
Username |
|
|
Password |
|
|
Field: |
Sample value: |
Description: |
File or ODBC name |
MySybaseODBC |
|
Time out |
|
|
Username |
|
|
Password |
|
|
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 |
|
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 |
|
Field: |
Sample value: |
Description: |
Database Catalog |
|
|
ODBC name |
|
|
Time out |
|
|
Username |
|
|
Password |
|
|
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 |
|
|
Field: |
Sample value: |
Description: |
ODBC name |
MyInformixODBC |
SYSTEM DSN Name defined on Dynamic AI Server |
Time out |
|
|
Username |
|
|
Password |
|
|
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”
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”
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 |
|
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 |
|
The following will describe how to work with the most common tasks regarding database connectivity.
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”.
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
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.
Be aware that all Reports using a certain connection will be removed when the connection is deleted.