{% hint style="warning" %} The following document assumes that you understand the basics of connecting to databases on Appsmith. If not, please go over them before reading further. {% endhint %}
Appsmith supports MySQL versions 5.5, 5.6, 5.7, and 8.0.
Appsmith needs the following parameters for connecting to a MySQL database:
{% hint style="success" %} All required fields are suffixed with an asterisk (*). {% endhint %}
You need to fill in the following parameters:
- Connection Mode*: You must choose one of the following two modes:
- Read Only: Choosing this mode gives Appsmith read-only permission on the database. This allows you to only fetch data from the database.
- Read / Write: Choosing this mode gives Appsmith both read and write permissions on the database. This allows you to execute all CRUD queries.
- Host Address / Port*: Fill in the database host’s address and port. If you don’t specify a port, Appsmith will try to connect to port 3306.
- Database Name*: Fill in the name of the database that you want to connect to. This is your database’s name.
You need to fill in the following parameters:
- Username*: Fill username required for authenticating connection requests to your database.
- Password*: Fill password required for authenticating connection requests for the given username to the database.
The SSL Mode can be set to one of the following values:
Default
: Same asPreferred
.Preferred
: Use SSL, if the server supports it.Required
: Reject connection, if SSL is not available.Disabled
: Connect without SSL, use a plain unencrypted connection.
More information available at MySQL documentation.
MySQL databases can be queried using the standard SQL syntax. All MySQL queries return an array of objects where each object is a row returned by the query and each property in the object is a column.
Normal query execution simply string concatenates the evaluated values of the javascript bindings to produce the final query. This opens up the possibility of SQL injection by merging untrusted user input with trusted data for execution. Using a prepared Statement is one strategy for mitigating this risk.
Appsmith converts the user query into a parameterized one by replacing the bindings in the query with '?'. The payload is then inserted one by one ensuring that the bindings get properly escaped and sanitized before the query is sent to the database for execution.
Follow the guide on how to use prepared statements for efficient and secured data transactions.
Once you have successfully run a Query, you can use it in your application to