Connecting with MySQLi
In Scriptcase, we have the following drivers available for connections with MySQL: MySQL PDO and MySQLi. If you are using your own pre-configured environment, MySQL extensions must be manually enabled in PHP.
Prerequisites
If you are using a manual installation on Linux, you’ll need to install the MySQL php extension. Check below how to do it.
1 - Access your Linux terminal and type this line below according to your OS to install MySQLi driver.
| Ubuntu | CentOS | 
|---|---|
| sudo apt-get install php8.1-mysql | sudo yum install php-mysql | 
2 - Check if the MySQL driver is enabled in your Scriptcase diagnosis. See below on how to locate your diagnosis and check if the driver is enabled.
- Accessing the top menu Help > Diagnosis, you can easily find it through the interface.

- Or, by accessing your Scriptcase installation path:
127.0.0.1/scriptcase/diagnosis.php or domain.com/scriptcase/diagnosis.php
Creating a Connection with ScriptCase
Server sent charset unknown to the client If you are using MySQL 8, and your Scriptcase is using PHP 7.0 or 7.3, due to the PHP 7 bug, an error occurs when trying to connect to the Scriptcase. Click here and see how to work around this error.
See below how to create a connection in your Scriptcase project using the MySQL database.
1 - Access any project from your Scriptcase.
2 - Click on the New Connection icon to create a connection.

or access the Database > New Connection menu tab.

After that, a new page will appear with all database connections.
3 - Select the MySQL connection.

Connection
Enter the parameters for connecting to your MySQL database as follows:

- 
   Connection Name: Define the name of your new connection. By default, Scriptcase adds the prefix conn along with the database name. 
- 
   DBMS Driver: Select the MySQL Driver used to connect. In this example, we use the MySQLi Driver. 
- Server/Host (Name or IP): Enter the IP or domain of the server where the database is installed.
   - E.g. serverdomain.comor192.168.254.170
 
- E.g. 
- 
   Port: Inform the number port for your database server. 
- 
   Username: Inform the user to authenticate the connection to your MySQL database. 
- 
   Password: Enter the password to complete the authentication process. 
- Database Name: Type your database name to connect with him. Or, if you want to choose one different database, click on the button List Database to show all databases availabes for your user.
   - Create Database: Clicking on this button, you will create a new MySQL database for use.
 
- Test Connection: Click on this button to get a response from the Scriptcase request to find out if the parameters entered are correct.

Security
On this tab you can set your SSL encryption for your database connection. Check below how to do this.

Use SSL
Activates or deactivates the use of secure connections with MySQL.
Client Key
Path to the client’s private identification key in the format PEM.
Client Certificate
Path to the client’s public certificate key.
CA Path
Path to the directory that contains the Certificate of Authority (CA) in the format PEM, if used, it should specify the same certificate used by the server.
CA Certificate
Path to the Certificate of Authority (AC) in the format PEM. This option, if used, should specify the same certificate as the server.
Specific Chipper
A list of permitted numbers to use with the cryptography of the connection. If one of the numbers is not supported, the SSL connection won’t work.
Filter
Accessing this tab, you can configure which Database items will be displayed on the connection, depending or not on the owner.

Show
It allows the MySQL connection to see tables, views, system tables and procedures depending on the items selected by the user. By default, the items Tables and Views are already selected by Scriptcase.
- Tables: By selecting this option, the tables in your database will be displayed.
   - By default, Scriptcase enables this option.
 
 
- By default, Scriptcase enables this option.
- Views: By selecting this option, the views of your database will be displayed.
   - By default, Scriptcase enables this option.
 
 
- By default, Scriptcase enables this option.
- 
   System Tables: By selecting this option, the system tables of your database will be displayed. 
- Procedures: By selecting this option, the procedures of your database will be displayed.
Searches
Allows you to define which tables and owners are displayed.
- Tables: You can define in this option which tables will be displayed. The configuration can contain a PREFIX%or name of the tables to display.- By default, Scriptcase leaves this option empty.
- E.g.
 
  
- Owner: Inform the user who sees the tables entered for display.
   - The user must be in capital letters as in the example above.
 
 
- The user must be in capital letters as in the example above.
- Show: Choose whether tables for the informed owner are displayed.
NOTE: By using table filtering, you eliminate unnecessary tables for your project and improves the performance of your database connection.
Advanced
In this tab, you have access to specific settings for the connection. The changes made in this session impact the data display and application performance.

- 
   client_encoding: Select the encoding used in your database. In the example above, we use the client_encoding UTF-8. 
- Decimal Separator: Select the type of separator for decimal records, between comma and period.
   - By default, the period .is selected as a separator.
 
 
- By default, the period 
- Persistent Connection: Define whether the connections will be closed after the execution of your scripts in Scriptcase applications.
   - By default, Scriptcase disables this option.
 
 
- By default, Scriptcase disables this option.
- Use the schema before table name: Define whether the database schema is displayed before the table names.
   - 
       By default, Scriptcase enables this option. 
- 
       E.g. 
  
- 
       
SSH
Here are the SSH options available in the image and their descriptions regarding database connection:

Use SSH
Enables or disables the SSH tunnel for database connection. When enabled, the database connection will be routed through the SSH server.
SSH Server
The IP address or hostname of the SSH server that will be used for tunneling. This is the machine that will act as a bridge to access the database securely.
SSH Port
The port used to connect to the SSH server.
SSH User
The username used to authenticate with the SSH server. This user must have permissions to establish an SSH connection.
Private cert. file
The private key file used for authentication if the SSH server requires key-based authentication instead of a password.
Local port for port forwarding
The local port on the client machine that will be used for forwarding database traffic through the SSH tunnel. This port acts as a bridge between the database client and the remote database.
Database server from SSH
The hostname or IP address of the database server as seen from the SSH server. This is necessary when the database is only accessible within the SSH server’s network.
Database port from SSH
The port of the database server that will be accessed through the SSH tunnel. This should match the database service’s listening port.