You can use CockroachDB in IntelliJ IDEA as a database data source, which lets you accomplish tasks like managing your database's schema from within your IDE.
As of CockroachDB v20.2, IntelliJ IDEA only has partial support. This means that the application is mostly functional, but its integration still has a few rough edges.
The level of support in this document was tested as of the following versions:
- CockroachDB v19.1.0-beta.20190225
- IntelliJ IDEA Ultimate 18.1.3
- PostgreSQL JDBC 41.1
This feature should also work with other JetBrains IDEs, such as PyCharm, but Cockroach Labs has not yet tested its integration.
Warnings & Errors
Users can expect to encounter the following behaviors when using CockroachDB within IntelliJ IDEA.
- Warnings do not require any action on the user's end and can be ignored. Note that even if a message indicates that it is an "error", it can still be treated as a warning by this definition.
- Errors require the user to take action to resolve the problem and cannot be ignored.
[XXUUU] ERROR: could not decorrelate subquery...
Displays once per load of schema.
 ERROR: unknown function: pg_function_is_visible() Failed to retrieve...
Display periodically. Does not impact functionality.
 org.postgresql.util.PSQLException: ERROR: column "n.xmin" does not exist
Requires setting Introspect using JDBC metadata (details below).
Set CockroachDB as a Data Source in IntelliJ
- Launch the Database tool window. (View > Tool Windows > Database)
- Add a PostgreSQL data source. (New (+) > Data Source > PostgreSQL)
On the General tab, enter your database's connection string:
Field Value Host Your CockroachDB cluster's hostname Port Your CockroachDB cluster's port. By default, CockroachDB uses port 26257. Database The database you want to connect to. Note that CockroachDB's notion of database differs from PostgreSQL's; you can see your cluster's databases through the
User The user to connect as. By default, you can use root. Password If your cluster uses password authentication, enter the password. Driver Select or install PostgreSQL using a version greater than or equal to 41.1. (Older drivers have not been tested.)
Install or select a PostgreSQL driver. We recommend a version greater than or equal to 41.1.
If your cluster uses SSL authentication, go to the SSH/SSL tab, select Use SSL and provide the location of your certificate files.
Go to the Options tab, and then select Introspect using JDBC metadata.
You can now use IntelliJ's database tool window to interact with your CockroachDB cluster.
Report Issues with IntelliJ IDEA & CockroachDB
If you encounter issues other than those outlined above, please file an issue on the
cockroachdb/cockroach GitHub repo, including the following details about the environment where you encountered the issue:
- CockroachDB version (
- IntelliJ IDEA version
- Operating system
- Steps to reproduce the behavior
- If possible, a trace of the SQL statements sent to CockroachDB while the error is being reproduced using SQL query logging.