DataGrip快捷键及使用技巧
快捷键
功能
快捷键
打开表
Command + O
打开DDL
Command + B
将DDL打开到console中
Command + Option + Shift + B
新建console
Command + Shift + L
打开console
Command + Shift + F10
格式化SQL
Command + Option + L / Command + Shift + Enter
最近记录
Command + E
console query历史
Command + Option + E
提交
Command + Enter
新增记录
Command + N
删除记录
Command + Backspace
回退
Command + Option + Z
刷新
Command + R
上一页
Command + Option + ↑
下一页
Command + Option + ↓
断开数据库/停止执行
Command + F2
查找
Command + F
条件历史
Option + ↓
全部收起
Command + -
使用技巧
从Navicat和DataGrip的区别来说
数据的复制
复制数据分三种情况:
复制为Insert或Update语句
复制某一列多个值(一般用于关联表in查询)
复制为表格数据
Navicat
复制为Insert或Update:右击数据,选择复制为insert/update语句
复制某一列多个值:选中要复制的数据,复制,粘贴到文本编辑器中编辑为in(1,2)的格式,再复制到Navicat使用;
复制为表格数据:选中数据直接复制。
DataGrip
三种情况统一在打开表的右上角选择,选项如下(本来想贴图的一直上传失败):
SQL Inserts
SQL Updates
Where Clause
CSV
HTML
JSON
……
选项很多,选中某个选项之后,直接选中数据Command + C复制即可。
比如要选多个值去关联表用in查询,直接选中多个值,右上角选择Where Clause,复制出来直接是:"in (1,2)"的格式,省的自己改了。
快速打开表
这个功能跟IDEA的双击Shift搜索是一样的。
Navicat
之前用Navicat找表,首先要打开库,然后去搜索,而且搜索必须是正确拼写才能搜到。
DataGrip
而DataGrip找表,直接双击Shift,就显示出来了所有库包含这个名字的表,可以缩写,可以不写下划线(不写下划线就很爽)。
当然了如果只想在打开的库里面找也行,不需要双击Shift这个搜索,直接在鼠标焦点在数据库浏览器的情况下,直接输入库名就可以,也是可以不输入下划线的。
双击Shift搜索的时候,有时候会有个小烦恼,比如我打开了t_product的表的DDL,这时候搜索结果里面显示的这个库的表就只能跳到已经打开的DDL。需要手动在DDL点击一下“Edit Data”图标或者按Command + ⬇︎跳转到表数据页。
编辑SQL
SQL复制到Query Console之后,第一步格式化。
Navicat
之前Navicat格式化之后,SQL从横向的巨长无比变成了纵向的巨长无比,看着很费劲。而且要改某个字段需要一个一个对照,别提多费眼了。
DataGrip
DataGrip的格式化,会把SQL按行的长度自动换行,格式化后基本一目了然。而且在编辑SQL的时候,选中字段的时候,对应的值会高亮,选中值时,字段会高亮。可以说是太好用了。
Query Console小连招:
Command + Shift + L 打开一个新的Query Console
Command + V 粘贴SQL
Command + Option + L 格式化SQL
万用的Command + Enter
Navicat
之前用Navicat,在Query Console中执行SQL快捷键是Command + R,修改数据的话,修改完点其他地方默认直接保存,如果是生产环境手抖了,想恢复到几秒钟之前都是难事。
DataGrip
Query Console中执行SQL?Command + Enter!
修改完数据保存?Command + Enter!
选中表要打开?Command + Enter!
总是不管你干什么,要确认的时候就Command + Enter!
不仅好记,而且生产环境数据就算改了,想恢复,只要没提交,Command + R刷新一下就ok了,确认好再提交哦。
之前用Navicat的时候,表中有个字段是JSON格式的配置,它只展示那一行,看不全啊,只能复制出来看。当时看别人用SQLyog可以看全,可是SQLyog貌似没有mac版本。后来用了DataGrip,点一下就直接放大单元格展示全了。查看→修改→保存,舒服。
历史记录
历史记录真的是个好东西。
Navicat
Query Console一定要保存,否则关了可就找不到了。某个表打开了按某条件搜索到了结果,应该不用了吧关掉。过了一会又要查,再打开,需要把条件全部筛一遍。或者没有关闭,需要用其他条件查询,查询之后又要用刚才的条件,啊要疯了。
DataGrip
Query Console是会话机制,只要会话还在,关了也无所谓,去会话窗口找一下就好了。某个表打开按某条件搜索了,关掉这个表,过了一会打开,还是刚才的查询结果。换了搜索条件查询,又要用刚才的条件查询?简单,看一下下面执行的历史记录,直接把SQL中where后面copy过来,粘贴到表格上面的WHERE就ok了。
DataGrip在表中查询数据的时候,与Navicat很不一样。Navicat彻底图形化操作,而DataGrip只是提供了WHERE和ORDER BY两个文本框,自己写条件和排序。当然了,点击表头也是可以进行排序的。