Oracle DBA遇到频次最高的五十个问题

简介: 随着数据价值在企业地位越来越高,DBA这一职位更是受到重视和支持,如何帮助各位数据达人维护好数据,也是ITPUB社区一直秉承的理念,本期我们将社区DBA关注最多的50个问题,已经各位大师对问题的解决方式进行了汇总和整理,期待大家更多给与问题和反馈,以下是问题和解决方案。 问题1:如何收集统计信息不影响数据库?解决方案大多数情况下,表的统计信息不准导致了优化器对于执行计划的错误计算,因此需要对表的统计信息进行更正,以便让优化器重新选择准确的 执行计划。但是在生产情况下,随意的收集统计信息,则会给数据库带来隐患:1、对重新收集统计信息的表,对应的一些SQL可能需要重新硬解

随着数据价值在企业地位越来越高,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/

问题2:Oracle安装完成后的初始口令?
解决方案
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和监听文件没有问题,那就是路径的问题了,检查PATH和TNS_ADMIN,是否正确,若不正确,修改正确,再查看pl/sql加载,工具-选项-OCI库里面的路径是否正确。

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

问题6:PL/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。

问题7:GoldenGate目标端检查发现错误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语句加--注释掉,启动复制进程,一般没有问题,如果修改的QQ号买卖平台表比较多,可以使用脚本检查

问题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:怎样查看哪些用户拥有SYSDBA、SYSOPER权限?
解决方案
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();

问题14:Oracle常用系统文件有哪些
解决方案
通过以下视图显示这些文件信息: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:不使用索引消除排序为什么性能更好
解决方案
这种属于稀疏结果的场景,不走这个避免排序的索引会更好些。

同样是扫描全表数据,一般FTS比FS更快。

fts=full table scan;

fs=full index scan;

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

问题18:ORA--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

问题20:12C中能否单独给PDB做DG
解决方案
可以针对某几个PDB做dataguard,有一个参数 enabled_pdbs_on_standby 来控制.

问题21:DataGuard是否需要配置静态监听
解决方案
不是一定需要配,但是最好配

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

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

问题22:Oracle在生产环境如何划分表空间
解决方案
1.索引与数据分开没有必要.

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

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

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

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

问题23:正式环境asm要加盘,需要重启udev服务,需要申请停机吗
解决方案
这个不需要重启,找到新添加的盘,添加到ASM就可以。

问题24:OGG使用add extract exta, SourceisTable初始化后,如何接着做增量同步
解决方案
如果源端是Oracle init的时候可以指定SCN,table user.*, SQLPREDICATE 'AS OF SCN 1909670000',初始化之后再从这个SCN开始应用队列文件.

问题25:如何知道开发前台使用update语句更新的值
解决方案
SQL TRACE 现在可能叫做 SQL monitor 或者直接10046event, 追踪 Session 。事后分析,可以用logminer挖redo,也可以针对特定SQL类型和表启用审计。

SQL TRACE 现在可能叫做 SQL monitor 或者直接10046event, 追踪 Session 。

问题26:物化视图可以基于scn开始同步么
解决方案
1、通过物化视图进行增量同步,平时有用,效果不错;

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

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

问题27:表空间的文件设置的自动扩大,文件32G无法自动新增数据文件
解决方案
可以给表空间多加几个数据文件,让这几个数据文件都自动增长。

问题28:关于多节点RAC中VIP漂移的疑问
解决方案
VIP漂移的规律对于连接数据库,没有关系。节点故障,导致VIP漂移后,你连接哪个节点和VIP漂移到哪个节点没有任何关系

问题29:关于B树索引的问题
解决方案
1、B*Tree的顶层节点称为root节点,即根节点;

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

3、B*Tree的leaf节点间有双向指针,而branch节点间没有

问题30:控制文件丢失如何恢复
解决方案
只是控制文件坏了,不代表数据丢失,直接重建就可以了.

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

问题31:Oracle的自动收集计划是什么量级的收集
解决方案
收集是全库范围内的,但并不是读取库中所有的数据,也不是对所有修改过的表都收集,是对修改数据量达到某个阈值的表进行收集,而且也不都是全表读,有时是按照一定的比例收集。

问题32:expdp怎么导出分区表的某些分区
解决方案
–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′…)”

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

问题34:怎么知道DB用的是CBO还是RBO
解决方案
一般没有修改的话,默认优化模式是choose,如果有分析过表则会走CBO,否则RBO,可以通过强制指定单个SQL的优化类型。

问题35:RAC安装时安装软件如何确定哪台服务器为节点1
解决方案
GI和数据库都先在节点1上跑,我记得是安装GI到运行ROOT.SH这个脚本时决定,也就是,谁先跑ROOT.SH,ASM1就给谁,后跑的就用ASM2。

问题36:oracle adg主库故障怎样启用备库
解决方案
这个就是failover了。

alter database recover managed standby database finish;

alter database commit to switchover to primary;

shutdown immediate;

startup;

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

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

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

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

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

table_t1(

card_no 账户,

product_no 产品,

product_num 数量,

start_dt 开始日期,

end_dt 结束日期

);

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

问题40:oracle数据库可以暴力备份吗?
解决方案
实际上os拷贝大小与oracle块大小不一致.

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

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

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

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

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

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

问题41:如何监控数据库表增长趋势
在巡检的时候发现很多数据库每天整体表空间占用率增长较快

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

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

解决方案
找到一个视图

DBA_HIST_SEG_STAT

问题42:oracle是通过什么方法来控制实例名
解决方案
先有实例,再有数据库:通过ORACLE_SID找到参数文件,参照文件里记录了要启动的数据库;

根据当前操作系统环境变量的ORACLE_SID去ORACLE_HOME/dbs寻找对应ORACLE_SID的spfile或pfile来启动数据库。

问题43:Grid安装时候搜索不到磁盘怎么解决
解决方案
把字符设备更改成块设备即可。

问题44:oracle自增字段做主键是否会比较快
解决方案
自增主键本身就是增序索引,索引块中存储的记录也都是按顺序存在数据块中,此时排序效率肯定要高。

问题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;

问题48:SQL语句如何插入全年日期
解决方案
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完成。

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

目录
相关文章
|
11月前
|
人工智能 运维 Oracle
ChatGPT能代替Oracle DBA吗?用Oracle OCP(1z0-083)的真题测试一下(文末投票)
ChatGPT已经通过了很多考试,姚远老师是Oracle OCP和MySQL OCP讲师,我很好奇ChatGPT能不能通过Oracle OCP的考试呢?让我们拿Oracle 19c OCP考试(1z0-082)的真题对ChatGPT进行一个测试。
137 0
|
11月前
|
人工智能 运维 Oracle
ChatGPT能代替Oracle DBA吗?用Oracle OCP(1z0-083)的真题测试一下。
第1道题ChatGPT就做错了,姚远老师心里不禁窃喜,看来ChatGPT也不咋地,我们也许不会失业,让我们来看看第一道题的题目
122 0
|
Oracle 关系型数据库 数据库管理
ORACLE分配DBA权限
ORACLE分配DBA权限
|
Oracle 安全 关系型数据库
【Oracle】什么?作为DBA,你竟然不会安装Oracle??
很长一段时间内,国内互联网公司都在提倡“去IOE”,但是很多企业还是愿意为昂贵的Oracle数据库买单,不少读者所在的公司也在用Oracle,很多读者自行安装Oracle数据库时,多多少少遇到了些问题,苦恼于几天下来还是没能解决问题。这不,不少读者跑来问我,让我输出一篇如何在物理机上安装Oracle的文章,最好是安装过程中不会出现各种“疑难杂症”。哈哈,这要求不过分,我周末也着实捣鼓了一番,不过我是安装在CentOS 7/ CentOS 8虚拟机中的,效果和在物理机中一样,整个过程也算是小有所成吧!输出此文,记录捣鼓的过程,与各位Oracle开发者共勉。
117 0
【Oracle】什么?作为DBA,你竟然不会安装Oracle??
|
SQL Oracle 关系型数据库
【学习资料】第1期Oracle DBA 增值 PostgreSQL,Greenplum 学习计划 - 珍藏级
大家好,这里是Oracle DBA 增值 PostgreSQL,Greenplum 学习计划 - 珍藏级
|
存储 SQL Oracle
【学习视频】第6期2019-Oracle迁移到PostgreSQL - 适合DBA与业务开发者
大家好,这里是《PG干O,仁心所象 - 去O实战培训》 公益活动纪录 - 《PG开发者指南、去O、管理与优化实践》
|
Oracle 关系型数据库 Linux
Oracle+Python适合 Oracle DBA 使用的 Python
传统上,当需要为操作系统编写一些脚本时,人们常常会选用 Bash 或 Perl 脚本工具。
1276 0