当前位置导航:炫浪网>>网络学院>>编程开发>>Oracle教程

ORACLE问答精选

  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;

相关内容
赞助商链接