Oracle sqlplus prelim 参数介绍

摘要:
从Oracle10g开始,sqlplus提供了一个参数选项-prelim,用这个参数,在系统已经hang的时候。一.通过以下步骤可以获取系统信息:sqlplus-prelim/assysdbaoradebugsetmypidoradebugunlimit;oradebugdumpsystemstate10对于9i数据库,可以通过安装10g的客户端连接9iR2工作正常。二.prelim参数特点1.首先在数据库上启用10046事件:SQL˃altersystemsetevents‘10046tracenamecontextforever’;Systemaltered.2.先用普通的方式连接:D:/˃sqlplus/nologSQL*Plus:Release10.2.0.1.0-Productionon星期六11月1515:36:022008Copyright1982,2005,Oracle.Allrightsreserved.SQL˃connsys/manageassysdba已连接。sqlplus-prelim能够在数据库hang住的情况下连接数据库,但只能说是连接,并不代表能够做很多操作。

Oracle10g开始,sqlplus提供了一个参数选项-prelim用这个参数,在系统已经hang的时候。我们可以连接到SGA而不是数据库也就是说没有session被创建。


. 通过以下步骤可以获取系统信息:

sqlplus -prelim / as sysdba
oradebug setmypid
oradebug unlimit;
oradebug dump systemstate 10

对于9i数据库,可以通过安装10g的客户端连接 9iR2工作正常。

二.prelim参数特点

1.首先在数据库上启用10046事件:

SQL> alter system set events ‘10046 trace name context forever’;

System altered.

2. 先用普通的方式连接:

D:/>sqlplus /nolog

SQL*Plus: Release 10.2.0.1.0 - Production on 星期六 11 15 15:36:02 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

SQL> conn sys/manage as sysdba
已连接。
SQL> exit
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
断开

3. 看看加prelim参数时的情况:

D:/>sqlplus -prelim /nolog

SQL*Plus: Release 10.2.0.1.0 - Production on 星期六 11 15 15:36:34 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

SQL> conn sys/manage as sysdba
初级连接已建立
SQL> exit
ORACLE 断开

从上面的信息可以看到,在使用prelim连接时,提示为初级连接已建立,退出sqlplus没有显示banner


4.
也可以通过下面的方式来用prelim方式连接数据库:

[oracle@xty ~]$ sqlplus /nolog

SQL*Plus: Release 10.2.0.3.0 - Production on Tue Dec 2 07:04:28 2008

Copyright (c) 1982, 2006, Oracle. All Rights Reserved.

SQL> set _prelim on
SQL> connect / as sysdba
Prelim connection established

5. 看看数据库的10046 trace

从生成的trace文件中,可以发现在正常连接时,连接上数据库后,sqlplus自动执行了下面的SQL

ALTER SESSION SET NLS_LANGUAGE= ‘SIMPLIFIED CHINESE’ NLS_TERRITORY= ‘CHINA’ NLS_CURRENCY= ‘’ NLS_ISO_CURRENCY= ‘CHINA’ NLS_NUMERIC_CHARACTERS= ‘.,’ NLS_CALENDAR= ‘GREGORIAN’ NLS_DATE_FORMAT= ‘DD-MON-RR’ NLS_DATE_LANGUAGE= ‘SIMPLIFIED CHINESE’ NLS_SORT= ‘BINARY’ TIME_ZONE= ‘+08:00′ NLS_COMP= ‘BINARY’ NLS_DUAL_CURRENCY= ‘’ NLS_TIME_FORMAT= ‘HH.MI.SSXFF AM’ NLS_TIMESTAMP_FORMAT= ‘DD-MON-RR HH.MI.SSXFF AM’ NLS_TIME_TZ_FORMAT= ‘HH.MI.SSXFF AM TZR’ NLS_TIMESTAMP_TZ_FORMAT= ‘DD-MON-RR HH.MI.SSXFF AM TZR’

select value$ from props$ where name = ‘GLOBAL_DB_NAME’

select SYS_CONTEXT(’USERENV’, ‘SERVER_HOST’), SYS_CONTEXT(’USERENV’, ‘DB_UNIQUE_NAME’), SYS_CONTEXT(’USERENV’, ‘INSTANCE_NAME’), SYS_CONTEXT(’USERENV’, ‘SERVICE_NAME’), INSTANCE_NUMBER, STARTUP_TIME, SYS_CONTEXT(’USERENV’, ‘DB_DOMAIN’) from v$instance where INSTANCE_NAME=SYS_CONTEXT(’USERENV’, ‘INSTANCE_NAME’)

select decode(failover_method, NULL, 0 , ‘BASIC’, 1, ‘PRECONNECT’, 2 , ‘PREPARSE’, 4 , 0), decode(failover_type, NULL, 1 , ‘NONE’, 1 , ‘SESSION’, 2, ‘SELECT’, 4, 1), failover_retries, failover_delay, flags from service$ where name = :1

sqlplus使用prelim连接上数据库后,没有生成10046 trace文件,看起来没有执行SQL,也就是没有执行任何初始化动作和查询必要的信息。也许这也就是称之为初级连接的来历吧。

由于使用prelim方式连接,没有执行sql语句的,所以在数据库的某些hang住的情况下,能够连接上数据库。比如由于library cache latch 被长时间持有不能释放,不能解析SQL语句引起的hang。有的人会说,我的应用刚连上去还没做任何操作就hang住了。这只是表面现象,连接上数据库后,一般都会做一些初始化的操作,如设定环境之类的。

sqlplus -prelim能够在数据库hang住的情况下连接数据库,但只能说是连接,并不代表能够做很多操作。比如执行SQL查询。这种情况下,可能最有用的就是使用oradebug

6. oradebug 介绍

oradebugoracle 最初设计的时候做调试的一个工具,后来进一步发展到通过事件(event)来定义跟踪,然后event 又发展到支持sqltrace sql trace 就是编号为10046 event
也就是说这是一个从底层调试到高级支持的一个发展的过程,oracle逐步完善。 oracle events 事件支持这一体系的定义和延伸出来的功能,非常强大。其实也就是从软件开发人员自己调试代码的工具逐渐发展到给用户提供接口进行跟踪和调试应用。

免责声明:文章转载自《Oracle sqlplus prelim 参数介绍》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇C# FileSystemWatcherwebrtc 音频一点相关知识下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

db2操作 连接、备份、恢复db2

先deactivate后再start standby再primary报错不能启动hadr standby的时候,先restore,但是别rollback,直接start hadr as standby 先把hadr起来后再推icm 1、先把所有的库的hadr stop了2、把primary的库离线备份3、在副节点db2stop force ,再start(...

Oracle的dual

1.dual 确实是一张表.是一张只有一个字段,一行记录的表(虚拟表). 2.习惯上,我们称之为'伪表'.因为他不存储主题数据.3. 他的存在,是为了操作上的方便.因为select 都是要有特定对象的.如:select * from mytable ;select * from myview;等等. 4.dual 是由 sql.bsq 建立的。每个data...

oracle数据导入dmp

导入数据库--创建表空间(原数据库所在的表空间名)create tablespace 表空间名 datafile 'g:hygyzjgltest.dbf' size 1024M;--创建用户create user xhdc identified by hygy default tablespace 表空间名;--授予dba权限grant dba to xh...

Sqlserver 使用同义词跨服务器数据库连表查询

  跨服务器,跨数据库查询并不是什么新鲜事,不过之前在工作中看到一段代码,之前也没有接触过数据库同义词,发现挺方便的。代码示例类似这样:   代码很普通,奇怪之处在于A 表在服务器ServerA的DatabaseA中,而B表在服务器ServerB的DatabaseB中。于是我第一反应是linked server,但可以这样写吗?没远程Server 的ip...

MSSQL临时(tempdb)系统数据库

--Reference http://blogs.msdn.com/sqlserverstorageengine/archive/2008/03/30/sql-server-table-variable-vs-local-temporary-table.aspx 走进SQL Server 2005 tempdb数据库 (一) Working with t...

EF基础篇-DB First

EDM entity data model  实体数据模型   Conceptual models 概念模型 Mappings         连接 Storage models    存储模型   Orm object relational mapping 对象关系映射 EF entity framework 是基于ADO.Net的ORM框架,将数据库中...