Start Free
SonarQube Community Build | Server installation and setup | SonarQube Community Build | Installing the database

Installing the SonarQube Community Build database

Several external database engines are supported. Check the respective requirements.

Create an empty schema and a sonarqube user. Grant this sonarqube user permissions to createupdate, and delete objects for this schema. 

Microsoft SQL Server

MS SQL database's shared lock strategy may impact SonarQube Community Build runtime. Making sure that is_read_committed_snapshot_on is set to true to prevent SonarQube Community Build from facing potential deadlocks under heavy loads.

Example of query to check is_read_committed_snapshot_on:

SELECT is_read_committed_snapshot_on FROM sys.databases WHERE name='YourSonarQubeDatabase';

Example of query to update is_read_committed_snapshot_on:

ALTER DATABASE YourSonarQubeDatabase SET READ_COMMITTED_SNAPSHOT ON WITH ROLLBACK IMMEDIATE;

Encryption

If your Microsoft SQL Server doesn't support encryption, you must add encrypt=false to the JDBC URL connection string.

If your Microsoft SQL Server requires encryption but you don't want SonarQube Community Build to validate the certificate, you must add trustServerCertificate=true to the JDBC URL connection string.

Integrated security

To use integrated security:

  1. Download the Microsoft SQL JDBC Auth 12.8.1 package and copy mssql-jdbc_auth-12.6.3.x64.dll to a folder location set in the PATH environment variable on SonarQube Community Build host.
  2. If you're running SonarQube Community Build as a Windows service, make sure the Windows account under which the service is running has permission to connect your SQL server. 
  3. Ensure that sonar.jdbc.username or sonar.jdbc.password properties are commented out or SonarQube Community Build will use SQL authentication.
sonar.jdbc.url=jdbc:sqlserver://localhost;databaseName=sonar;integratedSecurity=true

SQL authentication

To use SQL authentication, use the following connection string. Also, ensure that sonar.jdbc.username and sonar.jdbc.password are set appropriately:

sonar.jdbc.url=jdbc:sqlserver://localhost;databaseName=sonar
sonar.jdbc.username=sonarqube
sonar.jdbc.password=mypassword
Oracle

If there are two SonarQube Community Build schemas on the same Oracle instance, especially if they are for two different versions, SonarQube Community Build gets confused and picks the first it finds. To avoid this issue:

  • Either privileges associated to the SonarQube Community Build's Oracle user should be decreased.
  • Or a trigger should be defined on the Oracle side to automatically alter the SonarQube Community Build's Oracle user session when establishing a new connection: ALTER SESSION SET current_schema="MY_SONARQUBE_SCHEMA".
PostgreSQL
  • Must be configured to use UTF-8 charset.
  • If you want to use a custom schema and not the default "public" one, the PostgreSQL search_path property must be set:
ALTER USER mySonarUser SET search_path to mySonarQubeSchema

Was this page helpful?

© 2008-2025 SonarSource SA. All rights reserved. SONAR, SONARSOURCE, SONARQUBE, and CLEAN AS YOU CODE are trademarks of SonarSource SA.

Creative Commons License