`
一帆过海
  • 浏览: 16215 次
  • 性别: Icon_minigender_1
  • 来自: 济南
最近访客 更多访客>>
社区版块
存档分类
最新评论

如何成一个真正的DBA?

阅读更多

如何成一个真正的DBA?

文章来源:CSDN 作者:selina33

     oracle的体系太庞大了,对于初学者来说,难免会有些无从下手的感觉,什么都想学,结果什么都学不好,所以把学习经验共享一下,希望让刚刚入门的人对oracle有一个总体的认识,少走一些弯路。

一、定位

    oracle分两大块,一块是开发,一块是管理。开发主要是写写存储过程、触发器什么的,还有就是用Oracle的Develop工具做form。有点类似于程序员,需要有较强的逻辑思维和创造能力,个人觉得会比较辛苦,是青春饭J;管理则需要对oracle数据库的原理有深刻的认识,有全局操纵的能力和紧密的思维,责任较大,因为一个小的失误就会down掉整个数据库,相对前者来说,后者更看重经验。

    因为数据库管理的责任重大,很少公司愿意请一个刚刚接触oracle的人去管理数据库。对于刚刚毕业的年轻人来说,可以先选择做开发,有一定经验后转型,去做数据库的管理。当然,这个还是要看人个的实际情况来定。

二、学习方法

    我的方法很简单,就是:看书、思考、写笔记、做实验、再思考、再写笔记

    看完理论的东西,自己静下心来想想,多问自己几个为什么,然后把所学和所想的知识点做个笔记;在想不通或有疑问的时候,就做做实验,想想怎么会这样,同样的,把实验的结果记下来。思考和做实验是为了深入的了解这个知识点。而做笔记的过程,也是理清自己思路的过程。

    学习的过程是使一个问题由模糊到清晰,再由清晰到模糊的过程。而每次的改变都代表着你又学到了一个新的知识点。

    学习的过程也是从点到线,从线到网,从网到面的过程。当点变成线的时候,你会有总豁然开朗的感觉。当网到面的时候,你就是高手了

    很多网友,特别是初学的人,一碰到问题就拿到论坛上来问,在问前,你有没有查过书,自己有没有研究过,有没有搜索一下论坛?这就叫思维惰性。由别人来回答你的问题,会让你在短时间内不费劲地弄懂这个知识点,然而通过自己的努力去研究它,不但会更深入的了解这个知识点,更重要的是在研究的过程会提高你解决问题和分析问题的能力。总的来说,没有钻研的学习态度,不管学什么东西,都不会成功的。

    当然,初学的人很多时候是因为遇到问题时,无从下手,也不知道去哪里找资料,才会到论坛上提问题的。但我认为,在提问的时候,是不是可以问别人是如何分析这个问题?从哪里可以找到相关的资料?而不是这个问题的答案是什么?授人以鱼不如授人以渔。

    下面我讲下我处理问题的过程

    首先要知道oracle的官方网站:www.oracle.com 这里有oracle的各种版本的数据库、应用工具和权威的官方文档。其次,还要知道http://metalink.oracle.com/这里是买了oracle服务或是oracle的合作伙伴才可以进去的,里面有很多权威的解决方案和补丁。然后就是一些著名网站:asktom.oracle.com www.orafaq.net, www.dbazine.com。这里有很多经验之谈。

    遇到问题了。如果是概念上的问题,第一时间可以找tahiti.oracle.com,这里会给你最详细的解释。如果在运行的过程中出了什么错误。可以去metalink看看。如果是想知道事务的处理的经验之谈。可以去asktom。当然。这里只是相对而言。

三、oracle的体系

    oracle的体系很庞大,要学习它,首先要了解oracle的框架。在这里,简要的讲一下oracle的架构,让初学者对oracle有一个整体的认识。

    1、物理结构(由控制文件、数据文件、重做日志文件、参数文件、归档文件、密码文件组成)

    控制文件:包含维护和验证数据库完整性的必要信息、例如,控制文件用于识别数据文件和重做日志文件,一个数据库至少需要一个控制文件

    数据文件:存储数据的文件

    重做日志文件:含对数据库所做的更改记录,这样万一出现故障可以启用数据恢复。一个数据库至少需要两个重做日志文件

    参数文件:定义Oracle 例程的特性,例如它包含调整SGA 中一些内存结构大小的参数

    归档文件:是重做日志文件的脱机副本,这些副本可能对于从介质失败中进行恢复很必要。

    密码文件:认证哪些用户有权限启动和关闭Oracle例程

    2、逻辑结构(表空间、段、区、块)

    表空间:是数据库中的基本逻辑结构,一系列数据文件的集合。

    段:是对象在数据库中占用的空间

    区:是为数据一次性预留的一个较大的存储空间

    块:ORACLE最基本的存储单位,在建立数据库的时候指定

    3、内存分配(SGA和PGA)

SGA:是用于存储数据库信息的内存区,该信息为数据库进程所共享。它包含Oracle 服务器的数据和控制信息, 它是在Oracle 服务器所驻留的计算机的实际内存中得以分配,如果实际内存不够再往虚拟内存中写。
PGA:包含单个服务器进程或单个后台进程的数据和控制信息,与几个进程共享的SGA 正相反PGA 是只被一个进程使用的区域,PGA 在创建进程时分配在终止进程时回收

    4、后台进程(数据写进程、日志写进程、系统监控、进程监控、检查点进程、归档进程、服务进程、用户进程)

    数据写进程:负责将更改的数据从数据库缓冲区高速缓存写入数据文件

    日志写进程:将重做日志缓冲区中的更改写入在线重做日志文件

    系统监控:检查数据库的一致性如有必要还会在数据库打开时启动数据库的恢复

    进程监控:负责在一个Oracle 进程失败时清理资源

    检查点进程:负责在每当缓冲区高速缓存中的更改永久地记录在数据库中时,更新控制文件和数据文件中的数据库状态信息。

    归档进程:在每次日志切换时把已满的日志组进行备份或归档

    服务进程:用户进程服务。

    用户进程:在客户端,负责将用户的SQL 语句传递给服务进程,并从服务器段拿回查询数据。

    5、oracle例程:Oracle 例程由SGA 内存结构和用于管理数据库的后台进程组成。例程一次只能打开和使用一个数据库。

    6、SCN(System Change Number):系统改变号,一个由系统内部维护的序列号。当系统需要更新的时候自动增加,他是系统中维持数据的一致性和顺序恢复的重要标志。

四、深入学习

    管理:可以考OCP证书,对oracle先有一个系统的学习,然后看Oracle Concepts、oracle online document,对oracle的原理会有更深入的了解,同时可以开始进行一些专题的研究如:RMAN、RAS、STATSPACT、DATAGUARD、TUNING、BACKUP&RECOVER等等。

    开发:对于想做Oracle开发的,在了解完Oracle基本的体系结构之后,可以重点关注PL/SQL及Oracle的开发工具这一部分。 PL/SQL主要是包括怎么写SQL语句,怎么使用Oracle本身的函数,怎么写存储过程、存储函数、触发器等。 Oracle的开发工具主要就是Oracle自己的Developer Suite(Oracle Forms Developer and Reports Developer这些),学会如何熟练使用这些工具。

    介绍几本oracle入门的好书

oracle官方文档:《concept》上面讲了oracle的体系和概念,很适合初学者看。
OCP的教学用书,也就是STUDY GUIDE(SG)。
Oracle8i 备份恢复手册
Oracle8高级管理与优化
Oracle8i PLSQL程序设计
Oracle8数据库管理员手册

    以上书本都是机械工业出版社出版。

介绍几个网站

http://tahiti.oracle.com/          oracle的官方文档
http://metalink.oracle.com/   oracle的技术支持网站。需要购买Oracle服务才能有一个帐号,才能登陆,有大量的Knowledge Base,大量问题解决经验。
http://www.oracle.com/        oracle的官方网站,可以在这里down oracle的软件、官方文档和获得最新的消息
http://www.dbazine.com/     Oracle的杂志
http://asktom.oracle.com/
http://www.orafaq.net/
http://www.ixora.com.au/
http://www.oracle-base.com/
http://www.dba-oracle.com/oracle_links.htm

分享到:
评论

相关推荐

    DBA 生存手册 成为一个RockStar级DBA

    ### DBA生存手册:成为一个RockStar级DBA #### 一、引言 数据库管理员(Database Administrator,简称DBA)是IT行业中一个重要的角色,负责维护数据库系统的稳定性和安全性。《DBA生存手册:成为一个RockStar级DBA...

    高清+目录 MySQLDBA修炼之道 Good!!

    《MySQL DBA修炼之道》是一本专为MySQL数据库管理员(DBA)量身打造的专业书籍,旨在帮助读者深入理解和掌握MySQL数据库的管理和优化技巧。书中的内容涵盖了从基础到高级的各种主题,包括数据库设计、性能调优、备份...

    [老白]DBA日记(第三部).pdf

    - **每日一个技术要点**:本书计划每天讨论一个Oracle技术要点,通过深入浅出的方式帮助读者理解其原理及解决问题的思路。 - **知识点来源**:主要参考Oracle Concepts文档,强调理解基本概念对于成长为高手的重要性...

    Oracle DBA认证题库

    Oracle DBA(数据库管理员)认证是Oracle公司提供的一项专业资格认证,旨在证明持证者具有管理和维护Oracle数据库系统的专业知识和技能。这个题库包含了Oracle DBA认证考试中可能遇到的各种问题,涵盖了数据库管理的...

    Mysql DBA修炼之道清晰版

    这份"Mysql DBA修炼之道清晰版"的资源,显然是一份详细的学习资料,旨在帮助读者提升在MySQL管理领域的技能。以下是该主题可能涵盖的一些核心知识点: 1. **MySQL概述**:包括MySQL的历史、特点、版本区别以及在...

    DBA笔试题 附答案

    在数据库管理与优化过程中,SQL语句的性能调整是至关重要的一个环节。调整SQL时最关注的几个指标包括: - **Response Time**: SQL执行的时间长度,即从提交SQL到返回结果所需的时间。 - **DB Block Gets**: 表示...

    oracle_dba.rar_oracle_oracle dba

    从一个版本升级到另一个版本,或者在不同硬件、操作系统之间迁移数据库,都是DBA需要掌握的技能。 13. **SQL优化**: 学习如何编写高效的SQL语句,理解执行计划,使用绑定变量,以及如何避免全表扫描等技巧。 14...

    大牛白鳝作品 老白Oracle DBA日志三部曲

    总的来说,通过阅读《老白Oracle DBA日志三部曲》,读者将能系统地学习到Oracle数据库的管理和运维技巧,提升自己在数据库领域的专业素养,无论是对于初级DBA还是经验丰富的专业人士,这都是一份宝贵的参考资料。...

    oracle之DBA教程

    "Oracle之DBA教程"是一个为新手量身定制的学习资源,旨在帮助初学者从零开始掌握Oracle数据库管理系统的各个方面,逐渐成长为一名合格的DBA(Database Administrator,数据库管理员)。本教程将覆盖安装、配置、性能...

    Oracle_Applications_DBA 系统概要及安装

    Oracle_Applications_DBA 系统概要及安装,真正掌握更多的知识

    ORACLE DBA教程

    控制文件是另一个关键组件,它是一个二进制文件,保存了数据库的元数据,如创建日期、数据库名称、数据文件和日志文件的位置等。在数据库的打开和访问过程中,都需要依赖控制文件。为了提高容错性,通常会配置镜像...

    DBA 日记 第三部 作者:大牛白鳝

    作者通过一个实例,讲述了如何引导新人阿风从理解ORACLE的基础组件、原理和算法出发,学会用ORACLE的思维去分析问题,从而实现技术上的飞跃。这个过程强调了学习数据库技术不应仅限于技巧和工具的使用,更应深入理解...

    MySQL DBA面试题和答案 高手总结 仅供参考

    2. **半同步复制**:在MySQL 5.5中引入,它确保事务在写入Master和至少一个Slave后才返回给客户端,从而减少了数据丢失的可能性。如果Slave宕机,Master会等待超时,然后切换到异步复制模式。 3. **无损半同步复制*...

    DBA日记第三部.pdf

    老白的经历和思想表明,对于一个DBA来说,技术知识的积累固然重要,但更重要的是培养解决问题的思路和方法。老白在与新手DBA阿风合作的过程中,并没有直接教授技术细节,而是帮助其理解了Oracle数据库的核心原理。...

    oracle dba 手册

    这个"Oracle DBA入门手册"显然旨在为初学者提供一个清晰的学习路径,帮助他们快速掌握Oracle数据库管理的基础知识。下面,我们将深入探讨Oracle DBA的核心职责以及相关的重要概念和技术。 首先,Oracle数据库是世界...

    Oracle DBA 两日速成课程

    这个两日速成课程旨在让你快速掌握Oracle DBA的基本技能,但请记住,Oracle数据库管理是一个深度和广度都相当大的领域,真正的精通需要时间和实践经验的积累。在实践中不断学习和成长,你将成为一名出色的Oracle DBA...

Global site tag (gtag.js) - Google Analytics