Presto is a cool technology that works with everything (within reason). So it should be totally well documented how to set it up with IntelliJ, right?? Not so fast... #googlefail
UPDATE - IntelliJ and DataGrip now have drivers for presto and trino right out of the oven, so no need to read on!
If you like ancient history, feel free to keep reading :) Happy coding!
While it's not totally un-intuitive, many people trying to set it up might not see the options and give up. Don't give up, here's the coolness!
If you don't know by now, there's two forks of presto in the universe. Not surprisingly there is a JDBC driver for each and mostly they seem to be nearly identical, however at the time of writing, PrestoSQL's driver performed a bit faster for me. I encourage folks to follow their releases for more critical information.
PrestoDB, the original project by Facebook.
Trino, the rename of the fork PrestoSQL the fork of the project in the community
So just click the link under "JDBC Driver" and download it..
To a personal location:
Or copy it to intellij's location:
- In "Database" panel click
+or right click and select New -> "Driver"
- Enter "PrestoSQL" or "PrestoDB" in the name (whichever driver you chose.
- Under the "Driver Files" box, click the
+and browse to the downloaded jdbc jar.
- Pick the driver class (facebook or prestosql)
- Add the Datasource and use the Driver (and click "Test connection".)
- Right click on new Datasource->Database Tools->Manage Shown Schemas... select "All Databases" and also select "All Schemas".
The last step is particularly helpful if you presto is hosting multiple catalogs across database instances. If you're dealing with particularly large amount of tables, this step could take a while.
NOTE : make sure to use full url with jdbc protocol and port
Hopefully this will unlock all the presto possibilities for you!
- Queries across database instances.
- Single SQL syntax.
- Schema explorer and keyboard completion.
On the way, there could be a few "gotchas" so here's a quick list of things that could trip you up.
Make sure the protocols, address, and ports are correct. By default, presto runs on 8080 but if your team set it up with ssl 443 might be the right setup, or it could even be a custom port. You may also have basic networking issues, so test if you can even connect to the host/port (maybe through the ui if permitted by your systems team).
By default presto doesn't require credentials, so even though it shows username and password, you might be able to just put in "presto" and either blank or some garbage into password. On the other hand if presto is secured with file based store or LDAP you'll need to be granted credentials.
If presto is missing or has catalog access restrictions, you may not be able to see or query all of the datasources and schemas that presto is attached to.
Since IntelliJ isn't managing the driver, you'll be responsible for your own updates... Small price to pay, or we can all keep voting for this feature and maybe someday IntelliJ will add it.
If you don't like this, then have a look at DBeaver which supports PrestoDB and PrestoSQL without downloading the driver. Same caveats apply
IntelliJ's database explorer is slick and integrated experience and you can easily use any JDBC Driver. Presto in particular is one that is especially powerful.
Let me know if you have any comments or feedback. Enjoy!