The Mendix Platform offers many ways to integrate with external data, but integrating with external databases has not been a seamless experience until now. The Database connector module can be used to seamlessly connect to external databases without limiting you in your choice of database or SQL dialect, enabling you to incorporate your external data directly in your Mendix application. This document will focus on executing an SQL (Structured Query Language) Statement on relational external databases.
The Execute statement action (present in the Database Connector module) provides a consistent environment for Mendix projects to perform an arbitrary SQL Statement on relational external databases. JDBC (Java Database Connectivity) API, a standard Java API, is used when this Java action attempts to connect with a Relational Database for which a JDBC driver exists.
After completing this how-to you will know how to do the following:
- Execute SQL statements on relational external databases with the help of Database connector module.
- Configure ‘Execute statement’ action.
2 Prerequisites for the Execute Statement Action
Before you can start with this how-to, please make sure you have completed the following prerequisites.
- The Database Connector from the App Store
- A database URL address that points to your database.
- The username for logging into the database, relative to the database URL address.
- The password for logging into the database, relative to the database URL address.
- The SQL statement to execute, relative to the database type (SQL dialect differs for different databases).
- The JDBC driver jar, for the database you want to connect to.
The JDBC driver jars, for the databases you want to connect to, must be placed inside the userlib directory of your Mendix application. So if you want to connect to Amazon RDS PostgreSQL database (For e.g.
jdbc:postgresql://xyz-rds-instance.ccnapcvoeosh.eu-west-1.rds.amazonaws.com:5432/postgres), you need to place PostgreSQL Jdbc driver jar inside the userlib folder.
4 Using Execute Statement Action in a Microflow
- Look for the Database connector in the Toolbox.
Drag and drop the ‘Execute statement’ action to your microflow.
Provide all the valid arguments to the Execute statement action and specify output variable name of your choice, which in below mentioned case is
amountOfInsertedRowsis also the output of the SQL Statement which you provided for the
sqlargument within the connector.
The Execute statement action’s result is either an Integer or a Long value which usually represents the amount of affected rows.
- This database connector can be used for CREATE, INSERT, UPDATE, STORED PROCEDURE, DELETE or DDL SQL statements.
- This database connector should not be used for SELECT SQL queries.
The jdbcUrl argument, in the Execute statement connector, must specify a database URL that points to your relational database and is dependent upon the particular database and JDBC driver. It will always begin with “jdbc:” protocol text, but the rest is up to particular vendor. For example ‘jdbc:mysql://hostname/databaseName’ jdbcUrl format can be used for MySQL databases.
Proper security must be applied as this action can allow SQL Injection in your Mendix application.