当前位置:首页 » 数据仓库 » oracle数据库学习笔记
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

oracle数据库学习笔记

发布时间: 2022-08-28 20:18:05

A. 关于Oracle数据库OCP考试及相关问题

你可以参考下我以前的2个回答.
Q1.我现在看的是OCA
1Z0-051
1Z0-052(11G),但是现在考试基本上都是1Z0-047和1Z0-042(10G),请问11G的东西和10G差的多么,如果看完了11G的能考10G的么?
还有现在ORACLE考试的论坛比较好的是哪个?最好能有最新题库的!
回答:
1.请问11G的东西和10G差的多么,
11g有自己的新特性,但总体上差不多
2.如果看完了11G的能考10G的么?
没问题
首先,你要搞清楚自己要考哪个,OCA,OCP?
OCA自己看书就可以,再做点007,042(10G),052(11G)的题库(网上有),就可以了,考试不难
OCP需要经过原厂培训(oracle官方规定,现在可以到个大培训中心询问,比如尚观,万和),再经过043(10G)的考试可以拿到OCP证书。OCP也不是很难,要多做笔记跟实验。如果没经过原厂培训,就算自己报名考试过了,ORACLE也是不会给你投递证书的。
论坛跟题库,1楼的ITPUB论坛上很多。
我的共享文档里也有OCP的笔记。
Q2.我现在已经工作,从事的工作多和oracle有关,不过都是些基础的,谈不上管理。我打算考oracle
ocp证书。但是一头雾水,特来此地找已经通过的XD请教以下问题:
1、是不是必须参加原厂培训,考试形式是什么样的?
2、这个证书的考试是不是还分oracle版本?
3、考试主要考几科,都是什么?
问题补充:我计划考10g的认证,需要考几门课?有没有教材可以提前看看的,介绍下。我现在没有oca的证书,不过听说可以参加某些培训直接考ocp,不知是否真假,请介绍下。多谢,多谢。。答的好的将追加分数。
十分感谢,能否介绍下市面上能买到的教材有哪些?很多人都说考试的时候发现和“题库”的一样,不知这类题库是什么意思?买到的还是参加培训机构时获得的,能否说明?
回答:
1.是的,官方规定
2。是的,比较普遍的是10g,11g也不少
3.10g:007(基本sql+plsql),042(管理1),043(管理2)
11g:007,052,053,内容跟10g对应,加了一些新特性,差别不大
教材
http://www.itpub.net/forum-4-1.html
我的共享文档里也有OCP笔记。
可以直接考到OCP,去各大培训机构询问下,比如万和,尚观,上海交大等,都是跟ORACLE原厂合作关系。原厂在北京
可以先看看OCA认证考试指南,了解下体系结构,新华书店好像有。
“《OCA认证考试指南(IZO-052):Oracle
Database
11g
Administrat》旨在对参加OCA
Oracle
Database
11g
Administration
I考试的读者提供帮助。每一章都配备了练习题、自测题、实践题、本章知识点回顾和小结,从各个方面使读者对本章所学内容进行充分的消化和吸收。《OCA认证考试指南(IZO-052):Oracle
Database
11g
Administrat》是OCA认证考试最权威的辅导教程,也是Oracle从业人员必备的参考书。”跟042差别不大。
考试题目基本都出自题库(论坛上都有下载),所以考试是比较好过的,培训的话会有原厂教材发的,但过了OCP也不代表什么(一张纸而已),企业还是会考察你的真正能力,所以想要从事这方面的工作需要自己不断学习,多去ITPUB上交流

B. Java的学习技巧是什么

下面简单列举一下大家学习java的一个系统知识点的一些介绍

一、java基础部分:java基础的时候,有些知识点是非常重要的,比如循环系列。For,while,do-while.这方面只要大家用心点基本没什么难点。

二、面向对象:oop面向对象的时候,偏重理论,相信这方面的文章也很多,大家可以多看看,在这就不说了。重点掌握面向对象的三大特征和基本原理。

三、java核心一:这方面主要偏重API,所以在学习了这章的时候,一定要对照API去学习,多看API,主要就是方法多,string和集合的方法最为重要。后面将为大家提供本人整理的部分笔记。

四、java核心二:主要讲解了异常,线程和IO流,其实个人认为重点掌握线程就行,对于流和异常多写就行,线程偏重理论也最为重要。

五、oracle数据库方面:建议学习数据库的时候大家一定要端正态度,数据库极为重要,本人当时在学习这个的时候,一直以为数据库只是为了增删改查,故没有认真学习,后期面试的时候吃了不少亏,因为现在软件公司对数据库的要求跟java一样重要,基本都会单独一张笔试题笔试数据库。

六、JDBC/XML系列:JDBC主要是3个核心接口(Connection) (Statement) (ResultSet)的使用,大家在学习的时候,熟练运用3接口,jdbc的原理也相当重要,虽然后期学习了HIbernate之后,JDBC不需要再用,但其底层原理还是JDBC,而且现在很多软件公司不一定会用到Hibernate框架,所以建议大家还是把“本”学好,XML:重点掌握解析互换的2个核心接口方法。

七、HTML/CSS/JS:对于这个,本人相当纠结,因为这个有点偏向于美工的意思,所以后期想从事后台开发的同学一般不会太重视,但是现在都是web项目,而且很多软件公司并不是把许多这方面的事情交给美工(除非是那种有很高要求的静态页面),而且现在html代码都是在jsp里面写,所以建议还是好好学学,因为公司不会让一个美工去专门为你写一些简单的html代码,包括js!这章其实不难,就是属性方法知识点比较多,大家多记记,多写写,重在多练!

八、Servlet/Jsp:如果想从事web和b/s开发(现在基本都是web和b/s开发),这章极为重要,服务器的访问以及配置。tomcat的使用都在这一章,虽然后期struts框架的学习简化了servlet代码的繁琐性,但是你可知道现在有些公司只用servlet不用struts!即使用了框架技术也不一定是struts!servlet跟JDBC一样都是“本”,而struts和Hibernate一样都是封装了它们而后简化代码而已。所以只有把“本”学会了,就不怕框架的变化!jsp就不多说了,如果你学习java这个就不会缺少!后期b/s项目页面的布局以及功能就全靠它了。

九、Ajax/Jquery:当初学习这个的时候,本人没有用心去学,然后结果就是本人在进公司之后花了一个星期的时间练习jQuery!这个对于强化web服务器页面的功能技术实在是强大。这个封装了js对象的技术,可以对jsp页面元素进行样式的更改以及操作,想要玩好web项目,这个技术必须玩好!

十、SSH:传说中的三大框架;

Struts:前面已经提到,这个框架技术主要是为了弥补servlet和jsp页面之间交互的复杂性,可以有效的提高客户端与服务器之间的交互。而且采用了MVC思想进行改善减弱代码之间的复杂性。

Hibernate:主要封装了jdbc的核心功能,可以采用映射方式访问并操作数据库,一定程度上讲是简化了程序代码,但前面已经提到,由于是框架,而框架是随着时代而改变的,并且很多公司不一定用到这个框架,所以,只有掌握好JDBC的根本原理,才会更加理解这个框架。

Spring框架:其实后期学框架知识大家都会觉得很无趣和乏味,因为框架的知识都是理论很深的知识点,spring主要是要完善代码之间的耦合度,包括类似工厂模式的对象自动控制,AOP的事物日志管理等,都其实是为了减少程序员的工作量,但不得不说是有很大的作用的,而且这个框架可以整合JDBC以及Hibernate,struts技术,可以把所有的框架技术都整合在一起。相当于一块主板把内存,风扇,cpu,显卡都集中在一起。

前面所有的都是个人学习之中的一点感受,希望大家也能有所感触,主要想说明的是前面的基础一定要打好。

对于学习方法的问题也可以和大家聊一聊,本人在学习之初,由于面向对象和集合一些理论较深的知识点出现,导致后期比较注重理论,最终在写实际项目的时候吃了苦头,因为代码量没有跟上,即使理论都懂,但很多功能还是无法自己写出,所以要强调的是在注重理论的情况下一定要多写代码。

我的建议是在理论比较深刻的知识点面前,比如面向对象,集合,线程这些知识,多看点理论,而对于html,css以及API方法比较多的知识点的情况下,多写代码。总之,各50%最好!当然,这就需要大家付出更多的时间和精力辛苦勤劳下了!java的学习还是要多练代码,多思考,举一反三,任何的知识点只要你认真的去做,没有拿不下的顽石,勤能补拙,相信自己,然后用功,你就胜利了。

摘自:张纯睿的博客,更多学习资料

C. oracle理论学习详解及各种简单操作例子怎么解决

1. 数据库的发展过程
层次模型 -->网状模型 -->关系模型 -->对象关系模型
2. 关于数据库的概念
DB:数据库(存储信息的仓库)
DBMS:数据库管理系统(用于管理数据库的工具)
RDBMS:关系型数据库管理系统
ORDBMS:对象关系型的数据库管理系统
3. Oracle数据库的主要特点
1)支持多用户、大事务量的处理
2)数据库安全性和完整性控制
3)支持分布式数据处理
4)可移植性
4.Oracle一些常见问题?
1)如果我只有一张表,为什么我还要创建数据库?
SQL语言要求所有表都需放在数据库里。这项设计当然有它好的理由。SQL能控制多为用户同时访问表的行为。能够授予或撤销对整个数据库的访问权。这有时比控制每张表的权限要简单很多
2)创建库的命令的字母全是大写,一定要这样吗?
有些系统确实要求某些关键字采用大写形式。但SQL本身不区分大小写。也就是说,命令不大写也可以,但命令大写是良好的SQL编程惯例。
3)给数据库、表和列命名时有什么主意事项吗?
创建具有描述性的名称通常有不错的效果。有时候要多用几个单词来命名。所有名称都不能包含空格,所以使用下划线能够让你创建更具描述性的名称。命名时最好避免首字母大写,因为SQL不区分大小写。极有可能会搞错数据库。
4)为什么不能直接把BLOB当成所有文本值的类型?
因为这样很浪费空间。VARCHAR或CHAR只会占用特定空间。不会多于256字符。但BLOB需要很大的存储空间。随着数据库的增长,占用存储空间就是冒着耗尽硬盘空间的风险。另外,有些重要的字符串运算无法操作BLOB类型的数据。只能用于VARCHAR或CHAR。
5)为什么需要INT和DEC这类数值类型?
节省数据库存储空间和效率有关。为表的没列选择最合适的数据类型可以为表瘦身,还可以使数据操作更为快速。
5.Oracle关系数据库基础
1)主键:表中其中一列或几列的组合,其值能唯一标识表中每一行。
表中任何列都可以作为主键,但要满足如下条件:
任何两行都不具有相同的主键值
每个行都必须具有一个主键值(主键列不允许为null值)
主键列中的值不允许修改或更新
主键值不能重用(如果某行从表中删除,它的主键不能赋给以后的新行)
一般以id或uuid作为主键的名字
2)外键是什么:
在一个关系(参照表)中是主键,而另一个关系引用这个键。那么这个键在另一个关系中就是外键。
3)外建能干什么:
使两个关系(表)形成关联,外键只能引用参照表中的主键。保持数据一致性,完整性。
如图:

4)如何在数据库内表示一对一

5)如何在数据库内表示一对多

6)关系模型的完整性约束是什么?
是通过关系的某种约束条件对关系进行约束。也就是说关系的值随时间变化时应该满足一些约束条件。如年龄不能超过1000,性别必须是男或者女
7)关系模型的完整性约束能有什么?
实体完整性、参照完整性、用户自定义完整性。
实体完整性:针对基本关系而言,也就是一个二维表,主键不能为NULL
参照完整性:表之间存在关系,自然就存在关系的引用(外键),表和表之间的关系通过外键实现,外键可以为NULL或引用表的主键
用户自定义完整性:针对不同的需求定义自己的完整性约束,如不允许学生编号中出现非数字字符,性别必须是男或者女
6. Oracle自学笔记
1)数据库和表的名称不一定要大写。
2)列是存储在表中的一块数据,行是一组能够描述某个事物的列的集合。列和行构成了表。
3)创建oracle数据库。使用oracle自带的Database Configuration Assistant 来创建库
4)使用DBA身份 创建表空间。具体sql如下:
create tablespace pzw datafile 'C:/oracle/pzw.dbf' SIZE 1024M REUSE AUTOEXTEND OFF extent management local segment space
management auto;
5)删除用户命令
drop user pzw cascade;
6)删除表空间命令
DROP TABLESPACE pzw INCLUDING CONTENTS AND DATAFILES;
7 )查看表空间命令。

链接地址:查看oracle表空间的两种方式
8)创建用户。
create user pzw identified by pzw;
9)将包空间分配给用户
alter user pzw default tablespace pzw;
10)给用户授权
grant create session, create table, unlimited tablespace to pzw;
11)创建表
CREATE TABLE doughnut_list
(
doughnut_name VARCHAR(10),
doughnut_type VARCHAR(6),
doughnut_birthday DATE
);

12)删除表
DROP TABLE
doughnut_list;

13)给表中增加一列
Alter table EMP add sale number;

14)数据库插入一条数据
insert into DEPT_EMP_TABLE (DEPT_EMP_NO,emp_no,Dept_No,Joined_Date) values (009,'00002',1,to_date('2011-2-28 15:42:56','yyyy-mm-dd hh24:mi:ss'));
commit;

15)数据库修改一条数据
update emp set emp_name='张惠妹',age=20,sex='女',profession='流行歌手' where emp_no = '00002';
commit;
16)数据库删除一条数据

delete emp where emp_no = '000013';
commit;

17)查询全部数据
select * from emp;
18)创建视图
create view adress_view as select * from pzw.adress;

以下为oracle演示数据操作及练习题(对菜鸟及有用。使用scott 登陆。默认密码tiger)
1.查看演示数据的表。
select*fromtab
或者selecttable_namefromuser_tables;
2.查看表结构(plsql操作无效。使用命名提示符 可以操作)
desc dept;
3.查看员工姓名
select ENAMEfrom emp;
4.查询员工的编号和明星(sql语句不区分大小写)
select empno, enamefrom emp;
5.查询所有的字段
select*fromemp;
一般建议不使用*号,使用*号不明确,建议将相关的字段写到select语句的后面,使用*号的效率比较低
6.列出员工的编号,姓名和年薪。
select empno, ename,sal*12from emp;

select语句中可以使用运算符,以上存在一些问题,年薪的字段名称不太明确

7.将查询出来的字段显示为中文
select empnoas 员工编号, ename as 员工姓名, sal*12 as 年薪 from emp;
可以采用as命名别名,as可以省略
如:可以采用as命名别名,as可以省略
8.查询薪水等于5000的员工
select empno, ename, sal from emp where sal=5000;

如果是字符类型的数据进行比较的时候,是区分大小写的。
9.查询薪水不等于5000的员工
select empno, ename, sal from emp where sal<>5000;
10.查询工作岗位不等于manager的员工
select empno,ename,sal,job from emp where job<>
'manager';

在sql语句中如果是字符串采用单引号,引起来,不同于Java中采用双引号,如果是数值型也可以引起来,只不过是数值类型数据当成字符串来处理
11.查询薪水为1600到3000的员工(第一种方式,采用>=和<=)
select empno, ename, sal from emp where sal>=1600 and sal<=3000;
查询薪水为1600到3000的员工(第一种方式,采用between ...and...)
select empno,ename,sal,job from emp where salbetween
1600and 3000;

between ….and …,包含最大值和最小值

between ….and …,不仅仅可以应用在数值类型的数据上,还可以应用在字符数据类型上

between ….and …,对于两个参数的设定是有限制的,小的数在前,大的数在后
12.查询津贴为空的员工
select * from emp where commis null;

13.查询津贴不为空的员工
select * from emp where commis not null;
14.工作岗位为MANAGER,薪水大于2500的员工。
select empno, ename, sal from emp where job='MANAGER'and sal>2500;

and表示并且的含义,表示所有的条件必须满足
15.查询出job为manager和job为salesman的员工。
select * from emp where job='MANAGER'or job='SALESMAN';

or,只要满足条件即可,相当于或者
16.查询薪水大于1800,并且部门编号为20 或者 30的
select * from emp where sal>1800and (deptno=20or deptno=30);

17.查询出job为manager和job为salesman的员工
select * from emp where jobin('MANAGER','SALESMAN');
18.查询job不等于MANAGER并且不能与SALESMAN的员工(第一种写法)
select * from emp where job<> 'MANAGER' and job <> 'SALESMAN';

19 .查询job不等于MANAGER并且不能与SALESMAN的员工(第二种写法)

select * from emp where jobnot in('MANAGER','SALESMAN');

20.查询以M开头的所有员工
select * from emp where ename like 'M %';

21.查询以T结尾的所有员工
select * from emp where ename like '%T';

22.查询以O结尾的所有员工
select * from emp where ename like '%O%';

23.查询姓名中第一个字符为A的所有员工
select * from emp where ename like '_A%';

Like可以实现模糊查询,like支持%和下划线匹配

Like中%和下划线的差别?
%匹配任意字符出现任意次数
下划线只匹配一个任意字符出现一次

Like语句是可以应用在数值类型的数据上的,但是如果没有使用引号括起来的话,那么不能使用%和下划线。类似于等号的操作,如果使用引号括起来的话,那么可以使用%和下划线,将数值类型的数据转换为字符类型后进行处理。
24.按照薪水由小到大排序
s elect * from emporder by sal;

如果存在where子句那么order by必须放到where语句的后面
25.手动指定按照薪水由小到大排序
select * from emp order by saldesc;

26. 按照薪水和姓名排序
select * from emp order by sal desc ,ename desc;

如果采用多个字段排序,如果根据第一个字段排序重复了,会根据第二个字段排序

select * from emp order by sal asc;

26.手动指定按照薪水由大到小排序
select * from emporder by sal desc;

27.按照薪水升序(使用字段的位置来排序)
select * from emp order by 6;

不建议使用此种方式,采用数字含义不明确,程序不健壮
28.查询员工.将员工姓名全部转换成小写。
select lower(ename)from emp;

29.查询job为manager的员工
select * from emp where job=upper('manager');

30.查询姓名以M开头所有的员工
select * from emp wheresubstr(ename, 1,1)='M';

方法的第二个参数表示的是查询字符的位置,0,1都表示第一个字符,负数表示从结尾开始的位置,第三个参数表示截取字符串的长度。
31.取得员工姓名的长度
select length(ename) from emp;

32.取得工作岗位为MANAGER的所有员工
select * from emp where job=trim('MANAGER ');

trim会去首尾空格,不会去除中间的空格
33.查询1986-02-20入职的员工(第一种方法,与数据库的格式匹配上)
select * from emp where HIREDATE='20-2月 -81';

查询1982-02-20入职的员工(第二种方法,将字符串转换成date类型)
select * from emp where hiredate=to_date('1981-02-20 00:00:00', 'YYYY-MM-DD HH24:MI:SS');

to_date可以将字符串转换成日期,具体格式to_date(字符串,匹配格式)
34.查询1981- 02-30以后入职的员工,将入职日期格式为yyyy-mm-dd hh:mm:ss
select empno, ename,to_char(hiredate,'yyyy-mm-dd hh24:mi:ss')from emp where hiredate>to_date('1981-02-2000:00:00', 'YYYY-MM-DD HH24:MI:SS');

35.查询员工薪水加入前分位
select empno, ename, to_char(sal, '$999,999') from emp;

36.查询薪水加入千分位和保留两位小数
select empno, ename, to_char(sal, '$999,999.00') fromemp;

将数字转换成字符串,格式

控制符

说明

9

表示一位数字

0

位数不够可以补零

$

美元符

L

本地货币符号

.

显示小数

,

显示千分位

37.将字符串转换成数值
select * from emp where sal>to_number('1,500','999,999');
38.取得员工的全部薪水,薪水+津贴
select empno, ename, sal, comm, sal+nvl(comm,0) fromemp;

39.如果job为MANAGER薪水上涨10%,如果job为SALESMAN工资上涨50%(case … when … then …end)
select empno, ename, job, sal, (casejobwhen 'MANAGER' thensal*1.1when 'SALESMAN' thensal*1.5end)as newsal from emp;

40.如果job为MANAGER薪水上涨10%,如果job为SALESMAN工资上涨50%(decode)
select empno, ename, job, sal, decode(job,'MANAGER', SAL*1.1, 'SALESMAN',sal*1.5) as newsal from emp;

41.四舍五入
select round(1234567.4567, 2) from al;

Dual是oracle提供的,主要为了方便使用,因为select的时候需要用from
42.聚合函数

count

取得记录数

sum

求和

Avg

取平均

Max

取最大的数

min

取最小的数

43.取得所有员工人数
select count(*) from emp;

Count(*)表示取得所有记录,忽略null,为null值也会取得
44.取得津贴不为null的员工数
select count(comm) from emp;

采用count(字段名称),不会取得为null的纪录
45.取得工作岗位的个数
select count(distinctjob) from emp;

Distinct可以去除重复的纪录
46.取得薪水的合计
select sum(sal) from emp;

47取得薪水的合计(sal+comm)
select sum(sal+nvl(comm, 0)) from emp;
48.取得平均薪水
select avg(sal) from emp;

49.取得最高薪水
select max(to_char(hiredate, 'yyyy-mm-dd')) from emp;

50.取得最小薪水
select min(sal) from emp;

51.取得最早入职的员工
select min(hiredate) from emp;

52.可以将这些聚合函数都放到select中一起使用
select count(*), sum(sal), avg(sal), max(sal),min(sal) from emp;

53.取得每个岗位的工资合计,要求显示岗位名称和工资合计。
select job, sum(sal) from empgroupby job;

采用group by,非聚合函数所使用的字段必须参与分组,
Group by中不能使用聚合函数
如果使用了order by,order by必须放到group by后面
54。取得每个岗位的平均工资大于2000
select job, avg(sal) from emp group by job having avg(sal) >2000;

分组函数的执行顺序:
1、 根据条件查询数据
2、 分组
3、 采用having过滤,取得正确的数据
55. 显示每个员工信息,并显示所属的部门名称
select ename ,dname from emp a ,dept b where a.deptno = b.deptno;

以上查询也称为“内连接”,指查询相等的数据
56.取得员工和所属的经理的姓名
select a.ename, b.ename from emp a, emp b wherea.mgr=b.empno;

以上称为“自连接”,只有一张表连接,具体的查询方法

57.(内连接)显示薪水大于2000的员工信息,并显示所属的部门名称
SQL99语法:
select ename,sal,dname from emp a join dept b on a.deptno = b.deptno where sal>2000;
SQL92语法
select ename,sal,dname from emp a, dept b where a.deptno=b.deptno and sal > 2000;

Sql92语法和sql99语法的区别:99语法可以做到表的连接和查询条件分离,特别是多个表进行连接的时候,会比sql92更清晰
58.(外连接)显示薪水大于2000的员工信息,并显示所属的部门名称,如果某一个部门没有员工。那么该部门也必须显示出来
select dname,ename from emp a right join dept b on a.deptno = b.deptno;
59.查询员工名称和所属经历的名称,如果没有上级经理,也要查询出来
Select e.ename, m.ename mname from emp e, emp mwhere m.empno(+) = e.mgr;
60.查询员工信息,查询哪些人是管理者,要求显示出其员工编号和员工姓名
select ename,ename from emp where empno in (select distinct mgr from emp where mgr is not null);
61.查询那些人的薪水高于员工的平均薪水,需要显示员工编号,员工姓名,薪水。
select empno, ename, sal from emp where sal>(selectavg(sal) from emp);

分析思路:首先根据文字描述找出被依赖的条件,逐次分析
62.查询各个部门的平均薪水所属的等级,需要显示部门编号,平均薪水,等级编号

select a.deptno, a.avg_sal, b.grade from (select deptno, avg(sal) avg_sal fromemp group by deptno) a, salgrade b where a.avg_sal between b.losal and b.hisal;

关键点:将子查询看作一张表
63.查询员工信息以及部门名称
Select e.empno, e.ename, e.deptno, (select dname from dept where deptno = e.deptno) as dname from emp e
64.union可以合并集合(相加)

select * from emp where job='MANAGER'
union
select* from emp where job='SALESMAN'
65.minus可以移出集合(相减)
查询部门编号为10和20的,取出薪水大于2000的。

select * from emp where deptno in(10, 20)
minus
select* from emp where sal>2000
66.rownum隐含字段
select rownum, a.* from emp a;
67.取得前5条数据
select * from emp where rownum <=5;
68.取得薪水最好的前5名

select empno, ename, sal from (select empno,ename, sal from emp order by sal desc)whererownum <=5

D. oracle数据库入门怎么入

oracle数据库入门学习是一个重复的过程,理论和时间交替来完成,不要看书看不明白非要看明白,到机器上试一下就明白了;不要机器上反复弄不通的东西还弄,懂得向书上和旁边的人求助。
一、定位
oracle分两大块,一块是开发,一块是管理。
开发主要是写写存储过程、触发器什么的,还有就是用Oracle的Develop工具做form。有点类似于程序员,需要有较强的逻辑思维和创造能力,比较辛苦,是青春饭;
管理则需要对oracle数据库的原理有深刻的认识,有全局操纵的能力和紧密的思维,责任较大,因为一个小的失误就会荡掉整个数据库,相对前者来说,后者更看重经验。
二、学习方法
学习方法就是:看书、思考、写笔记、做实验、再思考、再写笔记 。
看完理论的东西,自己静下心来想想,多问自己几个为什么,然后把所学和所想的知识点做个笔记;在想不通或有疑问的时候,就做做实验,想想怎么会这样,同样的,把实验的结果记下来。思考和做实验是为了深入的了解这个知识点。而做笔记的过程,也是理清自己思路的过程。
学习的过程是使一个问题由模糊到清晰,再由清晰到模糊的过程。而每次的改变都代表着你又学到了一个新的知识点。
学习的过程也是从点到线,从线到网,从网到面的过程。当点变成线的时候,你会有总豁然开朗的感觉。当网到面的时候,就已经达到大神级别了。
三、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这些),学会如何熟练使用这些工具。

E. 怎么样才能快速学会oracle

我觉得吧,oracle的体系太庞大了,对于初学者来说,难免会有些无从下手的感觉,什么都想学,结果什么都学不好,所以把我的经验分享下,希望让刚刚入门的人对oracle有一个总体的认识,少走一些弯路。
acle分两大块,一块是开发,一块是管理。开发主要是写写存储过程、触发器什么的,还有就是用Oracle的Develop工具做form。有点类似于程序员,需要有较强的逻辑思维和创造能力,个人觉得会比较辛苦,是青春饭;管理则需要对oracle数据库的原理有深刻的认识,有全局操纵的能力和紧密的思维,责任较大,因为一个小的失误就会down掉整个数据库,相对前者来说,后者更看重经验。 我的方法就是看书、思考、写笔记、做实验、再思考、再写笔记 。看完理论的东西,自己静下心来想想,多问自己几个为什么,然后把所学和所想的知识点做个笔记;在想不通或有疑问的时候,就做做实验,想想怎么会这样,同样的,把实验的结果记下来。思考和做实验是为了深入的了解这个知识点。而做笔记的过程,也是理清自己思路的过程。发现不懂得可以在相关论坛里面求助,看看别人是怎么分析问题的。你还可以在:http://hi..com/marrensy/blog/item/8a7120c40f3384e153664fdb.html里面看看,不会让你失望的哦。希望可以帮到你呢。

F. 请提供几本oracle数据库的学习用书,注意是适合一个没有任何计算机基础的人用的,谢了!

推荐一本书叫:涂抹Oracle:三思笔记之一步一步学Oracle。感觉不错的。不是纯理论知识。各大电商都有卖。推荐你去下载mldn李兴华的Oracle基础视频,我Oracle就是听这个自学的。非常实用也很基础。希望对你有帮助。

G. 谁有oracle数据库学习资料或笔记都可

我有,可留邮箱
或是在谷歌上搜一下 上面有很多的

H. oracle学习过程

Oracle有很多值得学习的地方,Oracle体系太庞大了,对于初学者来说,难免会有些无从下手的感觉,什么都想学,结果什么都学不好,所以把学习经验共享一下,希望让刚刚入门的人对Oracle有一个总体的认识,少走一些弯路。 一、定位 Oracle分两大块,一块是开发,一块是管理。开发主要是写写存储过程、触发器什么的,还有就是用Oracle的Develop工具做form。有点类似于程序员,需要有较强的逻辑思维和创造能力,个人觉得会比较辛苦,是青春饭;管理则需要对Oracle数据库的原理有深刻的认识,有全局操纵的能力和紧密的思维,责任较大,因为一个小的失误就会down掉整个数据库,相对前者来说,后者更看重经验。 因为数据库管理的责任重大,很少公司愿意请一个刚刚接触Oracle的人去管理数据库。对于刚刚毕业的年轻人来说,可以先选择做开发,有一定经验后转型,去做数据库的管理。当然,这个还是要看人个的实际情况来定。 二、学习方法 我的方法很简单,就是:看书、思考、写笔记、做实验、再思考、再写笔记。 看完理论的东西,自己静下心来想想,多问自己几个为什么,然后把所学和所想的知识点做个笔记;在想不通或有疑问的时候,就做做实验,想想怎么会这样,同样的,把实验的结果记下来。思考和做实验是为了深入的了解这个知识点。而做笔记的过程,也是理清自己思路的过程。 Oracle学习过程是使一个问题由模糊到清晰,再由清晰到模糊的过程。而每次的改变都代表着你又学到了一个新的知识点。 Oracle学习过程也是从点到线,从线到网,从网到面的过程。当点变成线的时候,你会有总豁然开朗的感觉。当网到面的时候,你就是高手了。 很多网友,特别是初学的人,一碰到问题就拿到论坛上来问,在问前,你有没有查过书,自己有没有研究过,有没有搜索一下论坛?这就叫思维惰性。由别人来回答你的问题,会让你在短时间内不费劲地弄懂这个知识点,然而通过自己的努力去研究它,不但会更深入的了解这个知识点,更重要的是在研究的过程会提高你解决问题和分析问题的能力。总的来说,没有钻研的学习态度,不管学什么东西,都不会成功的。 当然,初学的人很多时候是因为遇到问题时,无从下手,也不知道去哪里找资料,才会到论坛上提问题的。但我认为,在提问的时候,是不是可以问别人是如何分析这个问题?从哪里可以找到相关的资料?而不是这个问题的答案是什么?授人以鱼不如授人以渔。