What's New in DataGrip 2021.2
What's New in DataGrip 2021.2
DataGrip 2021.2 is here! This is the second major update of 2021, and it’s packed with various
enhancements. Let’s take a look at what it has to offer!
DDL data source
DDL data source generation is another step in our long-term development of seamless
database versioning. With this feature, you can keep your DDL files under a VCS
system and regenerate them every time your database structure is updated.
It is now possible to generate a DDL data source based on a real one. The DDL
files are created locally and the new data source is based on them. This way
you’ll always be able to regenerate these files and refresh the DDL data source.
Let’s take a look at how this works.
data:image/s3,"s3://crabby-images/c8490/c84901d91cc714f21e1b7b9e766a3860093bf73a" alt=""
We’ve added a new menu item, Dump to DDL data source, to the SQL Scripts
context menu.
data:image/s3,"s3://crabby-images/3dead/3deadc11f828530b3d46317756bae4c228d34935" alt=""
When the dialog opens, you need to specify the folder where the newly created
files will be stored.
data:image/s3,"s3://crabby-images/79c6a/79c6ad33992e28deb8c5bb53e37020a48d2d71f7" alt=""
On the Generation tab, specify how these DDL files should be generated.
data:image/s3,"s3://crabby-images/1115a/1115a2dee4f352f194baf0847ad0303c1f6ee2f6" alt=""
Finally, click OK to create the DDL data source.
data:image/s3,"s3://crabby-images/ceb10/ceb10f2c7306252177f23fafccd03df33ea2ca80" alt=""
The folder with the new files is automatically attached to your project.
data:image/s3,"s3://crabby-images/22858/22858d17d7d38add974700408981a8c7c7bd8537" alt=""
Creating objects
In v2021.2, you can create objects in a DDL data source via the UI.
The corresponding files will be created locally.
Diagrams
data:image/s3,"s3://crabby-images/50ab8/50ab8fdee5f93cb423ce91e865970cfcf0a8d149" alt=""
The following important features have been added to diagrams:
Table comments are now visible
Table colors are displayed on the diagram
You can turn off edge merges
Quality improvements:
DBE-: We have improved the algorithm
that draws diagrams, so the names of the objects no longer overlap with relation
lines.
DBE-: The notes are no longer lost
on save.
Code editor
data:image/s3,"s3://crabby-images/24f79/24f795df0f296575e3daa9d777a9ebd062245d9b" alt=""
Search in Local History
If you are looking for a particular revision in Local History, you can use
text search for help!
data:image/s3,"s3://crabby-images/4ef21/4ef2125d4f4454d32630064339c34230baeaa819" alt=""
Local History for sources
DataGrip now tracks local changes for object source codes. It can be especially
useful when working with procedures and functions.
Since every object's sources are stored in a file, all external changes are also
considered as local changes. When you introspect your database, this file is refreshed.
You can use the Local History popup to keep track of any changes to a function
or procedure. Note that all external changes are considered as one change if they
happened within two runs of the introspection.
data:image/s3,"s3://crabby-images/0af3e/0af3ea72e60f80949b986c2dac87c14815e522d5" alt=""
Long tab names are back
After receiving some feedback from users who didn’t like the shortened tab names,
we introduced the option to change them back. If you prefer long tab names, uncheck
the Shorten Tab Titles option.
data:image/s3,"s3://crabby-images/ac948/ac94821239fd22500bae501b757e0c38ce56e366" alt="Shrinking selection"
Maximize Editor / Normalize Splits action
For a long time we had the Hide All Tool Windows action, which could be
called by double clicking on a tab or pressing
Shift+Ctrl+F12. Many users treated it as a
Maximize Editor action and it worked as such!
After we introduced the split mechanism, the situation became more complicated.
Should this action hide the split tabs or not? So we did the following:
The Hide All Tool Windows action no longer hides the split tabs.
The new Maximize Editor / Normalize Splits action maximizes the
current tab, but doesn’t hide the tool windows.
Code completion
data:image/s3,"s3://crabby-images/861c6/861c6cdeaf4e64a7d32f3b3bb01d0807e6cbb723" alt=""
Completion scope
Now it's possible to define which objects should be presented in the code completion
list: objects only from the schema switcher (or the search path), from the current
scope, or from all schemas.
Suggest only search path objects: only objects from the schemas chosen
in the schema switcher are suggested.
Suggest objects from current scope (default setting): the list will
be populated with the objects DataGrip can correctly resolve without
qualification – the set of objects from the schema switcher, USE statements,
and the default schema.
Suggest objects from all available schemas: the list will contain all
objects from all available schemas.
This can be also managed by smart completion. Smart completion is invoked when you
press the completion hotkey (usually Ctrl+Space) several times.
Pressed once or invoked automatically: as described above.
Pressed twice: all schemas except those turned off for the introspection.
Pressed three times: objects from all available schemas and databases.
data:image/s3,"s3://crabby-images/14688/14688352897c8a01cd305b3fb417d3cde90056a0" alt=""
Completion of fields and operators
MongoDB
Fields and operators are now available in code completion for MongoDB. Read
this post for more details.
data:image/s3,"s3://crabby-images/c1e79/c1e792ca5efa8ca7a265dc183baa7740e9d6e025" alt=""
Completion for cross-database synonyms
SQL Server
Code completion for cross-database synonyms is now available.
data:image/s3,"s3://crabby-images/e8f30/e8f30ff2502cbf0d69ecf78a2af9502d81e85cc4" alt=""
INSERT completion and computed columns
Computed columns are taken into account when completing
statements – they are not included in the suggested item.
Quality improvements
DBE-,
DBE-2212:
Objects from the schema of the current context have higher priority in the code
completion list.
DBE-7781,
DBE-:
The automatic alias appears only when needed.
DBE-:
Table qualification in completion works as expected.
DBE-:
The priority of inside an clause has
been increased.
DBE-:
PostgreSQL
Completion in statements works as expected.
Code highlighting
data:image/s3,"s3://crabby-images/26104/26104428014d8f5f2cb25eb7a0b6ac3ed2fc5572" alt=""
Support for recursive CTE
Redshift
Queries that use recursive common table expressions are now properly highlighted
and can be run without being selected.
data:image/s3,"s3://crabby-images/2ec46/2ec46da573208cb165d36e9e6be335124e2be8d1" alt=""
Better CTE support
ClickHouse
The common table expressions syntax, when the CTE name goes before the
keyword, is now supported.
Quality improvements
DBE-3759,
DBE-,
DBE-:
Inspections for aggregates work more precisely.
DBE-:
ClickHouse
No more false-positive alerts from the inspection that reports not-null arguments
in .
DBE-:
Oracle
PL/SQL record type fields are resolved correctly.
DBE-:
DB2
Table aliases are resolved correctly.
Database explorer
data:image/s3,"s3://crabby-images/efa74/efa741e8f21e4229dd1a4a9820ad1be0c49558bc" alt=""
Separate folders for functions and procedures
If you turn on the Separate Procedures and Function option in the database
explorer settings (the gear icon), it will immediately take effect.
For SQL Server there are dedicated nodes for scalar and table functions.
For PostgreSQL there is a node for trigger functions.
data:image/s3,"s3://crabby-images/01349/01349293daf00aa93b608d31939aa535fc25a93e" alt=""
Separate nodes for triggers, keys, and indices
A new database tree option, Show Constraints and Triggers in the Schema,
assigns triggers, keys, and indices their own individual nodes in the database explorer.
Why is this useful?
You can find an object inside one schema by using quick search.
You can see the columns just under the table node. To do this, make sure the
Show Empty Groups option is turned off.
Natural sort order for database objects
If you turn off the Sort Alphabetically option in the database explorer
settings, natural sorting for objects will be applied.
Here’s what it looks like when Sort Alphabetically is off:
data:image/s3,"s3://crabby-images/70950/709505ff35e9e940872be8c917fb75893dc6b6c5" alt=""
Here’s what it looks like when Sort Alphabetically is off:
data:image/s3,"s3://crabby-images/9b1cc/9b1ccc2b2e8fc38c64939f03e36080ed8b3d0803" alt=""
...and when Sort Alphabetically is on:
Introspection
data:image/s3,"s3://crabby-images/7d127/7d1272914758b0cd935adaa925636425b0587428" alt=""
Native introspection
CockroachDB
CockroachDB will be fully supported in this release. DataGrip will no longer rely
on JDBC-based introspection, but use the native one instead.
This is much faster than JDBC-based introspection. Also, role, deftype,
and check constraint could not be introspected at all in the previous version.
The full list of objects that are now introspected includes database,
role, privilege, schema, sequence, deftype,
table, view, mat view, index, column,
and constraints. That partitions are not introspected yet is a
known issue.
Virtual foreign keys for pg_catalog
PostgreSQL
Some time ago, we announced a mechanism for
creating virtual foreign keys.
Now we’ve used this mechanism to cover pg_catalog with virtual foreign keys.
This brings a couple of improvements.
data:image/s3,"s3://crabby-images/dc58e/dc58e9638d1bc89ddd5f18b7f37d93487f247485" alt=""
First, completion helps you when querying system tables:
data:image/s3,"s3://crabby-images/af924/af924482a691371b0699437ea611c6fb3c4f9b4c" alt=""
Second, you can navigate by data in system tables:
data:image/s3,"s3://crabby-images/841d0/841d066b9d959ce2140da0ab6694914ae552c26b" alt=""
Tablespaces
Oracle
We added support for tablespaces, data files, and temporary files.
They are now introspected:
data:image/s3,"s3://crabby-images/885d7/885d78bfc707f49418bbff990b5efcad6baa339b" alt=""
They are also included in DDL generation:
data:image/s3,"s3://crabby-images/08c47/08c4755932fb3af2fc4107f2251a7f044c78eda1" alt=""
Linked Servers
SQL Server
This isn’t full support yet, because metadata is not available for objects
in linked servers. Linked servers are shown in the database explorer, and
the DDL for their creation can be generated.
Data editor
data:image/s3,"s3://crabby-images/7303b/7303bd3e79039a485418dbacff85ee497344b0d3" alt="Shrinking selection"
Context live templates from the data editor
Introduced in the previous release, context live templates now work from the
data editor. If you’re working with a table and you wish to query it, you can
easily do so with the help of the SQL Scripts action.
data:image/s3,"s3://crabby-images/e13e0/e13e011a2797d609554c6eec6e50346054ecc7a0" alt=""
Option for additive sorting
We recently introduced Alt+Click for additive sorting. But if you
prefer using Click, you can customize this behavior:
data:image/s3,"s3://crabby-images/d5ed7/d5ed7e924f76b73936ccf574404cea0a22c1984d" alt="Shrinking selection"
Add/delete column
MongoDB
You can now add columns to MongoDB collections. This action lets you add a new
field to any document of a collection.
Delete column will delete data not only on the page that is being displayed,
but also throughout the whole collection.
data:image/s3,"s3://crabby-images/4be1e/4be1e853ee60cfc81d53683402740ef175bc6cf9" alt="Shrinking selection"
Adding/renaming columns in CSV files
With the help of the UI data editor, you can now add and remove columns in CSV files.
data:image/s3,"s3://crabby-images/7aef3/7aef3e68b3ae3808cac8c7d536d723e89d9834cd" alt=""
Copy query to console
When working in a data editor, you might sometimes use complicated clauses in
and fields. If you want to continue
working with the resulting query, use a new action, Copy Query to Console,
under the gear icon. It opens the query in the default console.
data:image/s3,"s3://crabby-images/b5c52/b5c520f983ba3acf3e390586eab245e55a54655f" alt="Shrinking selection"
No more First row option in navigation by foreign keys
To make the navigation faster, we’ve removed the First row option.
No popup will be displayed, and you will be navigated to the table that shows
all referencing or referenced rows.
data:image/s3,"s3://crabby-images/9add1/9add1459dfd56a166ec1c3148c7c4bdf6cf44ff1" alt=""
Qualification in navigation by foreign keys
If you have foreign keys pointing to objects in another schema and these objects
have the same names, they will be displayed as qualified in the foreign keys
navigation UI.
Quality improvements
DBE-:
The size of the field is saved.
DBE-:
The time zone is always shown for values with a time zone.
DBE-9814:
Oracle
type values don’t display time if no time is set.
DBE-:
Oracle
Filtering by the field is possible.
DBE-:
DB2
Filtering by binary, blob, char for bit data, and
varchar for bit data fields is possible.
Import/Export
data:image/s3,"s3://crabby-images/ef8aa/ef8aad98dd583c74919d4273063d9a8ccbede88d" alt=""
Table link after import
When you finish an import, a link to the new table appears in the notifications.
Quality improvements
DBE-:
Export of numeric fields no longer fails if there are non-numeric values.
DBE-,
DBE-,
DBE-:
Importing became faster for PostgreSQL, Redshift, Exasol, Hive, Clickhouse,
DB2, and HSQL.
Navigation
data:image/s3,"s3://crabby-images/b69d5/b69d5578bdab1e67955220eb6778779e45b93ad6" alt=""
Behavior of the Enter key in the navigation bar
The behavior of the navigation bar is now more straightforward – the
Enter key always expands the node.
Before, the Enter key opened data for tables and opened consoles for data sources.
If you want to navigate from the object in the navigation bar rather than opening
its node, you can use these navigation shortcuts:
Open DDL: Ctrl+B
Open data: F4
Select in the database tree: Alt+Shift+B
data:image/s3,"s3://crabby-images/3a78d/3a78d7bd8a8d4c824187cbfffb8c8823f7db5c2f" alt=""
Signatures in the Go To popup
Now, when you are searching for a function, procedure, or operator, DataGrip
shows the signature in the Go To window. This helps when you use overloading
heavily.
General
data:image/s3,"s3://crabby-images/3154c/3154c75e20fbf317e0baf6b5a99a542b2a2904c3" alt=""
Localized UI
Starting from this version, you can enjoy the fully localized UI of DataGrip in
Chinese,
Korean and
Japanese.
Localization is available as non-bundled language pack plugins, which can be
easily installed to DataGrip. More than
1.5 mln users started using the partially localized EAP version of our language packs.
Now you can enjoy the full localization experience!
data:image/s3,"s3://crabby-images/45002/450025d39a955d77ab4a65ff0b17d36ff6029799" alt=""
New location for projects
In DataGrip, projects are now located by default in the same place as they are
in all other IntelliJ-based IDEs – in the user’s home folder, inside the
DataGripProjects subfolder.
Your project in DataGrip is a complex of your data sources, console and scratch
files, and attached folders. They were previously stored in the
configuration folder, meaning that each time
you updated your IDE, the projects were copied, along with IDE settings.
This sometimes caused the data source list to become empty. This problem has been
solved, and now DataGrip behaves consistently with other IDEs.
Because of errors in project migration, those who used the first EAP build might
have lost their Favorites, Bookmarks, Run Configurations, or data about virtual
foreign keys. To restore them, please migrate from the previous version again.
The details are described here:
DBE-.
Settings
data:image/s3,"s3://crabby-images/ee8a2/ee8a22ad901a380a2abdb1ade0518dbb417ddf2d" alt=""
Back and forward buttons
These buttons make it easier to navigate in the Settings window and not get
lost there.
data:image/s3,"s3://crabby-images/f6383/f6383ef2111cc846d1f270d0a7ffb2da6223f70f" alt=""
Advanced Settings
We’ve added Advanced Settings as a new node in Preferences/Settings.
It contains some use-case-specific options conveniently grouped by IDE tool. Most
of the settings have been transferred from the Registry, though some of them
are new.
A couple of notable settings:
Left-hand margin in Distraction-free mode.
Ability to set the caret to move down after you use the
Comment with Line Comment action.
Customizing the behavior of double-clicking on a tab.
data:image/s3,"s3://crabby-images/5eeb6/5eeb65e13c222ed8b955d80969a6d274235237a5" alt=""
Show scratch files action
A new Show Scratch Files action (found via Find Action:
Cmd+Shift+A) shows a list of scratches with snippets in a popup.
It has the same UI as the Recent Locations popup with speed-search and deletion.
data:image/s3,"s3://crabby-images/ff398/ff398f6df3461223d919c31ca5da3b896ae14d72" alt=""
Managing the Services tool window popups
When a query returns no data, there’s no need for the Services tool
window to appear if it was hidden already. Now you can define which operations
make the Services tool window appear on your own.
Quality improvements
DBE-:
PostgreSQL
We’ve reworked the introspector. For you, the main effect of the new introspector
is – no more object duplicates!
DBE-:
No more freezing when typing statements along with using virtual
foreign keys.
DBE-:
Empty scratch files are now automatically removed.