SQLPLUS 使用的一些技巧

为什么80%的码农都做不了架构师?>>>   hot3.png

SQLPLUS 使用的一些技巧

        在ORACLE的维护过程中,目前ORACLE有很多易用的客户端 工具,如pl sql、delveloer、TOAD,但作为 数据 管理员也需要经常和SQLPLUS 打交道,一些常用的操作往往需要在SQLPLUS完成,如果SQLPLUS不熟悉也在很大程度上降低我们的维护效率,本文主要介绍一些在 管理 数据过程中比较有用的的SQLPLUS技巧。

        技巧一:修改SQLPLUS的提示符

        1  问题描述:

        ORACLE的SQLPLUS默认情况下是没有 系统提示符的,由于在日常维护操作中经常要在SQLPLUS下做一些高危险的操作如shutdown之类的操作,如果操作的对象错误将导致设备事故。

        2  解决办法:

        通过修改SQLPLUS提示符号,可以明确地标识所要操作的数据库,避免操作错误;

        3  处理过程:

        SQLPLUS 程序在启动情况下可以通过 设置相关参数,让其执行login.sql,然后通过修改login.sql脚本可以定义一些语句,达到修改SQLPLUS的提示符的目的,便于识别,login.sql的 文件路径需要通过操作系统环境变量SQLPATH进行 设置

        WINDOWS环境下,通过修改 注册表项目在SQLPATH(位置一般在ORACLE-HOME下)在 注册表中,可以设置为D:/oracle/ora92/dbs

        UNIX的可以直接在ORACLE 用户的profile文件中加入SQLPATH环境变量,可以设置export SQLPATH=/home/oracle/app/oracle/product/9.2/dbs;具体的login.sql,如下所示,可以根据需要实际修改:         set serveroutput on size 1000000

        column old_name new_value pname

        set termout off

        select lower(user) || '@' ||instance_name old_name from v$INSTANCE;

        set sqlprompt '&pname> '

        set termout on



        通过这样修改每次通过SQLPLUS登陆系统的时候会显示username@instancname>更好地识别所要连接的数据库。注意:连接用户必须要有查看v$INSTANCE的 权限

        技巧二:在SQLPLUS 下执行操作系统 命令

        在使用SQLPLUS的过程中,经常要执行一些操作系统方面的命令,可以通过两种方法:

        1)在SQLPLUS命令行下执行host命令,可以切换到操作系统命令行下,执行完后exit可以切换回SQLPLUS命令行下。

        2)直接在SQLPLUS 下执行敲一个”!”后面跟上具体的命令行(但在windows下不支持)。

        技巧三:在SQLPLUS修改sql语句:

        使用SQLPLUS的过程中也经常需要修改sql语句,但是SQLPLUS下的修改sql语句的命令过于烦琐不好记忆,可以通过定义相关变量达到很好的效果。

        1)在UNIX 下可以定义define_editor=vi,如果需要修改sql语句,直接在命令行下用edit就可以进入vi环境,和vi操作 功能一样,方便操作,设置办法直接在sqlplus的命令行下敲:

        Define_editor=vi;

        在windows下可以定义define_editor=notepad,如果需要修改sql语句,直接在命令行下用edit就可以进入notepad编写环境,windows下操作就方便多了;

        技巧四:在SQLPLUS下查看sql语句的执行时间情况

        1)可以通过直接在sqlplus命令行下执行命令set time on(打开sql语句的执行时间显示);

        2)在sqlplus命令行下执行命令 set timing on(统计sql语句的执行时间);

        技巧五:在sqlplus 下查看SQL语句的执行计划

        在业务维护过程中,经常需要查看某个sql语句执行计划,看是否使用到合适的索引等,可以通过下操作来完成         set autotrace traceonly exp

        select * from cncdlp114.t_unit where unitcode='hwjsgs';

        set autotrace off



        执行完成后可以看到语句的执行计划:

        注意:执行操作前的前提该用户下有plan_table表(一般都有),如果没有可以通

        过语句来建立          -- Create table
        create table PLAN_TABLE
        (
          STATEMENT_ID      VARCHAR2(30),
          PLAN_ID           NUMBER,
          TIMESTAMP         DATE,
          REMARKS           VARCHAR2(4000),
          OPERATION         VARCHAR2(30),
          OPTIONS           VARCHAR2(255),
          OBJECT_NODE       VARCHAR2(128),
          OBJECT_OWNER      VARCHAR2(30),
          OBJECT_NAME       VARCHAR2(30),
          OBJECT_ALIAS      VARCHAR2(65),
          OBJECT_INSTANCE   INTEGER,
          OBJECT_TYPE       VARCHAR2(30),
          OPTIMIZER         VARCHAR2(255),
          SEARCH_COLUMNS    NUMBER,
          ID                INTEGER,
          PARENT_ID         INTEGER,
          DEPTH             INTEGER,
          POSITION          INTEGER,
          COST              INTEGER,
          CARDINALITY       INTEGER,
          BYTES             INTEGER,
          OTHER_TAG         VARCHAR2(255),
          PARTITION_START   VARCHAR2(255),
          PARTITION_STOP    VARCHAR2(255),
          PARTITION_ID      INTEGER,
          OTHER             LONG,
          DISTRIBUTION      VARCHAR2(30),
          CPU_COST          INTEGER,
          IO_COST           INTEGER,
          TEMP_SPACE        INTEGER,
          ACCESS_PREDICATES VARCHAR2(4000),
          FILTER_PREDICATES VARCHAR2(4000),
          PROJECTION        VARCHAR2(4000),
          TIME              INTEGER,
          QBLOCK_NAME       VARCHAR2(30)
        )


        结束语:

        其实ORACLE的SQLPLUS功能是很强大的,如果想研究其它的一些功能可以参考

        ORACLE的相关文档,提高维护技能
From: http://www.ixpub.net/thread-870623-1-5.html

原文链接: http://blog.csdn.net/t0nsha/article/details/3639935

转载于:https://my.oschina.net/dtec/blog/46841

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/548588.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#中泛型类型约束条件

记录一下&#xff0c;以免忘记。 泛型的类型参数where T &#xff1a;struct 类型参数需是值类型where T&#xff1a;class类型参数需是引用类型where T&#xff1a;new()类型参数要有一个public无参构造函数where T&#xff1a;<base class name>类型参数要派生自某个基…

RMAN 还原与恢复

为什么80%的码农都做不了架构师&#xff1f;>>> -- -- RMAN 还原与恢复 -- 在Oracle中&#xff0c;三大文件即控制文件&#xff0c;数据文件&#xff0c;日志文件的丢失与破坏都将需要使用还原或恢复来使数据库正常化。而RMAN还原与恢复 是实现数据库完整性、可靠性…

在阿里云服务器Windows Server 2012r IIS 上部署.NET网站

本文转载自这篇文章&#xff0c;转载记录一下&#xff0c;万一以后要用到可以作为参考。 1、添加站点 首先创建连接池&#xff0c;如下图所示&#xff1a; 然后添加网站&#xff0c;如下图所示&#xff1a; 添加网站这里&#xff0c;需要注意上图中这个画框的这个位置&#xf…

ASP.NET MVC 利用AreaRegistration进行Area区域模块化开发

背景资料&#xff1a; 随着业务的需要&#xff0c;结构需求越来越多&#xff0c;View文件夹下的文件夹也越来越多&#xff0c;又或者需要更改结构的页面路径&#xff0c;另外可能是多个人合作开发&#xff0c;有多个WEB项目需要合并在一个网站中访问。 用Areas可以解决上述问…

【吼吼睡cocos2d学习笔记】第四章 - 第一个游戏

来让我们开始第一个游戏的制作。 这个过程可能有点艰辛&#xff0c;但是只要坚持下来&#xff0c;第一个游戏往往能给我们带来巨大的收益&#xff08;当然这个收益不是经济上的:-P) 先上截图&#xff1a; iPad中&#xff1a; 游戏构思 角色 在屏幕的上方&#xff0c;有一定数量…

C# 6 的新特性

还是记录一下吧&#xff0c;好记性不如烂笔头。 1、静态的 using 声明 静态的 using 声明允许条用方法时候不适用类名。 C# 5&#xff1a; using System; //etc Console.WriteLine("Hello,World!"); C# 6: using static System.Console; //etc. Writeline("…

C#中的修饰符及其说明

主要修饰符修饰符应用于说明public所有类类型成员任何代码均可以访问该项protected类型和内嵌类型的修饰符只有派生的类型能访问该项internal所有类型或成员只能在包含它的程序集中访问该项private类型和内嵌类型的所有成员只能在它所属的类型中访问该项protected internal类型…

如何从iPhone / iPod Touch / iPad连接

如何从iPhone / iPod Touch / iPad连接 本文将介绍从iPhone / iPod Touch / iPad等设备连接到已启用L2TP over IPsec功能的PacketiX 服务器的方法。 操作前需要按照“在服务器上启用IPsec功能”的提示&#xff0c;在服务器端进行设置。如何增加一个连接设置 首先&#xff0c;你…

C# 中的 is 和 as 运算符 简单举例说明

假设有一个接口&#xff1a;IBankAccount&#xff1b;一个类SaverAccount&#xff0c;类SaverAccout继承自IBankAccount接口&#xff0c;如下图所示&#xff1a; public interface IBankAccount {public interface IBankAccount{void PayIn(decimal amount);bool Withdraw(dec…

ipad xcode连接不了iPad的。

今天是3月14号&#xff0c;也就是传说中的白色情人节。早上拿着ipad连接到电脑上&#xff0c;没想到xcode竟然识别不了。刚开始我以为是ipad也需要像iphone一样制作证书&#xff0c;于是我满怀期待的翻开教程开始制作证书。证书制作结束后&#xff0c;也把证书应用到手机和xcod…

C# partial 部分类使用简单举例说明

partial 关键字允许把类、结构、方法或者接口放在多个文件中。一般情况下&#xff0c;某种类型的代码生成器生成了一个类的某部分&#xff0c;所以把这类放在多个文件中是有益的。假定要给类添加一些从工具中自动生成的内容。如果重新运行该工具&#xff0c;前面所做的修改就会…

POJ 3250 Bad Hair Day【单调队列】

Description Some of Farmer JohnsNcows (1 ≤N≤ 80,000) are having a bad hair day! Since each cow is self-conscious about her messy hairstyle, FJ wants to count the number of other cows that can see the top of other cows heads. Each cowihas a specified heig…

C#中 out、ref、params 修饰符使用方法

使用 out 关键字可以一个方法返回多个返回值。 int i; string str; bool b;public void MyReturnMethod(out int a, out string b,out bool c) {a 9;b "Hello";c false; }params 关键字可以把可变数量的参数(相同类型)作为单个逻辑参数传递给方法。 //返回一些do…

2012年3月编程语言排行榜:JavaScript超越Perl和Python

2012年3月编程语言排行榜&#xff1a;JavaScript超越Perl和Python TIOBE 于昨日公布了2012年3月编程语言指数排行榜。排名前三的语言是&#xff1a;Java、C 和 C#。 在本月排行榜中&#xff0c;JavaScript上升至第8位。由于网站越来越依赖JavaScript&#xff0c;因此JS的流行程…

C#从构造函数中调用其他构造函数

有时&#xff0c;在一个类中有几个构造函数&#xff0c;以容纳某些可选参数&#xff0c;这些构造函数包含一些共同的代码。例如&#xff0c;如下情况&#xff1a; Class Car {private string _description;private int _nWheels;public Car(string description,unit nWheels){_…

Unix整理笔记——安全性——里程碑M13

1 保护信息安全系统有三个基本原则&#xff1a; 机密性&#xff1a;必须阻止那些不需要知道的人了解信息 完整性&#xff1a;信息必须避免未授权的修改或污染 可用性&#xff1a;对那些需要访问信息的人&#xff0c;信息必须是可用的 2 根用户管理选项 sudo

ASP.NET MVC 多语言开发简单案例

首先&#xff0c;新建一个空的MVC项目&#xff0c;增加一个名叫Language的文件夹用于存放资源文件&#xff0c;如下图所示&#xff1a; 在Language文件夹中&#xff0c;增加两个资源文件&#xff0c;分别用于存储中文和英文&#xff0c;如下图所示&#xff1a; 如何添加资源文件…

iphone viewdidLoad运行以及参数的传递。

问题&#xff1a; 有三个view&#xff0c;他们之间传递一个NSArray *NodeArrayIPadLoginViewController----》VedioContainerViewController-----》IpadTreeViewTestController在 VedioContainerViewController的ViewDidLoad 中&#xff0c;若写成如下代码IpadTreeViewTestCont…

C#中使用NPIO实现导入导出Excel简单操作

本文介绍了在Winform中使用NPOI(PIO项目下的.Net组件)来操作Excel文件&#xff0c;而无需安装Office。 要实现的效果是这样的&#xff1a; 1、导出Excel&#xff1a;根据指定datatable&#xff0c;弹出导出窗口&#xff0c;用户自定义路径、导出名&#xff0c;然后导出。 2、…

3招seo技巧让你把关键词做进百度前三

这个技巧也没有什么&#xff0c;说白了就是个百度点击原理&#xff01;当然&#xff0c;这个标题也就是一个标题党&#xff0c;但是的确能让你的排名靠前&#xff0c;因为我之前测试过&#xff0c;我做过一个词&#xff0c;有10个人&#xff0c;点击一下&#xff0c;隔天就第一…