你造吗,Oracle SQLplus 也有History命令了

很多时候我们只能通过SQLPlus来操作数据库,而当一个SQL执行结果太多时,我们要回翻之前的SQL语句就会很麻烦,甚至可能由于ssh客户端或SQLPlus客户端的buffer限制,更早以前的语句被刷出了窗口,你就不得不重新敲一遍SQL,这样会带来很多麻烦。

在12c里,针对此Oracle推出了 History命令,这很像Shell中的history,语法为:

HIST[ORY] [n RUN | EDIT | DEL[ETE]] | [CLEAR | LIST]

该特性使用户能够从当前会话的历史列表中运行、编辑或删除以前使用的SQL * Plus,SQL或PL / SQL命令。 可以使用SET HISTORY命令在当前SQL * Plus会话中启用或禁用HISTORY命令。

默认是关闭的,并在每次会话断开连接后会自动关闭,当hist关闭后,hist 列表会被清空。如下示例:

HISTORY命令能够:

列出命令历史列表中的所有条目。 在命令历史列表中运行条目。 在命令历史列表中编辑一个条目。 从命令历史列表中删除一个条目。 清除命令历史记录列表中的所有条目。

Hist命令选项

  • His(tory):列出命令历史列表中的所有条目。
  • n:表示命令历史记录列表中的条目。 星号(*)表示命令历史列表中最后使用的命令。

说明

官方文档在这里说hist命令列出来的最后一条会加*号,但在我测试的过程中,一直都没有出现*号。虽然只是个小细节并不影响什么,大家也可以自己测一下。

  • run:从命令历史列表中执行条目n。
  • edit:可以使用默认的文本编辑器在命令历史列表中编辑条目n。 在命令历史列表中编辑条目n并保存更改后,将在列表末尾创建一个新条目。 当命令历史列表中的条目数量达到最大限制时,列表中最早的条目将被清除以容纳新条目。
  • del(ete):能够从命令历史记录列表中删除条目n。 从历史记录列表中删除条目后,列表将重新排序,以反映最近的更改。
  • clear:能够清除历史记录列表中的所有条目。 一旦清除,历史列表就无法恢复。
  • list:列出历史列表中的所有条目。 这与使用HIST [ORY]命令本身是一样的。

拓展用法

可以使用SQL * Plus DEFINE命令来定义变量_EDITOR,以保存首选文本编辑器的名称。 例如,要将EDIT使用的编辑器定义为vi,请输入以下命令:DEFINE _EDITOR = vi

举例如下

以下示例执行历史列表中的第五个条目:

HIST[ORY] 5 RUN

以下示例允许编辑历史列表中的第三个条目:

HIST[ORY] 3 EDIT

此时会进入vi编辑状态,对选择的历史条目可以做修改:

以下示例允许从历史记录列表中删除第二个条目:

HIST[ORY] 2 DEL[ETE]

此时第二条历史记录被删除。

以下示例允许从历史记录列表中删除所有条目:

HIST[ORY] CLEAR

以下示例列出历史列表中的所有条目。 这与使用HIST [ORY]命令本身是一样的。

HIST LIST

以下示例说明如何启用或禁用命令历史记录,以及如何检查命令历史记录状态:

在示例中hist 后面加数字表示hist列表的长度。默认值为100.

有了hist特性,的确会给我们的操作带来很多方便。

The End.

12.2体系架构图领取

绿色通道

Oracle 12.2 体系架构图在DTCC现场首发,受到广大技术朋友的喜欢。最近很多朋友们找我们申请,因此开放绿色通道,可以在线申请免费领取。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-05-17

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

从零开始串联Python前后端技术

运维开发流程概述 是我们参与到其中的一个入口,我们需要了解运维开发的一些环节,还有运维开发的一些技术基础。我们通过一个实例来做演示,基本的需求就是从数据库中查...

2866
来自专栏Seebug漏洞平台

披着狼皮的羊——寻找惠普多款打印机中的RCE漏洞

原文:https://foxglovesecurity.com/2017/11/20/a-sheep-in-wolfs-clothing-finding-rce...

803
来自专栏xingoo, 一个梦想做发明家的程序员

Elasticsearch推荐插件篇(head,sense,marvel)

安装head head插件可以用来快速查看elasticsearch中的数据概况以及非全量的数据,也支持控件化查询和rest请求,但是体验都不是很好。 一般就用...

2427
来自专栏乐享123

How to Parallel All Cmds for Linux

1324
来自专栏喔家ArchiSelf

老码眼中的Git

Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。大神就是大神,在开发了Linux之后,Git 是...

732
来自专栏Bug生活2048

利用云开发优化博客小程序(一)——浏览量统计

由于我的博客是基于开源博客框架ghost搭建的,虽然相较于wordpress轻量了很多,但在功能上远没有wordpress丰富,像基本的网站统计,文章统计,点评...

913
来自专栏喔家ArchiSelf

老曹眼中的Git

Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。大神就是大神,在开发了Linux之后,Git 是...

683
来自专栏杨建荣的学习笔记

MySQL权限开通的设计方案

MySQL中的权限管理和其他数据库还是有很大的不同,它能够实现几种很特别的权限场景:

771
来自专栏学习有记

学委助手

学委除了要收作业,最烦的就是统计谁没有交作业啦,还有就是大家的命名不统一造成文件排序混乱,更加大了学委统计的难度。所以,写这个应用的目的就是查交和格式化文件命名...

902
来自专栏杨建荣的学习笔记

MySQL数据导入导出牛刀小试(r5笔记第3天)

最近学习了下MySQL中数据的导入导出,发现功能点真是丰富,很方便很快捷。 这些导入导出的方式还是有不少的细节的,在此先不做扩展和深入分析。 --数据导出 方式...

3514

扫码关注云+社区