分享好友

×
取消 复制
Oracle DBA遇到频次最高的五十个问题
2020-05-19 15:12:13

随着数据价值在企业地位越来越高,DBA这一职位更是受到重视和支持,如何帮助各位数据达人维护好数据,也是ITPUB社区一直秉承的理念,本期我们将社区DBA关注最多的50个问题,已经各位大师对问题的解决方式进行了汇总和整理,期待大家更多给与问题和反馈,以下是问题和解决方案。


问题1:如何收集统计信息不影响数据库?

解决方案

大多数情况下,表的统计信息不准导致了优化器对于执行计划的错误计算,因此需要对表的统计信息进行更正,

以便让优化器重新选择准确的 执行计划。

但是在生产情况下,随意的收集统计信息,则会给数据库带来隐患:

1、对重新收集统计信息的表,对应的一些SQL可能需要重新硬解析生成执行计划。

2、对于重新收集统计信息的表的部分SQL来说,可能会出现收集完统计信息了,但是执行计划更差的情况。

3、在业务高峰期收集统计信息,会需要额外的资源开销,影响数据库的性能。

 

在进行SQL优化时,通过查看执行计划,表的统计信息以及表的具体情况,去分析是否是由于统计信息不准导致执行计划有

问题,当确定了是统计信息 的问题时,不能盲目的去收集统计信息,需要进一步验证重新收集统计信息可以提升SQL性能

因此在针对重新收集统计信息可以提升SQL性能时, 主要介绍一下如何去重新收集统计信息而不影响数据库中

正在运行的SQL

 

Oracle中,统计信息的收集,都是存储在对应的数据字典里,因此正常收集完统计信息, 就会被对应的SQL去用来生成

执行计划。 但是,Oracle也提供了一种收集完统计信息却不会被记录在数据字典里,因此也不会被对应的SQL使用, 只有

在需要使用这些统计信息的时候, 通过设置一些参数,才可以正常的使用这些统计信息。

文章详情链接:http://blog.itpub.net/31536355/viewspace-2691584/

 

 

问题2Oracle安装完成后的初始口令?

解决方案

internal/oracle

sys/change_on_install

system/manager

sysman/oem_temp

 

问题3:怎样计算一个表占用的空间的大小?

解决方案

select owner,table_name,

NUM_ROWS,

BLOCKS*AAA/1024/1024 "Size M",

EMPTY_BLOCKS,

LAST_ANALYZED

from dba_tables

where table_name='XXX';

Here: AAA is the value of db_block_size ;

XXX is the table name you want to check

 

问题4:如何查看最大会话数?

解决方案

SELECT * FROM V$PARAMETER WHERE NAME LIKE 'proc%';

  SQL>

  SQL> show parameter processes

  NAME TYPE VALUE

  ------------------------------------ ------- ----------------- aq_tm_processes integer 1

  db_writer_processes integer 1

  job_queue_processes integer 4

  log_archive_max_processes integer 1

  processes integer 200

  这里为200个用户。

  select * from v$license;

  其中sessions_highwater纪录曾经到达的最大会话数

 

问题5:通过PL/SQL连接数据库,出现错误ORA-12154:TNS:无法解析指定的连接标识符

解决方案

1、使用sqlplus登陆。是否能登陆上,若能登陆上,说明tns和监听文件没有问题,那就是路径的问题了,检查PATHTNS_ADMIN,是否正确,若不正确,修改正确,再查看pl/sql加载,工具-选项-OCI库里面的路径是否正确。

 

2、使用sqlplus不能登陆,检查服务是否开启,然后再检查tns和监听里面的host是否正确。

 

问题6PL/SQL查询出来中文乱码

解决方案

PL/SQL查询出来中文乱码,一把是需要修改PL/SQL Developer 编码格式:在windows中创 建一个名为“NLS_LANG”的系统环境变量,设置其值为“SIMPLIFIED CHINESE_CHINA.ZHS16GBK”

然后重新启动PL/SQL Developer,这样检索出来的中文内容就不会是乱码了。如果想转换为UTF8字符集,可以赋予“NLS_LANG” “AMERICAN_AMERICA.UTF8”,然后重新启动 pl/sql developer

 

问题7GoldenGate目标端检查发现错误ogg-01296

解决方案

view report RORA_001找到错误ogg-01296对应的map表名,可以使用如下方式快速检查:

Tail -3000 RORA_001.rpt >> /tmp/ RORA_001.rpt

Cat  /tmp/ RORA_001.rpt |grep -i OGG-  会出现ogg-01296错误

edit report RORA_001在对应的map语句加--注释掉,启动复制进程,一般没有问题,如果修改的表比较多,可以使用脚本检查

 

问题8:用什么语句查询字段

解决方案

desc table_name 可以查询表的结构

select field_name,... from ... 可以查询字段的值

select * from all_tables where table_name like '%'

select * from all_tab_columns where table_name='??'

 

问题9:如何在Oracle服务器上通过SQLPLUS查看本机IP地址

解决方案

select sys_context('userenv','ip_address') from dual;

如果是登陆本机数据库,只能返回127.0.0.1

 

问题10:如何查看各个表空间占用磁盘情况

解决方案

SQL> col tablespace format a20
SQL> select
b.file_id
文件ID,
b.tablespace_name
表空间名,
b.bytes
字节数,
(b.bytes-sum(nvl(a.bytes,0)))
已使用,
sum(nvl(a.bytes,0))
剩余空间,
sum(nvl(a.bytes,0))/(b.bytes)*100
剩余百分比
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_id,b.bytes
order by b.file_id

 

 

问题11:怎样查看哪些用户拥有SYSDBASYSOPER权限?

解决方案

SQL>conn sys/change_on_install

SQL>select * from V_$PWFILE_USERS;

 

问题12:如何查看现有回滚段及其状态

解决方案

SQL> col segment format a30

SQL> SELECT SEGMENT_NAME,OWNER,TABLESPACE_NAME,SEGMENT_ID,FILE_ID,STATUS FROM DBA_ROLLBACK_SEGS

 

问题13:如何改变一个字段初始定义的Check范围

解决方案

SQL> alter table xxx drop constraint constraint_name;

之后再创建新约束:

SQL> alter table xxx add constraint constraint_name check();

 

问题14Oracle常用系统文件有哪些

解决方案

通过以下视图显示这些文件信息:v$database,v$datafile,v$logfile v$controlfile v$parameter;

 

问题15:表和索引收集信息如何立马生效:

请问大家有什么办法让手工进行表和索引收集的信息立马生效,让正在执行的SQL根据最新的统计信息 走正确的执行计划?

解决方案

已经在执行SQL的没法使用刚采集到的统计信息,只能等下一次执行,

DBMS_stats包采集时,添加参数 NO_INVALIDATE=>false 即可,

 

问题16:如何测硬盘IO

一般如何粗略查看硬盘IO的,有个存储盘,这样测试:

dd if=/dev/zero of=/dev/sdxx bs=8k count=250000 oflag=direct

返回用时200多秒,速度还不到 10 MB/s

bs换成2M,速度可以达到700 MB/s,按这个算,iops应该是1000左右吧,考虑数据库的块大小是8k,一开始就用8k去测

这样测合理么,这种iops做生产库适合么

解决方案

一般I/O类型是混合型的。

你这个存储是多个磁盘组成的吗、raid5 还是别的。样看不出来。

运行oracle程序,一般可以考虑使用orion测试

 

问题17:不使用索引消除排序为什么性能更好

解决方案

这种属于稀疏结果的场景,不走这个避免排序的索引会更好些。

同样是扫描全表数据,一般FTSFS更快。

fts=full table scan;

fs=full index scan;

虽然fts免不了order操作,但没结果或结果很少的话,这不会成为性能问题,显然,这个案例系统生成计划跑偏了。

 

问题18ORA--00604怎么解决

节点Alert日志爆出如下错误

ORA-00604: 递归 SQL 级别 1 出现错误

ORA-20099: Loginclosed,please connect to dba

ORA-06512: line

两个问题:

1、什么是递归SQL级别;

2,怎么消除这种错误,怎么排查?

解决方案

ORA-20099: Loginclosed,please connect to dba

这明显是人为在触发器里定义的错误,先看看触发器脚本怎么写!

 

问题19:如何做到让scanip开始不自动启动

解决方案

$GI_HOME/bin/srvctl disable scan -i 1
$GI_HOME/bin/srvctl disable scan -i 2
$GI_HOME/bin/srvctl disable scan -i 3

 

问题2012C中能否单独给PDBDG

解决方案

可以针对某几个PDBdataguard,有一个参数 enabled_pdbs_on_standby 来控制.

 

问题21DataGuard是否需要配置静态监听

解决方案

不是一定需要配,但是最好配

duplicate 方式建立standby,如果主库执行需要静态监听

broker管理,低版本需要静态监听

 

问题22Oracle在生产环境如何划分表空间

解决方案

1.索引与数据分开没有必要.

2.你可以根据业务来分.比如:财务1个表空间 销售另外1个表空间.

3.另外一些大表也可以单独分配一个表空间.

4.基础表,业务字典 一个表空间等等.

5.合理的是使用分区技术.

 

问题23:正式环境asm要加盘,需要重启udev服务,需要申请停机吗

解决方案

这个不需要重启,找到新添加的盘,添加到ASM就可以。

 

问题24OGG使用add extract exta, SourceisTable初始化后,如何接着做增量同步

解决方案

如果源端是Oracle init的时候可以指定SCNtable user.*, SQLPREDICATE 'AS OF SCN 1909670000',初始化之后再从这个SCN开始应用队列文件.

 

问题25:如何知道开发前台使用update语句更新的值

解决方案

SQL TRACE 现在可能叫做 SQL monitor 或者直接10046event 追踪sessoin。事后分析,可以用logminerredo,也可以针对特定SQL类型和表启用审计。

 

问题26:物化视图可以基于scn开始同步么

解决方案

1、通过物化视图进行增量同步,平时有用,效果不错;

2、自带的初始化方式效率,这个看你自己的环境,这个不好说,关键看网络;

3、物化视图增量刷新一般结合主键或者rowid实现的,scn 估计不太好弄.

 

问题27:表空间的文件设置的自动扩大,文件32G无法自动新增数据文件

解决方案

可以给表空间多加几个数据文件,让这几个数据文件都自动增长。

 

问题28:关于多节点RACVIP漂移的疑问

解决方案

VIP漂移的规律对于连接数据库,没有关系。节点故障,导致VIP漂移后,你连接哪个节点和VIP漂移到哪个节点没有任何关系

 

问题29:关于B树索引的问题

解决方案

1B*Tree的顶层节点称为root节点,即根节点;

2B*Tree的层数最大不是3,而是看实际需要,root节点在索引变大时会发生split,有时不止一次;

3B*Treeleaf节点间有双向指针,而branch节点间没有

 

问题30:控制文件丢失如何恢复

解决方案

只是控制文件坏了,不代表数据丢失,直接重建就可以了.

使用”recover database using backup controlfile until cancel;“进行恢复数据库,告诉Oracle把数据库恢复到数据文件头记录的最大SCN,同时也会把控制文件恢复到最新,最后用resetlogs打开数据库。

 

问题31oralce的自动收集计划是什么量级的收集

解决方案

收集是全库范围内的,但并不是读取库中所有的数据,也不是对所有修改过的表都收集,是对修改数据量达到某个阈值的表进行收集,而且也不都是全表读,有时是按照一定的比例收集。

 

问题32expdp怎么导出分区表的某些分区

解决方案

–Excluding Table Partitions’ Data

EXCLUDE=TABLE_DATA:”IN (select partition_name from dba_tab_partitions where table_name in (‘TABLE_NAME1′,’TABLE_NAME2′…) and partition_name like ‘%_P%’ and substr(partition_name,-4,4) < to_char(sysdate,’YYYY’) and partition_name not like ‘%P2013%’)” –P20XX

–Excluding Table

EXCLUDE=TABLE:”IN (‘TABLE_NAME1′,’TABLE_NAME2′…)”

 

问题33impdp remap_datafile remap_tablespace区别

解决方案

remap_*的作用不是帮你创建表空间和数据文件,而是在源和目标库之间可以改变表存储的数据文件和表空间,比如:表在源库中存储在表空间tbs1上,而目标库中没tbs1,只有tbs2,那么可以用remap_tablespace将表的存储表空间由tbs1改为目标库中的tbs2

 

问题34:怎么知道DB用的是CBO还是RBO

解决方案

一般没有修改的话,默认优化模式是choose,如果有分析过表则会走CBO,否则RBO,可以通过强制指定单个SQL的优化类型。

 

问题35RAC安装时安装软件如何确定哪台服务器为节点1

解决方案

GI和数据库都先在节点1上跑,我记得是安装GI到运行ROOT.SH这个脚本时决定,也就是,谁先跑ROOT.SHASM1就给谁,后跑的就用ASM2

 

问题36oracle adg主库故障怎样启用备库

解决方案

这个就是failover了。

alter database recover managed standby database finish;

alter database commit to switchover to primary;

shutdown immediate;

startup;

不过,这个要谨慎,会毁掉DG配置。

 

问题37ocrvoting disk 存放在asm中的问题

解决方案

ocr是集群的注册信息,只要信息不变更可以有很多信镜像,可以同时放在多个磁盘组中;voting disk是用来做权重vote的当然只能是一个.

 

问题38oracle dataguard 主备库可以是不同操作系统么

 

解决方案

不行,必须字节顺序一致。但是OGG可以跨OS,跨DB,支持不同版本数据库(oracle/DB2/SQLServer等),不同硬件平台OSlinux/AIX/windows

 

问题39:拉链表如何分区

拉链表数据量很大,请问怎么按日期分区,主要查询最近一段时间的数据

table_t1(

card_no 账户,

product_no 产品,

product_num 数量,

start_dt  开始日期,

end_dt  结束日期

)

解决方案

start_dtend_dt 如果在查询条件中都用到,你就选定一个字段,做时间范围分区;  如果还不够,另一个时间字段,还可以考虑划分子分区

 

问题40oracle数据库可以暴力备份吗?

解决方案

实际上os拷贝大小与oracle块大小不一致.

如果你拷贝这个块时正好有写入这个块,这样问题就来了.

oracle通过尾部的tailchk记录前面的一部分scn_base(2)的信息,这样就可能出现不一致的情况,这样拷贝这块就有问题.

这也就是为什么热备份模式要在日志中记录1次整个数据块的信息,这样热备份时要选择空闲时进行.

rman之类的工具自动修复这个错误.

如果拷贝时没有写入,也许没有问题.

实际上还是不建议这样的备份方式.

 

问题41:如何监控数据库表增长趋势

在巡检的时候发现很多数据库每天整体表空间占用率增长较快

想要通过user_segments 查询哪些表比较大,但是一直查不出结果,可能是由于数据文件比较多的原因。

那如何监控segment级别的数据增长呢,有没有其他有效手段可以抓出每天增长比较多的segment对象?

解决方案

找到一个视图 

DBA_HIST_SEG_STAT

 

问题42oracle是通过什么方法来控制实例名

解决方案

先有实例,再有数据库:通过ORACLE_SID找到参数文件,参照文件里记录了要启动的数据库;

根据当前操作系统环境变量的ORACLE_SIDORACLE_HOME/dbs寻找对应ORACLE_SIDspfilepfile来启动数据库。

 

问题43Grid安装时候搜索不到磁盘怎么解决

解决方案

把字符设备更改成块设备即可。

 

问题44oracle自增字段做主键是否会比较快

解决方案

自增主键本身就是增序索引,索引块中存储的记录也都是按顺序存在数据块中,此时排序效率肯定要高。

 

问题45:请问如何修改一张表的主键

解决方案

alter table aaa

drop constraint aaa_key ;

alter table aaa

add constraint aaa_key primary key(a1,b1) ;

 

问题46:如何创建SPFILE

 

解决方案

SQL> connect / as sysdba

SQL> select * from v$version;

SQL> create pfile from spfile;

SQL> CREATE SPFILE FROM PFILE='Era9iadmineyglepfileinit.ora';

文件已创建。

SQL> CREATE SPFILE='Era9idatabaseSPFILEEYGLE.ORA' FROM PFILE='Era9iad

mineyglepfileinit.ora';

文件已创建。

 

问题47:如何测试SQL语句执行所用的时间

解决方案

SQL>set timing on ;

SQL>select * from tablename;

 

问题48SQL语句如何插入全年日期

解决方案

create table BSYEAR (d date);

insert into BSYEAR

select to_date('20030101','yyyymmdd')+rownum-1

from all_objects

where rownum <= to_char(to_date('20031231','yyyymmdd'),'ddd');

 

问题49:怎样估算SQL执行的I/O

解决方案

SQL>SET AUTOTRACE ON ;

SQL>SELECT * FROM TABLE;

OR

SQL>SELECT * FROM v$filestat ;

 

问题50:如何查看数据文件放置的路径

解决方案

col file_name format a50

SQL> select tablespace_name,file_id,bytes/1024/1024,file_name from dba_data_fi

les order by file_id;

 

问题51:如何用正则表达式取出指定的方括号的值

解决方案

可以尝试用纯PL/SQL来实现你这个函数,包括按逗号解析、排序、拼接都用PLSQL完成。

排序部分没有SQLORDER BY那么方便,可以试试用关联数组,即 TABLE OF ... INDEX BY VARCHAR2(100) 这样的,把你要排序的字符串用作数组下标。然后用 FIRST, NEXT来遍历这个稀疏数组,间接完成了排序的动作。

分享好友

分享这个小栈给你的朋友们,一起进步吧。

Oracle数据库技术集
创建时间:2020-05-15 15:15:11
菜鸟教程
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • 栈栈
    专家
戳我,来吐槽~