ORACLE培训总结

2024-06-27

ORACLE培训总结(通用9篇)

ORACLE培训总结 篇1

第一章 oracle10g的安装与基本设置

一、数据库基础部分。

oracle数据库应用系统结构与产品。

sql语言:操作数据库,同时用于数据库管理。(通用部分)sql*plus语言:对sql的扩充,主要增加一些报表。pl/sql语言:过程化语言。数据库分区存储技术。

1、oracle数据库应用系统结构与产品

oracle数据字典有4.2万个。数据字典只记录标识。

结构方面:sql与oracle完成不同,sql可建多个库,结构与oracle明显不同。i:代表internet.c语言结构性最好,计算能力最强。指纹识别系统只能用c.2、pl:procedural language:过程化语言,条件、判断、循环。sql属非过程化语言,只关心结果,不关心过程。

3、数据库分区存储技术(一个表存到多个表空间上)数据库存储数据的最小单位:表。

逻辑空间——>表空间(在物理上与磁盘对应)1 ——>多个磁盘。

一个表可以存在多个磁盘上,但不能存到多个表空间上。集中式存储:安全性不好,i/o不平衡。

数据库的分区存储技术:range、list(oracle 11自动增加)range:可以比大小。

list:不能比大小,例如:人口住址等。

4、数据库存取权限控制。

5、oracle 10g flashback:数据闪回。恢复前提:归档和备份。(1)基于时间的恢复:从5楼到4楼。必须从5楼下到一楼,再从1楼到4楼。逻辑备份: 物理备份:常说的备份点。

不完全恢复:向回倒,不可逆转,日志自动清0,有的数据要丢失。exp、import.(1)基于时间的恢复(2)基于中止(撤消)的恢复。(3)基于事务的恢复。完全恢复。

delete from,rollback能100%恢复。drop,flashback不一定能恢复。

二、程序设计

pl/sql程序设计。存储过程(procedure),函数(function),包(package),数据库触发器(data triggers(枪栓))。

三、系统管理(dba)

1、oracle核心软件安装与产品升级。sun solaris hp ux 国税 aix 银行 tru64 电力 数据库的排序:在临时表空间中进行。8i和9i排序完不释放。10g可自动释放。640万人无人居住,不发生电费。

命令行模式运行速度快,容易发现问题的存在。

oracle占用可用内在的55-57%,所以不要建两个以上的库,oracle按表空间划分用户,sql可建多个库,结构与oracle明显不同。

2、创建主要的数据库存储结构。

划分磁盘空间。

3、数据库权限与角色管理。角色:权限的组合。

4、监视与控制用户对于数据库的操作。

5、数据库的启动与关闭。

6、数据库性能优化与调整。

7、数据库的备份与恢复。

四、基于web应用开发(会话进程)。

会话数(在线数)< 用户数< 进程数在(windows称为服务)< 操作系统核心参数 如何查看修改连接数,进程数及用户数,三者之间有什么关系? show parameter session;最大session数 show parameter process;最大进程数

select count(1)from all_users;查看已安装数据库的用户数 select * from all_users;oracle自带的用户数如何查。

默认的情况下系统中的最大session = min(session ,process * 1.1 + 5)

1、我们把它称为一次对话,或者叫会话。同样,在我们用电脑工作时,打开的一个窗口或一个web页面,我们也可以把它叫做一个“会话”,扩展到一个局域网里面,所有用户要通过防火墙上网,要打开很多个窗口或web页面(即会话),那么,这个防火墙,所能处理的最大会话数量,就是“并发连接数”。

(1)查看oracle 10g数据库会话数 select * from v$session;当前总会话数:select count(*)from v$session;可用总会话数:在sqlplus里查询,show parameter session

2、查看已安装数据库的用户数:select count(1)from all_users;sql>select * from all_users;

3、查看进程数

使用sys,以sysdba权限登录:sql> show parameter processes;

4、$ps –ef | grep oracle 进程,在windows称为服务。实例包括一个内存和进程(在windows中为服务)

按我的理解来说session就等价与一个客户端,它是用户经过用户进程到oracle事例的特定连接.它从用户连接开始一直持续到用户断开连接或退出数据库为止.进程,笼统地认为一个程序有若干进程组成,从os角度讲程序是静态的,而进程是动态的罢了.进程可以分为user process和oracle process.说穿了,进程就是用来执行程序的时候产生的,是一个动态过程.第二章 oracle安装

一、asm(automatic storage management)自动存储管理。oracle10g 新内容。镜像:oracle 10g以后才支持。磁盘组:diskmap 逻辑设备

裸设备:只做分区,不做格式化。看不到文件,在磁盘管理器中才能看到设备,u盘拷贝不了。只能用逻辑手段拷贝:exp rman.二、oltp_数据仓库_全局数据库名_(nts适配器错误_在windows中清理oracle)

1、t----->oltp(on line transaction processing)在线事务处理。网上数据传输量比较大,数据库数据改动大,数据库负荷重,oracle 会设比较大的回退段(rollback segments)和空闲率(pctfree 10%)oracle的块为:8k.它使用了所有的所谓数据的操作 crud(创建、读取、更新、删除)。当数据存储达到一定量的时候,规模就会几乎保持不变,因为可以从存储中删除过期数据。

2、数据仓库

数据仓库改动少,主要为查询速度快服务,用于存历史数据,用来构造决策支持系统。他的回退段和空闲率留的比较少。

数据仓库就完全是一种不同种类的应用程序。它并不是用来运行当前的操作,例如发送邮件。它是用来分析数据并且从现有数据中发现新的价值,主要是用来预测未来的情况。数据仓库并不是解决所有问题的通用结构。它必须集中于某一问题领域,例如航空服务、顾客收益等。数据仓库也有有趣的一面,那就是本身是稳定增长的。数据没有被删除,也不发生变更。我们不需要将冗余数据置于数据库之外(因为加入仓库中的数据经过了数据净化的过程,该过程检查了数据的正确性)来减少复杂性同时增强读取操作的性能。

为了能够对数据仓库中的数据进行分析,数据存储于一个多维结构中,叫做星型模式。如果将星型模式扩展,就会得到雪花模式。

3、全局数据库名:以字母打头,不超过8个。

数据库名不能重名,否则复制数据和同步数据时会出麻烦,数据库安装完后,数据库名不能更改,起名时要慎重。

4、oracle字符集。zh16gbk.5、nts适配器错误。

d:oracleproduct10.2.0db_1networkadminsqlnet.ora 把sqlnet.ora文件中的(nts)改为none,再重新启动oracleconfigudration and mirdatabase config.6、在windows中清理oracle。(1)删除注册表:

regedit-> local machine--> software-->oracle(2)删除oracle服务

regedit-> local machine-->system?currentcontrolset?services?ora*(3)删除oracle事件日志

(4)删除windows安装磁盘中program filesoracle目录。(5)删除oracle菜单。(6)删除oracle环境变量。

控制面板—>系统——>高级——>环境变量。总共删除2项。(7)重新启动操作系统

(8)删除oracle磁盘文件。篇二:oracle数据库学习总结 oracle数据库学习总结 时间过的还真快,不知不觉中就在这里呆了半个月了。这段时间里都在学习oracle数据库的编程,毕竟这是家软件外包公司。像我们这样的新员工也就只能接触到些curd的操作。废话不多说,赶紧来梳理下这半月来学习的知识点.在来公司之前一直都是使用sql server数据库,用sql server也开发了3个小型项目。所以对sql语句以及在数据库中扮演重要作用的存储过程,触发器,视图,主键/外键约束都很熟。但oracle是一个全新的环境,记得刚装上oracle的时候,我都不知道在哪查看自己已经建立好的表格。还好有师傅的帮忙,要不然我还真没这么快就能入门oracle。

学习东西就要学习些能改变自己思维的东西,只有这样才能让自己的眼光比别人更独到,思维比别人更深邃,oracle就是这样的东西。当然做这样的事是要很大的驱动力的呀,如果公司不是都采用oracle来写程序的话,我估计也就懒得学啦。

对于一位程序员来说并不需要完全掌握oracle的所有知识,毕竟自己不是dba。在日常开发中也用不到那些命令和工具,但是有些知识点我们还是必须得熟练的掌握它们。比如:一些基本的ddl和dml语句,存储过程,函数,视图,触发器,序列,游标,自定义类型和包。下面我就把这段时间里学习oracle获得的知识点罗列出来,一是为了方便以后查阅,二是为了和搭档交流学习经验。要适应的一些细节

从sql server转到oracle进行数据库编程,第一道门槛就是语法问题。很多很多的问题都是因为语法而产生的,现将它们统统集合起来并将它们一网打尽之。pl结构。在sql server中,采用的是批处理执行任务的方式,所以可以将多条sql语句选中批量执行,而不用顾忌要在专门的地方声明变量,在专门的地方进行逻辑编码。在oracle中采用的是pl编程方式,必须在专门的地方声明变

循环结构,要达到循环在oracle中有3种方式,各有各的好处,你懂的。它们分别如下: pl结构中的错误处理

就像c#中的try{} catch{}语句块 能捕获错误。写几个例子: helloworld级别的错误抛出例子record类型

oracle中的record类型类似于c语言中的结构体,主要用来接收select语句或游标中返回的数据,下面写个例子:ddl语句

这里的ddl语言主要是指能完成如下工作的ddl语言:创建表,创建表的主/外 键及级联效果,dml语句

select语句。oracle中的select语句的使用方法与sql server差不多,但还是有些不同之处。

篇三:oracle培训心得 oracle培训心得

2010年x月x日至x月x日,我有幸参加了工业和信息化部软件与集成电路促进中心主办的“oracle数据库高级实战培训班”学习交流。首先感谢学校领导给予了我这次学习机会。通过短暂的几天培训,我不仅对oracle知识有了部分的了解,也接受了很多最新的信息。在这次培训中,上课的老师有非常丰富dba经验,他结合他自身的dba工作经历,从oracle体系结构与网络配置、访问控制、事务处理与日志、闪回特性、数据库的备份与恢复和数据库性能监测与调整优化等几个方面对oracle进行了讲解。对课程讲解十分的详细。通过案例示范以及演示,指导我们一步步操作。

oracle主要以操作命令行为主,在学习的过程中,对老师的每一步操作都做好了记录。课堂上按照老师的要求一步步操作,课后按记录的操作步骤和命令反复多次的练习。以此到达了对oracle反复学习,熟悉掌握老师所传授的知识。

Oracle实训总结 篇2

在这一周Oracle数据库管理与应用的实训的时间里,实训老师针对我们本学期的学习,有针对性地对我们进行了很有价值的实训工作,从最基础的字段类型,到一般的Oracle语句,如创建数据表、视图、存储过程、触发器等,给我们细心讲解,虽然Oracle数据库管理与应用的课已经学习了将近一学期,但对其简单的知识点运用的都不是很熟练,没能真正去融会贯通。

不过,经过为期一周的针对性实训,我学到了很多知识,把以前学的所有知识点都贯穿到一起,又温习了一遍,让我们能从真正意义上了解到Oracle数据库的用处。

ORACLE培训总结 篇3

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):系统改变号,一个由系统内部维护的序列号。当

系统需要更新的时候自动增加,他是系统中维持数据的一致性和顺序恢复的重

要标志。

2.介绍项目中常用的标准SQL知识点

oracle左/右/全连接

inner join--内连接和where相同;相当于join;

left join--左向外连接,返回左边表所有符合条件的right join--右向外连接,返回右边表所有符合条件的full join--完整外部连接,左向外连接和右向外连接的合集

--建立测试数据

create table a(id number);

create table b(id number);

create table c(id number);

insert into a values(1);

insert into a values(2);

insert into a values(3);

insert into b values(1);

insert into b values(2);

insert into b values(4);

insert into c values(1);

--左:

--主流数据库通用的方法

select * from a left join b on a.id=b.id;

--Oracle特有的方法--最好不要用这样,不便于sql语句的移植。

select * from a, b where a.id=b.id(+);

IDID

--------------------

2--右:

--主流数据库通用的方法

select * from a right join b on a.id=b.id;

--Oracle特有的方法

select * from a, b where a.id(+)=b.id;

IDID

--------------------

--内

--主流数据库通用的方法

select * from a join b on a.id=b.id;

--where关联

select * from a, b where a.id=b.id;

IDID

--------------------

--全外

--主流数据库通用的方法

select * from a full join b on a.id=b.id;

--Oracle特有的方法

select *

from a, b

where a.id = b.id(+)

union

select *

from a, b

where a.id(+)= b.id;

IDID

--------------------

对于多表查询,如下:

select * from a

left join b on a.id=b.id

left join c on c.id=b.id;

IDID

--------------------

相当于先进行第一个left join,得到结果集A(3条记录);结果集A再与第二个left join进行查询;

select * from a

left join b on a.id=b.id

right join c on c.id=b.id;

相当于先进行第一个left join,得到结果集A(3条记录);结果集A再与right join进行查询,即以c表为主,因为C表只有一个记录,所以最终才显示一条记录;

3.查询效率优化方式介绍

表索引介绍,表索引的建立技巧

索引优点:

第一,通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。

第二,可以大大加快数据的检索速度,这也是创建索引的最主要的原因。

第三,可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。第四,在使用分组和排序子句进行数据检索时,同样可以显着减少查询中分组和排序的时间。

第五,通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。

(哪给表中的所有列加上索引是否合理)

索引缺点:

第一,创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。

第二,索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大。

第三,当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就

降低了数据的维护速度。

(索引是建立在数据库表中的某些列的上面。因此,在创建Oracle数据库索引的时候,应该仔细考虑在哪些列上可以创建索引,在哪些列上不能创建索引。)

 建议创建索引的列: 在经常需要搜索的列上,可以加快搜索的速度; 在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构; 在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度; 在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的; 在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间; 经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。不该创建索引的列: 对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列

很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索 引,反而降低了系统的维护速度和增大了空间需求。对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很

少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,并不能明显加快检索 速度。对于那些定义为text,image和bit数据类型的列不应该增加索引。这是因为,这

些列的数据量要么相当大,要么取值很少。

 第四,当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和

检索性能是互相矛盾的。当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当修改性能远远大于检索性能时,不应该创建Oracle数据库索引。

NESTED LOOP:

对于被连接的数据子集较小的情况,嵌套循环连接是个较好的选择。在嵌套循环中,内表被外表驱动,外表返回的每一行都要在内表中检索找到与它匹配的行,因此整个查询返回的结果集不能太大(大于1 万不适合),要把返回子集较小表的作为外表(CBO 默认外表是驱动表),而且在内表的连接字段上一定要有索引。当然也可以用ORDERED 提示来改变CBO默认的驱动表,使用USE_NL(table_name1 table_name2)可是强制CBO 执行嵌套循环连接。

Nested loop一般用在连接的表中有索引,并且索引选择性较好的时候.步骤:确定一个驱动表(outer table),另一个表为inner table,驱动表中的每一行与inner表中的相应记录JOIN。类似一个嵌套的循环。适用于驱动表的记录集比较小(<10000)而且inner表需要有有效的访问方法(Index)。需要注意的是:JOIN的顺序很重要,驱动表的记录集一定要小,返回结果集的响应时间是最快的。

4.ORACLE常用内部函数

5.ORACLE数据库的特点将结合第2和第3项讲

ORACLE培训总结 篇4

我的系统版本是:ubuntu-14.04-desktop-i386.iso 虚拟机是:Oracle VM VirtualBox 这个版本我是推进使用的,系统内有自带的gcc安装版本,不然安装gcc就比较麻烦了。下面是共享文件夹设置的过程:

1、安装增强功能

运行ubuntu系统可以看到:

安装好Ubuntu 14.04后,运行Ubuntu并登录。然后在VirtualBox的菜单里选择“设备(Devices)”-> “安装增强功能包(Install Guest Additions)”。

你会发现在Ubuntu桌面上多出一个光盘图标,这张光盘默认被自动加载到了文件夹/media/cdom。14.04版本比较强大少量很多麻烦操作,他会自动安装这个增强功能包。安装结果如下图所示:

若你用的系统为其他版本,需要输入以下指令来安装:

cd /media/cdom

sudo./VboxLinuxAdditions.run 开始安装工具包。安装完毕后会提示要重启Ubuntu。

2、设置共享文件夹

或者在虚拟机下选择:

设置一个共享文件夹:linux_share

3、建立挂载 在终端下输入:

mkdir /mnt/share 新建挂载点

mount-t vboxsf linux_share /mnt/share 挂载共享文件夹

注:虚拟机的共享文件夹与XP或WIN7端的共享文件夹不要一样的名字。

但在根目录下是看不到挂载点mnt文件夹的,每操作一步自己看看,多观察一下。其中“linux_share”是之前创建的共享文件夹的名字。OK,现在Ubuntu和主机可以互传文件了。注:如果提示 /sbin/mount.vboxsf: mounting failed with the error: No such device 可能是没有载入内核模块 vboxfs,先查看下: #lsmod | grep vboxsf 如果没有结果返回,说明 vboxsf没有载入,执行 #sudo modprobe vboxsf 正常的话mount-t vboxsf winshare /mnt/share共享文件夹应该可以访问了。

4、自动挂载共享文件夹

如果想要系统每次启动自动挂载这个文件夹, 在/etc/fstab文件中添加: linux_share /mnt/share vboxsf defaults 0 0

打开fstab文件后在文档中加入:linux_share /mnt/share vboxsf defaults 0 0,如图片上的最后一句。

保存,就可以实现自动挂载共享文件夹了。

5、共享文件夹验证

在XP或WIN7中复制如如下文件:

在终端中输入以下指令来查看:

我们在终端的share文件夹中看到了拷贝入linux_share文件夹中的文件,说明共享文件夹设置成功了。

怎样学习oracle 篇5

学习Oracle是一个漫长艰辛的过程。如果没有兴趣,只是被迫学习,那么是很难学好的。学习到一定程度的时候,要想进一步提高,就不得不接触很多Oracle之外的东西,如Unix,如网络、存储等。因此,要真的决心学好Oracle,就一定要有兴趣。有了兴趣,就会一切变得简单快乐起来。简单总结一下,那就是:兴趣、学习、实践。

我个人认为还是应该从SQL语句学起。比较好的教材是Oracle OCP认证的《SQL and PL/SQL》(1Z0-045)。学习SQL的时候,尽可能坚持使用Oracle自带的工具:SQLPLUS。有了一定的SQL基础后,就要尽可能的了解Oracle的体系结构,这就涉及到了Oracle管理的内容了。我学习的时候,机械工业出版社的《Oracle9i DBA手册》这本书对我的帮助挺大。或许现在都出11g版本的了吧。Oracle公司的《Oracle Concepts》是非常棒的书,对了解Oracle体系结构很有好处。每个Oracle版本都有对应的版本,可以认真多读几次,每次都会有新的收获。

学习Oracle备份与恢复技术也是必然的事情。大数据量情况下,Oracle 建议用RMAN来进行数据的备份与恢复。目前市场上有很多数据库备份恢复软件,其实好多也是后台调用RMAN。清华大学出版社出版的《Oracle 9i RMAN 备份与恢复技术》是一本非常不错的介绍RMAN的书。有了以上的基础,可以说已经入门了,对遇到的一些初级Oracle问题将不再束手无策。然而我们的学习之路仍然还很漫长。我们的用户可能经常抱怨数据库运行缓慢。这时,如果有一定的优化知识,那就好办了。有时你会看到优化前需要运行几个小时的作业,优化后也许几秒钟就能完成!Oracle9i的性能诊断工具包statspack、Oracle10g/11g的自动工作符合存储库AWR都是调优的好帮手。机械工业出版社出版的《Oracle9i STATSPACK高性能调整》是学习statspack不错的书

Oracle面试题库 篇6

A.UPDATE

B.EDIT

C.SELECT

D.ALTER TABLE

2.用SQLPLUS的_____命令可以查看表的结构信息,包括列的名称和数据类型

A DESCRIPTION

B DESC

C SHOW TABLE

D SHOW USER

3. Oracle的前端工具是 :

A SQL*PLUS

B C++

C PL/SQL

D JAVA

4. 在SQLPLUS中,如何运行SQL脚本程序

A /

B @脚本

C EXE 脚本

D 不能在SQLPLUS中直接运行脚本

5. 用命令将SQLPLUS缓冲区中的内容保存到文件中,使用下列哪种方法

A 将缓冲区的内容Ctrl+C,然后再Ctrl+V到文件中即可

B 使用SAVE命令参数是文件路径

C WRITE 方式,参数是文件路径

D Oracle会自动保存

6. 用来设置一行能够显示的字符长度的命令是

A SET LINESIZE

B SET LINE

C SET LINEBUFFER

D SET SIZELINE

7. 以下哪个命令用来设置查询显示结果的列宽

A SET COLUMN SIZE

B COLUMN 列 FORMAT 长度

C COLUMN 列 长度

D 长度 OF COLUMN

8. 如何判断数据库的时区?

解答:SELECT DBTIMEZONE FROM DUAL;

22. 解释GLOBAL_NAMES设为TRUE的用途

解答:GLOBAL_NAMES指明联接数据库的方式。如果这个参数设置为TRUE,在建立数据库链接时就必须用相同的名字连结远程数据库

9. 如何加密PL/SQL程序?

解答:WRAP

10. 解释FUNCTION,PROCEDURE和PACKAGE区别

解答:function 和procedure是PL/SQL代码的集合,通常为了完成一个任务。procedure 不需要返回任何值而function将返回一个值在另一方面,Package是为了完成一个商业功能的一组function和proceudre的集合

11. 解释TABLE Function的用途

解答:TABLE Function是通过PL/SQL逻辑返回一组纪录,用于普通的表/视图。他们也用于pipeline和ETL过程。

12. 举出3种可以收集three advisory statistics

解答:Buffer Cache Advice, Segment Level Statistics, Timed Statistics

13. Audit trace 存放在哪个oracle目录结构中?

解答:unix $ORACLE_HOME/rdbms/audit Windows the event viewer

14. 解释materialized views的作用

解答:Materialized views 用于减少那些汇总,集合和分组的信息的集合数量。它们通常适合于数据仓库和DSS系统。

15. 当用户进程出错,哪个后台进程负责清理它

解答: PMON

16. 哪个后台进程刷新materialized views?

解答:The Job Queue Processes.

17. 如何判断哪个session正在连结以及它们等待的资源?

解答:V$SESSION / V$SESSION_WAIT

18. 描述什么是 redo logs

解答:Redo Logs 是用于存放数据库数据改动状况的物理和逻辑结构。可以用来修复数据库.

19. 如何进行强制LOG SWITCH?

解答:ALTER SYSTEM SWITCH LOGFILE;

20. 举出两个判断DDL改动的方法?

Oracle笔试经验 篇7

一个半小时的PAC考试,分10个section,从头到尾都是单选,总体上看时间比较紧,主要内容包括编程原理(程序流程)、数理运算能力、数字敏感度、信息技术常识和英文。

虽说有点不利于非技术类考生,但实际上它的编程原理并不是针对某种特定程序语言的,其实就是考逻辑,不需要任何编程知识,

信息技术常识就是计算机三级信息技术的内容,只有一点点题,随便猜猜吧。毕竟人家招的是Graduate Trainee,包括技术类和非技术类,偶是学会计的,觉得还可以做。

英语分三部分,第一部分考词法超简单,最后一部分考阅读,中间一部分考反义词的`偶做得最快,因为纯粹考单词量,那些单词偶基本都不认识所以涂得最快。

写这个笔经是因为下周末还有一场笔试,一样的形式。没申请的同学这周抓紧了。

oracle实训报告 篇8

专业计算机应用技术

学号30802001533姓名赵彬彬

实训内容:oracle9i在红旗4.1平台上的安装

一.Oracle 9.2.0.4安装步骤

安装目录/oracle/binbin/product/9.2.0

1.安装环境检查

首先检查软硬件环境是否满足要求。要求:物理内存512M、安装所需磁盘空间约4G、临时存储空间如/tmp约1.5G、32位操作系统。

2.安装前准备

(1)从FTP下载安装文件和所需的操作系统补丁文件。

3个安装文件:disk1.cpio、disk2.cpio、disk3.cpio

1个操作系统补丁文件:p3006854_9204_LINUX.zip

(2)创建目录#mkdir –p /oracle/binbin/product/9.2.0

(3)配置虚拟机的网卡为桥接模式,配置id地址为192.168.1.54。利用ping命令,测试主机是否与linux通信。利用xftp工具,将上面四个文件传入oracle目录下。

(4)用putty登陆linux。创建安装Oracle数据库所要求的Linux用户和组:用户名oracle/oracle、组dba

#groupadd dba

#useradd –g dba oracle

#passwd oracle

输入oracle

再次确认密码

(5)oracle用户需要对/oracle目录有全部权限,修改/oracle目录的所有者为oracle用户所有。

#chown–Roracle:dba/oracle

(6)以oracle用户登录系统,修改oracle用户主目录下的.bash_profile文件,增加以下内容:

#vi /home/oracle/.bash_profile

export ORACLE_BASE=/oracle/binbin

export ORACLE_HOME=/oracle/binbin/product/9.2.0

export ORACLE_SID=binbin

export NLS_LANG=“SIMPLIFIED CHINESE_CHINA.ZHS16GBK”

export PATH=$ORACLE_HOME/bin:$PATH

export ORACLE_DOC=$ORACLE_HOME/doc

CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib

CLASSPATH=$CLASSPATH:$ORACLE_HOME/network/jlib

CLASSPATH=$CLASSPATH:$ORACLE_HOME/jdbc/lib/classes1

2.zip

CLASSPATH=$CLASSPATH:$ORACLE_HOME/jdbc/lib/nls_charset12.zip

CLASSPATH=$CLASSPATH:$ORACLE_HOME/sqlj/lib/translator.zip

CLASSPATH=$CLASSPATH:$ORACLE_HOME/sqlj/lib/runtime.zip

CLASSPATH=$CLASSPATH:$ORACLE_HOME/jdbc/lib/*.jar

CLASSPATH=$CLASSPATH:$JAVA_HOME/lib/*.jar

CLASSPATH=$CLASSPATH:$JAVA_HOME/jre/lib/*.jar

CLASSPATH=$CLASSPATH:.export CLASSPATH

if [!$LD_LIBRARY_PATH ];then

LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/ctx/lib:$ORACLE_HOME/jdbc/lib

export LD_LIBRARY_PATH

fi

ulimit-n 65535 >/dev/null 2>&1

(7)以root登录系统为操作系统打补丁。即先将补丁文件解压,再运行shell来安装。

#unzip p3006854_9204_LINUX.zip

#sh rhel3_pre_install.sh

(8)将3个cpio安装文件解压缩。

#cpio –idmv < disk1.cpio

#cpio –idmv < disk2.cpio

#cpio –idmv < disk3.cpio

3.开始安装

注意:oracle目录的拥有者必须为oracle。安装过程中,根据提示运行相应的文件。

(1)以oracle用户登录,启动图形界面(安装需要在图形界面下进行)。

(2)启动终端窗口,进行如下两项环境设置,然后运行安装程序runInstaller进入安装界面。

$export DISPLAY=:0.0

$export LANG=C

$./runInstaller

4.测试安装

#sqlplus /nolog

SQL>conn /as sysdba

SQL>show SGA

Total System Global Area219223120 bytes

Fixed Size451664 bytes

Variable Size201326592 bytes

Database Buffers16777216 bytes

Redo Buffers667648 bytes

SQL> select file_name from dba_data_files;

FILE_NAME

--------------------------

/oracle/binbin/oradata/binbin/system01.dbf

/oracle/binbin/oradata/binbin/undotbs01.dbf

/oracle/binbin/oradata/binbin/cwmlite01.dbf

/oracle/binbin/oradata/binbin/drsys01.dbf

/oracle/binbin/oradata/binbin/example01.dbf

/oracle/binbin/oradata/binbin/indx01.dbf

/oracle/binbin/oradata/binbin/odm01.dbf

/oracle/binbin/oradata/binbin/tools01.dbf

/oracle/binbin/oradata/binbin/users01.dbf

/oracle/binbin/oradata/binbin/xdb01.dbf

SQL> select name from v$controlfile;

NAME

-----------------

/oracle/binbin/oradata/binbin/control01.ctl

/oracle/binbin/oradata/binbin/control02.ctl

/oracle/binbin/oradata/binbin/control03.ctl

二.遇到的问题:

1.磁盘空间不足

解决的方法:关闭虚拟机,选择编辑虚拟机,添加一块磁盘,大小为8G。然后打开虚拟机。用root用户登录,输入fdisk –l,查看系统是否识别硬盘。再输入fdisk /dev/sdb,对SCSI第二块硬盘进行分区。分区后,用mkfs –t ext3 /dev/sdb1进行格式化。最后把/dev/sdb1挂载到/oracle目录下。

2.无法连接到图形界面

解决的方法:把root用户注销,此时就oracle登录系统,并且以oracle用户进入的图形界面。

3.权限不足

解决方法:把三个文件拥有者的权限授予oracle,并查看/oracle目录拥有者是否为oracle。

4.oracle用户无法启动图形界面

解决方法:删除tmp目录下的临时文件。

5.临时文件产生的错误

解决方法:删除先前的临时文件。

三.收获

体会:通过这次安装oracle的实践,充分运用以前所学的linux基础,更好的运用这些知识。体会到光看课本是不行的,必须付出实践,在实践中学习,在实践中增长知识才是最快的。实践能力是最重要的。

ORACLE学习心得体会 篇9

下面是摘抄的部分 :[local]2[/local] oracle相关语法及命令

一、oracle入门

理论知识:

oracle的物理组件有三个:(1)数据文件 数据文件是用于存储数据库数据的文件,如表、索引数据。每个oracle数据库有一个或多个物理数据文件,一个数据文件只能与一个数据库关联。(2)日志文件 用于记录对数据库进行的修改信息,日志文件主要用于在数据库出现故障时实施数据库恢复。(3)控制文件 控制文件是记录数据库物理结构的二进制文件,每个oracle数据库都含有一个控制文件。

oracle的逻辑组件:

表空间(tablespace)表空间是数据库最大的逻辑单位,一个数据库至少包含一个表空间,一个表空间包含一个或多个段等等。

段(segment)段存在于表空间中,分成4类,数据段、索引段、回退段、临时段。区(extent)区是磁盘空间分配最小单位,由连续的数据块组成,一个或多个区构成段,区只能存在于一个数据文件中。

数据块(data block)数据块是数据库中最小的数据组织单位与管理单位,oracle数据库中的数据存储于数据块中,取值范围2k-64k之间。

模式(schema)模式是对用户所创建的数据库对象的总称,又称为用户模式。

概念:

内存 oracle内存结构包含以下两个内存区。

1、系统全局区(sga)实例启动时分配该内存区,是oracle实例的一个基本组件。又称为共享全局区,它用来存储数据库信息,并由多个数据库进程共享。可分为共享池、数据缓冲区及日志缓冲区。(1)共享池 是对sql、plsql程序进行语法分析、编译、执行的内存区域。共享池由库缓存和数据字典缓存组成。其中,库缓存含有最近执行的sql、plsql语句的分析码和执行计划;数据字典缓存含有从数据字典中得到的表、索引、列定义和权限等信息。(2)数据缓冲区 数据缓冲区用于存储从磁盘数据文件中读入的数据,所有用户共享。(3)日志缓冲区 日志记录数据库的所有修改信息,主要用于恢复数据。

2、程序全局区(pga)服务器进程启动时分配该内存区。pga为非共享区,只能单个进程使用,当一个用户会话结束后,pga释放。

用户进程(pga)发送sql语句到共享全局区(sga),先在共享池的库缓存中查询是否存在所需的数据块,如果存在就在数据字典中读取相应的数据块,如果不存在就由服务器进程(dbwr)来io数据库

语法知识:

创建表空间的语法如下:

create tablespace tablespacename datafile d:filename.dbf [size int [kb|mb]] [autoextend [off|on]];tablespacename 是需创建的表空间名称。datafile 指定组成表空间的一个或多个数据文件,当有多个数据文件时使用逗号分隔。

filename 是表空间中数据文件的路径和名称。size 指定文件的大小,用k指定千字节大小,用m指定兆字节大小。autoextend子句用来启用或禁用数据文件的自动扩展。oracle默认用户:

用户名:sys 默认密码:chage_on_install 用来管理拥有oracle数据字典文件 用户名:system 默认密码:manager 用来管理拥有数据字典视图对象 用户名:scott 默认密码:tiger 示例用户,包括emp、dept等表

连接oracle: 在控制台下输入 sqlplus 用户名/密码 回车或 sqlplusw 回车

相关命令:

disconn //退出当前登录 conn 用户名/密码 //连接oracle alter user 用户名 identified by 密码 //修改用户口令 drop user 用户名 cascade;//删除用户 alter user 用户名 account lock;//给某个用户加锁 alter user 用户名 account unlock;//给某个用户解锁 ed 回车: //打开缓冲区

/ 回车: //执行缓冲区中的语句 create user 用户名 identified by 密码 [password expire] [default tablespace 表空间名] [temporary tablespace 临时表空间名];//创建用户

相关权限: grant connect to scott;//connect角色将允许用户创建数据库并在数据库中创建表或其他对象 grant resource to scott;//resource角色将允许用户使用数据库中的空间 grant create sequence to scott;//create sequence权限将允许用户创建序列,此权限包含在connect连接角色中 grant select on emp to scott;//将emp表的查询权限授予用户scott grant update(vencode,venname)on 表名 to scott;//将特定列的更新权限授予用户scott grant 权限 on 表名 to 用户名 with grant option;//接受该权限的用户可以将此权限授予其他用户 revoke select,update on 表名 from 用户名;//收回相应的权限

二、sql查询和sql函数 sql支持如下类别的命令:

数据控制语言: grant(授予)和revoke(回收)命令。

数据类型: char: 长度在1到2000个字节,声明多少字节在内存中就占用多少字节,输入的值小于指定的长度时用空格填充。varchar2: 长度在1到4000个字节,输入的值是多少字节,就占用多少字节。long: 长度在2gb,设置为此类型的列时,要注意:一个表中只有一列可以为long类型,long类型列不能定义为唯一约束或主键约束,不能建立索引,过程或存储过程不能接受long类型的参数。number(p,s): 其中p为精度,表示数字的总位数,在1至38之间。s为范围,表示小数点右边数字的位数,在-84至127之间。date: 日期类型,sysdate为当前系统时间。格式为08-9月-07。timestamp: 用于存储日期的年、月、日以及时间的时、分和秒。其中秒精确到小数点后6位,systimestamp返回当前日期、时间。格式为08-9月-07 04.08.30.000000 下午。raw: 此数据类型用于存储基于字节的数据,如二进制数据或字节串,该类型最多能存储2000个字节,可以建立索引。long raw: 此数据类型用于可变长度的二进制数据,最多能存储2gb。long数据类型的所有限制对long raw数据类型也同样有效。lob又称为大对象数据类型,最多能存储4gb的非结构化信息。包括: clob: clob代表character lob(字符lob),它能存储大量字符数据。如xml文档。blob: blob代表binary lob(二进制lob),它能存储较大的二进制对象,如图形、视频剪辑和声音剪辑。bfile: bfile代表binary file(二进制文件),它能够将二进制文件存储在数据库外部的操作系统文件中。

伪列:

rowid: select rowid,ename, from scott.emp where empno=7900;rownum: select * from scott.emp where rownum<11;//限制查询返回的行数

语法知识:

desc 表名;//查看表结构

alter table 表名 modify(列名 varchar2(25));//修改列 alter table 表名 add(列名 varchar2(12),列名 number(12));//添加列 alter table 表名 drop column 列名;//删除列 truncate table 表名;//中删除记录而不删除结构,不使用事务处理,因此无法回滚

drop table 表名;//删除表及其全部数据 create table 新表名 as select * from 表名 where 1=2;//用现有的表创建一个新表 select deptno*2 new no,dname,loc from dept;//指定一个含有特殊字符(如空格)的列标题

savepoint 标记名;//标记事务点 rollback;//回滚整个事务处理 rollback to [savepoint] 标记名;//回滚到事务中某个特定的保存点

集合操作符: union(联合): 此操作符返回两个查询选定的所有不重复的行。

语法 select orderno from order_master union select orderno from order_detail;union all(联合所有): 此操作符合并两个查询选定的所有行,包括重复的行。

语法:select orderno,ename from order_master union all select orderno,proname from order_detail order by 2;注意:在两个select语句中指定的列名不必相同,但数据类型必须匹配。也可以对联合查询的结果进行排序,使用order by子句时,它必须放在最后

一个select语句之后,而且必须指定列索引来排序,而不是指定列名,列索引是从1开始的整数。上述语法便是以proname的索引排序 intersect(交集): 此操作符只返回两个查询都有的行。

语法:select orderno from order_master intersect select orderno from order_detail;minus(减集): 此操作符中返回由第一个查询选定但是第二个查询中没有选定的行,也就是在第一个查询结果中排除第二个查询结果中出现的行。

语法:select orderno from order_master minus select orderno from order_detail;查询尚未交付的订单

连接(||)操作符:

语法: select(供应商||venname||的地址是||venadd1|| ||venadd2|| ||venadd3)地址 from vendor_master where vencode=v002;将多个字符串合并为一个字符串。sql函数:

1、日期函数: add_months: 此函数返回给指定的日期加上指定的月数后的日期值。语法为add_months(d,n),其中d是日期,n表示月数。

示例:select add_months(sysdate,2)from dual;将当前时间加上2个月后的日期值。

months_between:

此函数返回两个日期之间的月数。语法为months_between(d1,d2),其中d1和d2是日期,如果d1大于d2,则结果为正数;否则为负数。last_day: 此函数返回指定日期当月的最后一天的日期值,语法为last_day(d),其中d表示日期。

示例:select last_day(sysdate)from dual;返回当前日期的月的最后一天,如果是9月就返回30-09月-07 round: 此函数返回日期值,将日期四舍五入为格式模型指定的单位。语法为round(d,[fmt])。其中d是日期,fmt是格式模型。fmt是一个可选项,日期默认舍入为最靠近的那一天。如果指定格式为年year,则舍入到年的开始,即1月1日;如果格式为月month,则舍入到月的第一日;如果格式为周day,则舍入到最靠近的星期日。

示例:select round(sysdate,month)from dual;返回最接近的一个月。next_day: 此函数返回指定的下一个星期几的日期。语法为next_day(d,day)。其中d表示日期,而day指周内任何一天。

示例:select next_day(sysdate,星期日)from dual;返回下一个星期日的日期,也可以用1表示,以此类推,星期一以2表示。trunc: 此函数将指定日期截断为由格式模型指定的单位日期,与round函数不同的是它只舍不入,语法为trunc(d,[fmt]),与round格式相同。

示例:select trunc(sysdate,year)from dual;返回当前年的第一天,也就是1月1日。示例:select trunc(sysdate,day)from dual;返回紧靠前面的星期日。如果为2005年1月27日就会返回2005年1月23日。extract: 此函数提取日期时间类型中的特定部分。语法为extract(fmt from d),其中d是日期时间表达式,fmt是要提取的部分的格式。格式的取值可以是year,month,day,hour,minute,second,注意此处的格式不使用单引号。

示例:select extract(year from sysdate)from dual;返回当前的年份。

2、字符函数: initcap(char): 首字母大写,示例:select initcap(hello)from dual;输出结果:hello。lower(char): 转换为小写,示例:select lower(fun)from dual;输出结果:fun。upper(char): 转换为大写,示例:select upper(sun)from dual;输出结果:sun。ltrim(char,set): 左剪裁,示例:select ltrim(xyzadams,xyz)from dual;输出结果:adams。rtrim(char,set): 右剪裁,示例:select rtrim(xyzadams,ams)from dual;输出结果:xyzad。

translate(char,from,to): 按字符翻译,示例:select translate(jack,abcd,1234)from dual;输出结果:j13k。replace(char,search_str,replace_str): 字符串替换,示例:select replace(jack and jue,j,bl)from dual;输出结果:black and blue。instr(char,substr[,pos1,pos2]): 查找子字串位置。

示例:select instr(vorldwide,d)from dual;输出结果:5。pos1为可选,表示从第几个位置查找。pos2为可选,表示从第几次出现的位置找。substr(char,pos,len): 取子字符串,示例:select substr(abcdefg,3,2)from dual;输出结果:cd。concat(char1,char2): 连接字符串,示例:select concat(hello,world)from dual;输出结果:helloworld。chr: 此函数根据ascii码返回对应的字符,示例:select chr(45788),chr(53671),chr(50167),chr(65)from dual;输出结果:曹 学 明 a。ascii:

此函数返回gbk编码值,示例:select ascii(曹)cao ,ascii(学)xue,ascii(明)ming from dual;输出结果:45788 53671 50167。lpad和rpad:

示例:select lpad(function,15,=)from dual;输出结果:=======function。而rpad则相反,字符串填充在右边。trim: 此函数从字符串的开头或结尾(或开头和结尾)剪裁特定的字符,默认剪裁空格。如果加上leading选项时与ltrim函数相似。指定trailing时和 rtrim函数相似。示例: select trim(9 from 999992598899)from dual;输出结果:25988。

示例: select trim(leading 9 from 999992598899)from dual;输出结果:2598899。示例: select trim(trailing 9 from 999992598899)from dual;输出结果:9999925988。length: 此函数返回字符串的长度,示例:select length(frances)from dual;输出结果:7。decode: 示例:select deptno,dname,decode(loc,new york,纽约,boston,波士顿)from scott.dept;篇二:oracle数据库学习心得 oracle数据库结课论文

一个好的程序,必然联系着一个庞大的数据库网路...今年我们学习了 oracle数据库这门课程,起初的我,对这个字眼是要多陌生有多陌生,后来上课的时候听一会老师讲课,偶尔再跟上上机课,渐渐的学会了不少东西,但我感觉,我学到的仍是一些皮毛而已,怀着疑惑和求知的心态,我在网上搜索了关于 oracle数据库的一些知识。

1.oracle的特点: 可移植性 oracle采用c语言开发而成,故产品与硬件和操作系统具有很强的独立性。从大型机到微机上都可运行oracle的产品。可在unix、dos、windows等操作系统上运行。可兼容性 由于采用了国际标准的数据查询语言sql,与ibm的sql/ds、db2等均兼容。并提供读取其它数据库文件的间接方法。

可联结性 对于不同通信协议,不同机型及不同操作系统组成的网络也可以运行oraˉcle数据库产品。

2.oracle的总体结构

(1)oracle的文件结构 一个oracle数据库系统包括以下5类文件:oracle rdbms的代码文件。

数据文件 一个数据库可有一个或多个数据文件,每个数据文件可以存有一个或多个表、视图、索引等信息。

日志文件 须有两个或两个以上,用来记录所有数据库的变化,用于数据库的恢复。控制文件 可以有备份,采用多个备份控制文件是为了防止控制文件的损坏。参数文件 含有数据库例程起时所需的配置参数。

(2)oracle的内存结构 一个oracle例程拥有一个系统全程区(sga)和一组程序全程区(pga)。

sga(system global area)包括数据库缓冲区、日志缓冲区及共享区域。pga(program global area)是每一个server进程有一个。一个server进程起动时,就为其分配一个pga区,以存放数据及控制信息。

(3)oracle的进程结构oracle包括三类进程: ①用户进程 用来执行用户应用程序的。

②服务进程 处理与之相连的一组用户进程的请求。

③后台进程 oracle为每一个数据库例程创建一组后台进程,它为所有的用户进程服务,其中包括: dbwr(database writer)进程,负责把已修改的数据块从数据库缓冲区写到数据库中。lgwr(log writer)进程,负责把日志从sga中的缓冲区中写到日志文件中。smon(system moniter)进程,该进程有规律地扫描sag进程信息,注销失败的数据库例程,回收不再使用的内存空间。pmon(process moniter)进程,当一用户进程异常结束时,该进程负责恢复未完成的事务,注销失败的用户进程,释放用户进程占用的资源。arch(archiver)进程。每当联机日志文件写满时,该进程将其拷贝到归档存储设备上。另外还包括分布式db中事务恢复进程reco和对服务进程与用户进程进行匹配的dnnn进程等。3.oracle的逻辑结构

构成oracle的数据库的逻辑结构包括:(1)表空间

(2)5种类型的段(segment)

①数据段;②索引段;③回滚(rollbock)段;④临时段;⑤自举(bootstrap)段。段的分配单位叫范围(extent)

表空间(tablespace)一个数据库划分成的若干逻辑部分称为表空间。一个数据库可以有一个或多个表空间,初始的表空间命名为system,每一个逻辑表空间对应于一个或多个物理文件。dba使用表空间做以下工作: 控制数据库对象,如表、索引和临时段的空间分配。为数据库用户设置空间配额。

利用个别表空间的在线或离线,控制数据的可用性。后备或恢复数据。

通过分配空间,以改进性能。

在每个数据库中都存在system表空间,它在建立数据库时自动建立。在该表空间中,包含数据库的数据字典,其中存储全部数据库对象的名字和位置。system表空间总是在线的,像其它表空间一样,可以通过增加新的数据库文件来扩大。一个表空间可包含许多表和索引。但一个表和索引不能跨越表空间,可跨越组成表空间的文件。在db的打开的情况下,dba利用alter tablespace语句,可以实施表空间的在线或离线。system表空间必须在线。表空间离线有下列原因: 一般为了使部分数据库不能使用,而允许正常存取数据库其余部分。执行表空间离线备份。

一个离线的表空间,不能被应用用户读或编辑。

可以增加数据文件扩大已有的表空间,也可增加新的表空间使数据库容量增大,或分配空间给某个应用。使用alfer tablespace add file语句将另一个数据文件加入到已存在表空间中。使用create tablespace语句可建立一个新的表空间。段(segment)表空间中的全部数据存储在以段划分的数据库空间中。一个段是分配给数据库用于数据存储的范围的集合。数据可以是表、索引或rdbms所需要的临时数据。段是表空间的下一个逻辑存储的级别。一个段不能跨越一个表空间,但可跨越表空间内的文件。一个数据库最多需要五种段类型: 数据段 一个包含一个表(或聚集)的全部数据,一个表(或聚集)总有一个单个数据段。

索引段 一个索引段包含对一个表(或聚集)建立的一个索引的全部索引数据。一个表可以有一个、多个或者没有索引段,取决于它所拥有的索引个数。一个聚集必须至少有一个索引段,即在聚集码上 建立聚集索引。

回滚段 每个db有一个或多个回滚段。一个回滚段是db的一部分,它记录在某一情况下被撤消的动作。回滚段用于事务控制和恢复。

临时段 在处理查询时,oracle需要临时工作空间,用于存储语句处理的中间结果,这个区称为临时段。

自举段 自举段在system表空间中,在数据库建立时建立。它包括数据字典定义,在数据库打开时装入。4.用户数据库对象

由用户建立的对象驻留在表空间中,含有真正的数据。数据库对象有表、视图、聚集、索引、伪列和序号生成器。

(1)聚集(cluster)聚集是存储数据的一种可选择的方法。聚集包括存储在一起的一组表,它们共享公共列并经常一起使用。由于内容相关并且物理地存储在一起,存取时间得到改进,存储空间可以减少。聚集是一种优化措施。

聚集对性能的改进,依赖于数据的分布和sql操作的内容。特别是使用聚集对连接非常有利。可以明显地提高连接的速度。建立聚集命令的基本格式: sql>create cluster〈聚集名〉(列定义[,„]);利用聚集建立表命令基本格式: sql>create table〈新表名〉(列定义[,„]cluster〈聚集名〉(聚集列);篇三:oracle学习心得

oracle rac 学习心得 1.概念 rac,全称real application clusters,译为“实时应用集群”,是oracle新版数据库中采用的一项新技术,是高可用性的一种,也是oracle数据库支持网格计算环境的核心技术。

在oracle9i之前,rac的名称是ops(oracle parallel server)。rac 与 ops 之间的一个较大区别是,rac采用了cache fusion(高速缓存合并)技术。在 ops 中,节点间的数据请求需要先将数据写入磁盘,然后发出请求的节点才可以读取该数据。使用cache fusion时,rac的各个节点的数据缓冲区通过高速、低延迟的内部网络进行数据块的传输。2.优缺点

优点:

oracle rac主要支持oracle9i、10g、11g版本,可以支持24 x 7 有效的数据库应用系统,在低成本服务器上构建高可用性数据库系统,并且自由部署应用,无需修改代码。在oracle rac环境下,oracle集成提供了集群软件和存储管理软件,为用户降低了应用成本。当应用规模需要扩充时,用户可以按需扩展系统,以保证系统的性能。(1)多节点负载均衡;(2)提供高可用:故障容错和无缝切换功能,将硬件和软件错误造成的影响最小化;(3)通过并行执行技术提高事务响应时间----通常用于数据分析系

统;(4)通过横向扩展提高每秒交易数和连接数----通常对于联机事务系

统;(5)节约硬件成本,可以用多个廉价pc服务器代替昂贵的小型机或大

型机,同时节约相应维护成本;(6)可扩展性好,可以方便添加删除节点,扩展硬件资源。缺点:(1)相对单机,管理更复杂,要求更高;(2)在系统规划设计较差时性能甚至不如单节点;(3)可能会增加软件成本(如果使用高配置的pc服务器,oracle一般 按照cpu个数收费)。3.rac 特点

每一个节点的linstance都有自己的sga 每一个节点的linstance都有自己的background process 每一个节点的linstance都有自己的redo logs 每一个节点的linstance都有自己的undo表空间

所有节点都共享一份datafiles和controlfiles 4.rac 组件

5.undo和redo读书笔记

1)redo是什么?oracle的redo是如何工作的 redo是重做日志文件,是oracle数据库的日志文件.oracle的重做日志有两种:在线重做日志以及归档重做日志。

在线重做日志:主要用于由于数据库主机掉电等原因导致实例失败,此时oracle采用在线重做日志在数据库启动时将数据库恢复到断电之前的时间点上。

归档重做日志:主要用于介质失败,比如:磁盘受损。此时需要使用对磁盘上的数据备份的归挡重做日志文件将该磁盘上的数据恢复到该归档文件数据所在的时间点上,然后再使用在线重做日志文件将适合的时间点上。

归档重做日志文件实质是被添满的旧的在线重做日志的副本。归档重做日志文件是数据库的历史数据。

在线重做日志在每个数据库中至少有两个重做日志组,每个日志组中至少有一个重做日志文件,这些在线重做日志组是循环使用的,当日志组1被写到最后时,然后自动切换到日志组2;当日志组2也被写满时,再切换到日志组1。2)undo是什么?oracle的undo是如何工作的 undo与redo相反,redo是恢复数据,用于在事务失败时重放事务,undo是撤消一条语句或者一组语句的作用。undo是存储在数据库内部的段或者表空间中(undo如果是手动管理,则使用undo段来管理;如果undo使用aum管理undo,则undo使用表空间来自动管理)。注意:在undo并不是物理的恢复到执行语句之前或者事务之前的样子,只是逻辑的恢复到原来的样子,所有修改只是逻辑的取消,但是数据结构和数据块在回滚之后也大不相同。原因是在多用户系统中,有很多事务是并发进行的,当一个事务修改一个数据并且被回滚,但是该数据在该用户对该数据做过修改之后也有被其他用户修改,这个时候如果是对该事务修改的数据块回滚到原来数据的物理样子,就有可能将后来的事务所做的修改给覆盖掉。所以回滚不是

一个简单的物理的恢复,而是逻辑恢复。3)undo和redo是如何协作工作的 4)6.篇四:oracle数据库学习总结 oracle数据库学习总结

时间过的还真快,不知不觉中就在这里呆了半个月了。这段时间里都在学习oracle数据库的编程,毕竟这是家软件外包公司。像我们这样的新员工也就只能接触到些curd的操作。废话不多说,赶紧来梳理下这半月来学习的知识点.在来公司之前一直都是使用sql server数据库,用sql server也开发了3个小型项目。所以对sql语句以及在数据库中扮演重要作用的存储过程,触发器,视图,主键/外键约束都很熟。但oracle是一个全新的环境,记得刚装上oracle的时候,我都不知道在哪查看自己已经建立好的表格。还好有师傅的帮忙,要不然我还真没这么快就能入门oracle。学习东西就要学习些能改变自己思维的东西,只有这样才能让自己的眼光比别人更独到,思维比别人更深邃,oracle就是这样的东西。当然做这样的事是要很大的驱动力的呀,如果公司不是都采用oracle来写程序的话,我估计也就懒得学啦。对于一位程序员来说并不需要完全掌握oracle的所有知识,毕竟自己不是dba。在日常开发中也用不到那些命令和工具,但是有些知识点我们还是必须得熟练的掌握它们。比如:一些基本的ddl和dml语句,存储过程,函数,视图,触发器,序列,游标,自定义类型和包。

下面我就把这段时间里学习oracle获得的知识点罗列出来,一是为了方便以后查阅,二是为了和搭档交流学习经验。

要适应的一些细节 从sql server转到oracle进行数据库编程,第一道门槛就是语法问题。很多很多的问题都是因为语法而产生的,现将它们统统集合起来并将它们一网打尽之。pl结构。在sql server中,采用的是批处理执行任务的方式,所以可以将多条sql语句选中批量执行,而不用顾忌要在专门的地方声明变量,在专门的地方进行逻辑编码。在oracle中采用的是pl编程方式,必须在专门的地方声明变

循环结构,要达到循环在oracle中有3种方式,各有各的好处,你懂的。它们分别如下: pl结构中的错误处理

就像c#中的try{} catch{}语句块 能捕获错误。写几个例子: helloworld级别的错误抛出例子 record类型

oracle中的record类型类似于c语言中的结构体,主要用来接收select 语句或游标中返回的数据,下面写个例子: ddl语句

这里的ddl语言主要是指能完成如下工作的ddl语言:创建表,创建表的主/外 键及级联效果,dml语句

select语句。oracle中的select语句的使用方法与 sql server差不多,但还是有些不同之处。篇五:oracle学习体会 oracle学习体会

王岩

2015年,为落实重点开展“完善业务系统,加强统计数据汇总分析”的工作要求,根据协会安排,我由政策信息部调整到统计部,在稳步推进业务系统数据库工作的基础上,努力配合做好网络及其他软硬件管理等工作。对于曾经负责信息宣传工作的我来说,计算机技术还是一个全新的领域。

根据协会安排,我从今年的4月到11月利用周末时间学习专业知识,旨在通过参加学习中心的linux系统和oracle数据库等培训课程,承担协会业务系统数据库的开发和管理工作。在参加专业培训机构课程的同时,臧立副主任也会不定期针对协会的业务系统数据库为我们做一些内训。通过这一年来的学习、回顾和梳理,让我对oracle数据库知识以及协会的业务系统数据库框架有了一定的了解,也对协会的数据库管理工作方面有了一些建议。

一份总结和体会 oracle数据库分两个方面,一块是开发,一块是管理。开发主要是写存储过程、触发器之类的编程工作,类似于程序员,需要有较强的逻辑思维能力和创造能力。数据库管理则是需要对oracle数据库的原理有深刻的认识,有全局操纵的能力和紧密的思维,而协会的业务系统数据库工作则是同时包含了开发和管理的内容。

在有一定的oracle专业知识之后,我开始接手了辽宁省协会和 广东省协会的业务数据分入处理工作。其中,根据每期不同的业务数据,需要对数据导入的操作脚本进行修改,遇到有问题的数据,需要根据错误进行逻辑分析,创建新的脚本来筛选出错误数据,并进行修改整理,最终将正确、完整的业务数据导入到协会业务系统数据库中,为保费结算工作提供了及时可靠的数据支持。

做计算机技术工作的人都知道,专业的知识只能称得上打开这项工作大门的一把钥匙,要想真正迈进协会数据库管理工作这项领域,我们还需要学习掌握协会的业务系统数据库框架。协会的数据库里面承载着一百多类表,包含着一千余个列,我们不仅要知道这些表的逻辑结构和数据类型,还要知道各个表之间的关联,从而在数据库中顺利的实现增、删、改、查我们所需要的数据。

一点不足和建议

协会的数据库建设工作无论是逻辑结构方面,还是软件兼容方面,都做的很好,但是在硬件设备管理上,我们可能还有更好的选择。2015年年末,我接手了一项筛查数据的工作,原因是山东数据库服务器机房出现故障,导致丢失了部分业务数据,我的任务就是要将这些丢失的数据文件名查找出来,以便山东协会后期进行补救工作。事后我对这件事进行了思考,事故的主要原因是因为他们的数据库服务器存放在省协会本部没有专业管理的机房中,由于空调故障室温过热,导致硬盘烧毁,在此方面,国家协会目前的做法和省协会一样,都将服务器存放在本部没有专业管理的机房。2015年7月,由于协会网络供应商硬件设备出现严重故障,导

致我会办公网络以及业务系统全面瘫痪,虽然我部已在第一时间查明原因,但却束手无策,只能敦促网络供应商尽快修复。

上一篇:题破山寺后禅院的阅读及答案下一篇:诚信的力量读后感