文档章节

简单的 Oracle 脚本

周翔
 周翔
发布于 2015/04/28 00:02
字数 443
阅读 170
收藏 7

Oracle用了很久,但是一般使用还是通过PL/SQL Developer下面执行.

以前用过相关的脚本是 awrrpt.sql 生成awr报告使用.


最近有这样一个想法,写一个SQL脚本放在用户目录下,系统出问题时由同事负责执行.等我有时间时去查看相关信息.所以尝试写SQL脚本.也可以写成定时任务去处理某些事情.


中间遇到的问题:

1 字符集的问题.Windows下默认GBK编码,在数据库服务器上可能会执行报错,很可能是字符集的原因.当时使用Eclipse把字符集改成UTF-8 解决这个问题.

2 关于注释.SQL语句里注释很重要,做一引起必要的说明,不然自己被自己搞昏了头.

SQL脚本:

--初始化参数
define user = "'HLWL'";
define operate = "'zhouxianglh'";
define log_name;

--初始化设置
--显示输出
set echo on;
--指定每行长度
set LINESIZE 999;
--指定每页大小,pagesize=0,则不会显示表头
set pagesize 10000;
--显示实际执行的SQl(包含参数执行时能过 old,new 的方式分别显示)
set verify ON;
--输出文本去除首尾空格
set trimspool on;
--显示字段名称
set heading ON;
--set autotrace on;对执行SQL进行分析

--开始写入文件
select '/home/oracle/zx_'||lower(name)||'_'||&user||'_'||to_char(sysdate,'yyyy-mm-dd-hh24-mi')||'.sql' log_name from v$database;
spool &logname;
--开始执行SQL
--查找当进程,找出导致系统当前性能问题的SQL
select inst_id,sid,serial#,seq#,taddr,sql_id,sql_child_number child,username,machine,last_call_et call_et,module,
(select object_name from dba_objects where a.row_wait_obj#=object_id) object_name,action,event from gv$session a 
where a.status = 'ACTIVE' and a.username is not null order by last_call_et;

--记录操作完成
select sysdate from dual;

--关闭文件
spool off;


© 著作权归作者所有

共有 人打赏支持
周翔

周翔

粉丝 7
博文 48
码字总数 21994
作品 0
长宁
程序员
JavaFX明天在哪里

从java one 大会上传来的消息,其实更多的是关于javaFx2的消息。oracle没有明确的说要停止javaFX脚本语言的开发,不过似乎表达了这个想法。Oracle should either start pushing JavaFX hard ...

崔钢
2010/10/10
1K
6
Redhat AS4下oracle10g自启动脚本设置

以redhat as4和oracle 10g为例。单机在安装过程依照oracle官方的文档一步步下来,只要设置好 参数、安装好必要的包,一般不会出什么问题。安装好了以后系统重启,oracle重启服务,网上很多人...

红薯
2009/12/26
278
0
使用delphi 开发 web(三)动态脚本里面使用数据库

在主程序里面把数据库访问控件设置并注册好,在脚本里面使用数据库就非常简单。 可以类似下面的脚本访问数据库。 <% uses SysUtils, Classes; var aaa,rndnum,bb:string; i,num:integer; be...

xalion
2012/01/05
0
0
Oracle DBCA高级玩法:从模板选择、脚本调用到多租户

作者介绍 本篇文章的思路如下: 但凡是学过Oracle的同学,对DBCA(Database Configuration Assistant, DBCA)都不会陌生,有了这个工具,使得创建数据库成为可能。而DBCA本身有图形和静默两种...

杨建荣
2016/12/07
0
0
PowerDesigner设置MYSQL主键自动增长的方法

我一直用的是Oracle数据库,所以在设计CDM的时候,就没有选定表主键自动增长。这是SQL Server和MYSQL才有的方式。Oracle中一般是采用SEQUENCE的方式来处理主键增长的问题的。相对写程序来说,...

yonge
2009/03/20
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Mac OS X下Maven的安装与配置

Mac OS X 安装Maven: 下载 Maven, 并解压到某个目录。例如/Users/robbie/apache-maven-3.3.3 打开Terminal,输入以下命令,设置Maven classpath $ vi ~/.bash_profile 添加下列两行代码,之后...

TonyStarkSir
今天
3
0
关于编程,你的练习是不是有效的?

最近由于工作及Solution项目的影响,我在重新学习DDD和领域建模的一些知识。然后,我突然就想到了这个问题,以及我是怎么做的? 对于我来说,提升技能的项目会有四种: 纯兴趣驱动的项目。即...

问题终结者
今天
4
0
打开eclipse出现an error has occurred see the log file

解决方法: 1,打开eclipse安装目录下的eclipse.ini文件; 2,打开的文本文件最后添加一行 --add-modules=ALL-SYSTEM 3,保存重新打开Eclipse。...

任梁荣
昨天
4
0
搞定Northwind示例数据库,无论哪个版本的SQLServer都受用

Northwind数据库 从这里可以找到突破口: http://social.msdn.microsoft.com/Forums/zh-CN/Vsexpressvb/thread/8490a1c6-9018-40c9-aafb-df9f79d29cde 下面是MSDN: http://msdn2.microsoft......

QQZZFT
昨天
1
0
mysql主从同步,安装配置操作

准备 两台mysql服务,我这里准备了如下: 主库:192.168.176.128 从库:192.168.176.131 如何在Linux上安装mysql服务,请看https://blog.csdn.net/qq_18860653/article/details/80250499 操作...

小致dad
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部