Q:如何使用CostBased优化器优化查询操作?
A:OracleServer提供了基于成本(CostBased)和基于规则(RuleBased)两种优化器,简称为CBO和RBO,用于确定查询操作的执行计划。CostBased优化器将计算各种执行计划的开销,然后选出最低成本的执行计划。可使用下列方法选择使用CBO:方法1:在INIT.ORA文件中设置参数OPTIMIZER_MODE=choose
方法2:在Session级设置 OPTIMIZER_GOAL=FIRST_ROWS或ALL_ROWS例如:altersessionsetoptimizer_goal=first_rows;方法3:在查询语句中使用Hint,包括CHOOSE,ALL_ROWS,FIRST_ROWS等。
Q:如何确定某个查询使用了哪一种优化器?
A:使用EXPLAINPLAN命令生成该查询语句的执行计划,然后检查PLAN_TABLE表中POSITION字段,如果值为Null,说明使用了RuleBased优化器;否则表明使用了CostBased优化器。例如:
SELECTdecode(nvl(position,-1),-1,'RBO','CBO')
FROMplan_table
WHEREid=0;
Q:我的查询上周的性能很好,为什么现在查询速度很慢?
A:这是由于执行计划被改变而造成的,下列因素将会改变一个执行计划:
1)INIT.ORA文件中的参数OPTIMIZER_MODE被改变
2)表上定义或改变了并行查询度
3)使用ANALYZE命令重新分析了表,而且使用了ESTIMATE方式,因这种方式选择不同的百分比可产生不同的分析结果。
4)DB_FILE_MULTIBLOCK_READ_COUNT参数被修改。
5)SORT_AREA_SIZE参数被修改
Q:为什么我的执行计划不是最好的?
A:CBO是依赖表的一些统计信息来选择出最低成本的执行计划,当这些统计信息不准确时,产生的计划便可能不是最佳的。因而应使用ANALYZE命令及时对表进行分析统计。
Q:当使用ESTIMATE方式对表进行分析时,选用什么百分比最好?
A:经测试证明,使用5%的的比例较好。即提高了分析效率,又保证分析结果的准确性。
Q:如何在Oracle8数据库中创建PartitionTable?
A:使用CREATETABLE命令,并指定PartitionKey和每个Partition的分区范围,Partition名为可选项,如未指定,系统将自动产生Partition名。例如:CREATETABLEemp
(EMPNONUMBER(5),
...)
PARTITIONBYRANGE(EMPNO),
emp_p1VALUESLESSTHAN(2000),
emp_p2VALUESLESSTHAN(4000)
emp_p3VALUESLESSTHAN(MAXVALUE);
Q:PartitionTable有何限制?
A:1)数据类型限制:
PartitionTable不能包含LONG、LONGRAW、LOB及OBJECT类型的字段2)Cluster不能被分区3)Bitmap索引:Bitmap索引必须是LOCAL索引,不能是GLOBAL索引4)优化器:
Oracle8中CostBased优化器支持Partitions,而RuleBased优化器对Partitions不敏感,无法通过Partitions获得性能的提高。
5)PartitionTables不能跨多个数据库,所有的Partition必须存在于一个数据库中
Q:如何建立一个与现存数据库相同,但不包含数据的空库?
A:对全库作Export或Import时,使用参数ROWS=Y
例如:expsystem/managerfull=Yrows=Nfile=full.dmp
impsystem/managerfull=Yrows=Nfile=full.dmp
Q:当ExportingProcedures和Packages时,是否会改变其时间标签(Timestamp)?
A:不改变,这是为避免不必要的重编译。
Q:Exp的参数VOLSIZE能否用于所有的平台?
A:VOLSIZE只能用于UNIX系统,将数据exporting至外部介质上(如磁带)
Q:如何通过SQL*PLUS往表中插入"'",如往表中插入i'm.
A:在SQL*PLUS中,我们可以用chr(39)来表示"'",例如:
sql>createtabletest(col1varchar2(10));
sql>insertintotestvalues('i'||chr(39)||'m');
sql>select*fromtest;
col1
-----
i'm
Q:在win95或windowsNT上运行oracleNet8Assistant或Net8EasyConfiguration时报错"unhandledexceptionerrorinJava.exe"
A:oracleNet8Assistant或Net8EasyConfiguration调用了Java,而Java在win95或windowsNT上运行对系统的分辨率和颜色都有要求.应把系统的分辨率调到大于640x480,把系统的颜色调到大于256色但不能设置成truecolor.
Q:安装oracle8forwindowsNT4.0需要NT的那种servicepack?
A:安装oracle8forwindowsNT4.0需要NT的servicepack3.
Qelphi3.0是否支持oracle8?
A:Delphi3.0只有oracle7的driver,所以不支持oracle8.
Delphi4.0.x有oracle8的driver,所以支持oracle8.
Q:怎样在oracle7和oracle8之间export/import数据?
A:必须先在oracle8数据库上以internal或sys用户运行catexp7.sql
svrmgr>connectinternal
svrmgr>@?/rdbms/admin/catexp7.sql
Q:怎样为远程用户设置"internal"的口令?
A:先在数据库端的init.ora文件中设置
remote_login_passwordfile=exclusive
并且为oracleowner设置环境变量
ORA__PWFILE=orapw.pwd
然后以oracleowner运行以下命令
$cd$ORACLE_HOME/dbs
$orapwdfile=orapw.pwdpassword=entries=5
Q:如何手工安装sqlplus的helpfacility?
A:以oracle用户运行以下命令
$cd$ORACLE_HOME/bin
$SYSTEM_PASS=system/manager;exportSYSTEM_PASS
$helpins
Q:如何查出前台正在发出的sql语句?
A:先查出正在运行的前台程序的sid:
sql>selectsid,serial#,username,program
fromv$session
wherestatus='ACTIVE';
然后根据上面得到的sid,可查出正在运行的前台程序发出的sql语句:
sql>selectuser_name,sql_text
fromv$open_cursor
wheresid=xx;
Q:在oracle8中如何使用sharedlibrary来编译pro*c程序?
A:首先以oracleowner创建sharedlibrary
$cd$ORACLE_HOME/rdbms/lib
$make-fins_rdbms.mkclient_sharedlib
然后设置LIBPATH环境变量(有的平台用LD_LIBRARY_PATH,请参见手册 :
$LIBPATH=$ORACLE_HOME/lib;exportLIBPATH
最后编译你的pro*c程序:
$make-fdemo_proc.mkbuildOBJS=yourprog.oEXE=yourprog
Q:在数据库一级设置SQLTrace
A:在init.ora中加入参数sql_trace=true.然后重新启动数据库。
Q:在SQL*PLUS中对某一session设置SQLtrace.
A:sql*plus>altersessionsetsql_tracetrue;
在产生Trace之后,使用如下命令关闭Trace.
sql*plus>altersessionsetsql_tracefalse;3:
Q:在PL/SQL中设置和关闭SQLTrace.
A:dbms_session.set_sql_trace(true);
dbms_session.set_sql_trace(false);
如果你不能发现这个package,首先用SYS用户执行
dbmsutil.sql这个脚本。
Q:怎样设置redolog文件的大小。
A:设置redolog文件的原则就是要保证30分钟之内进行logswitch.
logswitch的信息被记录在alertSID.log中。
-------------------------------------------------------
MonMay513:53:311997
Thread1advancedtologsequence68
Currentlog#2seq#68mem#0:/u05/dbs/log2ween.dbf-------------------------------------------------------
如果两次switch的时间是10分钟,你需要增加redolog文件
到三倍的尺寸。
如果两次switch的时间是15分钟,你需要增加redolog文件
到两倍的尺寸。
如果两次switch的时间超过30分钟,你不需要需要增加redo
log文件的尺寸。
同时设置CHECK_POINT_INTERVAL大于redolog文件的大小。
Q:怎样检查是否一个数据库用户被授予sysdba,sysoper的权限。
A:注册到sys用户下,查询数据字典v$pwfilw_users.
Q:你是否可以将withgrantoption的object权限授给一个role.
A:不能,这个被授权者必须是一个user或者public.
Q:withadminoption的系统授权是否是hierarchical
A:不是,所以revokegrantwithadminoption并不cascade.
如:userAgrantselectanytabletouserBwithadminoption.
userBgrantselectsnytabletouserCwithadminoption.
userArevokeselectanytablefromuserB.
此时userC仍然具有selectanytablewithadminoption.
Q:被授予的withgrantoption的object的权限是否被收回,如果授权者的权限已经被收回。
A:是的,object的withgrantoption的权限是hierarchical.
Q:在用createuser命令创建了一个用户之后,那些表可以用来查看这个新用户的基本信息。
A:可以查看表dba_users,dba_ts_quotas.
Q:是否可以用alterdatabasedatafaile'file_name'offlinedrop的命令来删除一个表空间中的某个数据文件。
A:这个命令并非是一个常规的对数据库的管理命令,仅仅当数据库出现异常,或某个文件丢失时,可以用他来强制将这一文件的记录从数据字典中删除,以达到open数据库的目的,但是此后,你必须备份此表空间的数据,然后重新创建该表空间。
Q:如何移动数据文件的位置?
A:1.正常关闭数据库;
2.拷贝数据文件到新位置;
$cp$ORACLE_HOME/dbs/dbsNEW.dbf/usr3/oracle/dbsNEW.dbf
3.svrmgrl
connectinternal;
startupmount;
alterdatabaserenamefile'<$ORACLE_HOME>/dbs/dbsNEW.dbf'
to'/usr3/oracle/dbsNEW.dbf';
alterdatabaseopen.
Q:如何移动LOG文件的位置?
A:可以先添加新的LOG文件,再删除原来的LOG文件。
svrmgrl>connectinternal;
alterdatabaseaddlogfile'<$ORACLE_HOME>/usr3/oracle/logNEW.dba';
alterdatabasedroplogfile'<$ORACLE_HOME>/dbs/logNEW.dbf';
Q:能否把数据文件一部分放在RAWDEVICE上,另一部分放在普通文件系统上?
A:可以,ORACLE把它们同等对待,把数据文件放在RAWDEVICE上有时可以提高系统的性能。
Q:能否把多个数据文件放在同一个RAWDEVICE上?在CREATETABLESPACE时,如何指定RAWDEVICE的大小?
A:一个RAWDEVICE只能作为一个数据文件使用,如果你有一个较大的RAWDEVICE,需要把它用于不同的表空间,你可以把它再分区。在使用RAWDEVICE创建表空间时,你只能使用RAWDEVICE的95%左右的空间,其余空间用于记录文件头的信息。
Q:如何知道我已经安装了哪种NETWORKDRIVER?
A:可以用'nm'命令检查,例如,TCP/IPDRIVER的符号名为'nttini',要检查Oracle是否链接了该符号,可以利用下列命令:
nmoracle|grepnttini如果nttini存在,表示rdbms已经链接了TCP/IPDRIVER.
Q:如何检查已安装的SQL*NET的版本?
A:可以在?/orainst目录下使用'inspdver'命令检查。
$inspdver|grepSQL*Net
2.3.4.0.0SQL*Net(V2)
Q:如何打开IntelligentAgentTracing?
A:在7.3.2.x,编辑SNMP.ORA文件,在7.3.3.x及以上版本编辑SNMP_RW.ORA文件,分别加入以下内容:
NMI.TRACE_LEVEL=16
NMI.TRACE_MASK=(106)
NMI.TRACE_DIRECTORY=
Q:SNAPSHOT不自动refresh怎么办?
A:我们可以从以下几个方面查找原因:
1.检查JOB_QUEUE_PROCESSES参数;
2.检查DBA_JOBS,确认JOB的状态不是broken;
3.检查DBA_JOBS_RUNNING,看refreshjob是否正在运行;
4.检查dblink和NET是否正常。
Q:如何清除replicated环境?
A:1.在MasterDefinitionsite,执行dbms_repcat.remove_master_databases();
2.在Mastersite执行dbms_repcat.drop_master_repgroup。
Q:如何确定snapshot是ReadOnly或Updatable?
A:可以运行下列语句,确定snapshot是ReadOnly或Updatable:
SQL>selectname,updatablefromuser_snapshots;
Example:--------
SQL>selectname,updatablefromuser_snapshots;