Adapt Model when Linked Database Table is Modified

AIMMS uses ODBC to connect to database tables. When database table columns are linked to AIMMS identifiers, adding columns to the table may require you to adapt the model. In this article, we’ll show an example of how to adapt for changes in the database table definition.

The Basic Model and Table

../../_images/basicDatabaseTable.PNG

The schema of our database is represented above.

../../_images/basicAimmsModel.PNG

The schema is captured by the AIMMS Database Table as shown above.

AIMMS project download

The Added Column is a Derived Column

Now let’s add the column regionNM to the database table as a derived column. The database schema then looks as follows:

../../_images/derivedExtensionDatabaseTable.PNG

Note

For the sake of efficiency, AIMMS caches the knowledge of the table structure of the tables it is connected to. When these table structures are changed while AIMMS is still open, the caches need to be updated. The easiest way to do this is to close the project and open it again.

The extended structure is then captured in the AIMMS model as follows:

../../_images/derivedExtensionAimmsModel.PNG

You can adapt the database table lpdata by using the wizard at the mapping and add the added link. When the region data is not used in the model, you can even ignore this step.

AIMMS project download

The Added Column is a Key Column

This is more interesting. Following our running example, instead of making regionNM a derived column, it’s made a key column as shown in the following schema:

../../_images/KeyExtensionDatabaseTable.PNG

There are two approaches to handling this in the AIMMS model:

Approach 1: the Model Selects Only Data of a Single Region

1DatabaseTable db_lpdata {
2    DataSource: "data\\lpdata.dsn";
3    TableName: "lptable";
4    Mapping:  "regionNM" --> s_Regions;
5}

The statement below will read all regions.

read from table db_lpdata ; ! this will fill s_Regions

Subsequently, we will select a single region. This can be done via a statement like:

ep_SelectedRegion := first( s_Regions ); ! Just select one region.

This is an alternative to selecting the region via the user interface.

For the selected region, the data mapping becomes:

 1DatabaseTable db_lpdataID {
 2    IndexDomain: i_reg;
 3    DataSource: "data\\lpdata.dsn";
 4    TableName: "lptable";
 5    Mapping: {
 6        "loadport" --> i_lpn,
 7        "lpsize"   --> p_lpsize1(i_lpn),
 8        "regionNM" --> i_reg
 9    }
10}

The actual read statement becomes:

read from table db_lpdataID(ep_SelectedRegion); ! Read in the data for the selected region.

Approach 2: the Model Aggregates the Data over All Regions

The data mapping becomes:

1DatabaseTable db_lpdataAgg {
2    DataSource: "data\\lpdata.dsn";
3    TableName: "lptable";
4    Mapping: {
5        "loadport" --> i_lpn,
6        "regionNM" --> i_reg,
7        "lpsize2"   --> p_lpsize2(i_lpn,i_reg)
8    }
9}

And the data is read and aggregated as follows:

read from table db_lpdataAgg ; ! this will fill  p_lpsize2

p_lpsizeAgg(i_lpn) := sum( i_reg, p_lpsize2(i_lpn, i_reg) ); ! Aggregate over all regions.

AIMMS project download