- 浏览: 50514 次
- 性别:
- 来自: 合肥
文章分类
最新评论
建立表空间:建立表空间使用create tablespace 命令
只有拥有dba 或是拥有create datebase权限的用户可以创建
SQL> create tablespace demon001 datafile 'd:\demon001.dbf' size 2m uniform size 128k;(这里的
uniform就是我们所指的区)
向指定表空间中添加表
create table mypart(deptno number(4),dname varchar2(14),loc varchar2(13)) tablespace demon001;
改变表空间状态 一般还是特权用户或是dba
(1)使表空间脱机
alter tablespace 表空间名 offline
(2)使表空间联机
alter tablespace 表空间名 online
(3)只读表空间,当建立表空间时,表空间可以读写,如果不希望该表空间上执行update,delete
,insert 操作,那么可以将表空间改为只读状态
alter tablespace 表空间名 read only;
如果要恢复则 alter tablespace 表空间名 read write;
(4)知道表空间得到其下面的表
select * from all_tables where tablespace_name='DEMON001';
(5) 知道一个表,查看属于哪个表空间
SQL> select tablespace_name,table_name from user_tables where table_name='表名';
(6)删除表空间
drop tablespace '表空间名' Including contends and datafiles;
说明:在删除表空间时,会把所有的数据对象和数据库文件也删除;
(7)当表空间达到足够大时,就增加不了数据了。这时候可以使用三种方式来增加表空间大小;
a.增加数据文件的数量
alter tablespace demon001 add datafile 'd:\demon002.dbf' size 20m;
b.增加数据文件大小
alter tablespace '表空间名' resize 20m;
c.设置文件的自动增长
alter tablespace '表空间名' autoextend on next 10m maxsize 500m;
(8)移动数据文件
如果你的数据文件所在的磁盘损坏时,该数据文件将不再使用,为了能够重新使用,需要将这些文件的副本移动到
其他磁盘,然后恢复
下面以demon001.dbf 为例说明 :
a.确定数据文件所在的表空间
select tablespace_name from dba_data_files where file_name='d:\demon001.dbf';
b.使表空间脱机,确保数据文件的一致性,将表空间转换为offline的状态
alter tablespace demon001 offline;
c.使用命令移动数据文件到指定的目标位置
host move d:\demon001.dbf e:\demon001.dbf
d.在物理上移动数据后,还必须执行alter tablespace 命令对数据文件进行逻辑修改
alter tablespace demon001 rename datafile 'd:\demon001.dbf' to 'e:\demon001.dbf';
e.在移动数据文件后,为了使用户可以访问该表空间,必须将其转化成online状态
alter tablespace '表空间名' online
.权限
1.系统权限 (用户针对数据库的一些操作如建库 建表 创建用户 )
system---》tom授权(登录)--》ken 当回收tom权限时,ken 是否可以再登录
系统权限不是级联回收
2.对象权限(对表的增删改查 ,索引等等操作)
对象权限是级联回收的
角色:是一些相关联权限的结合
预定义角色:是oracle所提供的角色,是执行一些特定的管理任务。
下面介绍三个常见的预定义角色:
a.resource:
b.connect
c.dba
自定义角色:一般是dba或是有create role 权限的用户
create role 角色名 not identified;
grant create session to 角色名 with admin option;
grant select on scott.emp to 角色名;
.........;
授角色(一般是dba 或是拥有grand any role 的权限)
grant 角色名 to 用户 with admin option;
消除角色 drop role 角色名 执行完该命令后,将不会再有登录权限
plsql
存储过程:
create table mytest(username varchar2(10),password varchar2(10));
创建:SQL> create or replace procedure insert_prol is//后面的or replace 是可选的
2 begin
3 insert into mytest values('dim','123');
4 end;
5 /
删除 drop procedure insert_prol;
执行 exec insert_prol;
call insert_prol;
例1:最简单的块
SQL> set serveroutput on;
SQL> begin
2 dbms_output.put_line('hell');//和java中的包中含有方法和函数相似
3 end;
4 /
例2:定义变量(假如输入为7788)
SQL> declare
2 v_name varchar(9);
3 v_sal number(5);
4 begin
5 select ename,sal into v_name,v_sal from emp where EMPNO=&no;// &是从控制台输入变量
6 dbms_output.put_line('用户名是:'||v_name||' 工资:'||v_sal);//"||"是连接符
exception
7 when no_data_found then
8 dbms_output.put_line('输入有误!');
9 end;
10 /
用户名是:SCOTT 工资:3000
2.1 定义常量的方法:“:=”
SQL> declare
2 c_tax_rate number(3,2):=0.03;
3 v_tax_sal number(7,2);
4 v_name varchar2(5);
v_sal number(7,2);
6 begin
7 select ename,sal into v_name,v_sal from emp where empno=&no;
8 v_tax_sal := v_sal*c_tax_rate;
9 dbms_output.put_line('姓名:'||v_name ||'工资:' ||v_sal ||'纳税:' ||v_tax_sal);
10 end;
11 /
标量:%type 解决字符串的不匹配:
还是上面的例子,如果我们得到的名字的个数大于5 那么就会报错(numeric or value error: character
string buffer too small),这是可以使用
declare
c_tax_rate number(3,2):=0.03;
v_tax_sal number(7,2);
v_name emp.ename%type;//这里是表示该变量的到的buffer大小和emp表中ename的大小相同
v_sal number(7,2);
begin
select ename,sal into v_name,v_sal from emp where empno=&no;
v_tax_sal := v_sal*c_tax_rate;
dbms_output.put_line('姓名:'||v_name ||'工资:' ||v_sal ||'纳税:' ||v_tax_sal);
end;
复合类型--pl/sql 记录实例【相当java中的结构体
declare
--定义一个pl/sql的记录类型emp_record_type 包含三个部分 name,salary,title
type emp_record_type is record(name emp.ename%type,salary emp.sal%type,title emp.job%type);
--定义一个emp_record_type类型的变量
dim_record emp_record_type;
begin
select ename,sal,job into dim_record from emp where empno=7788;
dbms_output.put_line('该记录的用户名是:'||dim_record.name);
end;
该记录的用户名是:SCOTT
如果没有显示结果,可能是没有设置:set serveroutput on;
复合类型--pl/sql 表实例 【相当java中的数组
SQL>
SQL> declare
2 --定义一个pl/sql的表类型 存放的类型是:emp.ename%type
3 --index by binary_integer 表示下标是整数
4 type emp_table_type is table of emp.ename%type index by binary_integer;
5 --定义一个emp_table_type类型的变量
6 dim_table emp_table_type;
7 begin
8 select ename into dim_table(-1) from emp where empno=7788;
9 dbms_output.put_line('该记录的用户名是:'||dim_table(-1));
10 end;
11 /
该记录的用户名是:SCOTT
【在这里如果把where 后的去掉就会出现错误 ,因为返回的个数大于一 :解决问题如下:使用游标
declare
2 --定义游标类型dim_emp_cursor
3 type dim_emp_cursor is ref cursor;
4 --定义一个游标变量
5 test_cursor dim_emp_cursor;
6 --定义变量
7 v_ename emp.ename%type;
8 v_sal emp.sal%type;
9 begin
10 --把test_cursor 和一个select 结合
11 open test_cursor for select ename,sal from emp where deptno=&no;
12 --循环取出
13 loop
14 fetch test_cursor into v_ename,v_sal;
15 exit when test_cursor%notfound;
16 dbms_output.put_line('名字:'||v_ename||'工资:'||v_sal);
17 end loop;
18 --关闭游标
19 close test_cursor;
20 end;
21 /
函数:
create function dim_fun1 (s_name varchar2) return
2 number is yearSal number(7,2);
3 begin
4 select sal*12+nvl(comm,0)*12 into yearSal from emp where ename=s_name;
5 return yearSal;
6 end;
7 /
执行:SQL> var year_sal number;
SQL> call dim_fun1('SCOTT') into:year_sal;
Method called
year_sal
---------
36000
包的创建 包体的创建 及包的使用
create package dim_pag is
2 procedure update_sal (name varchar2,newSal number);
3 function total_income(name varchar2) return number;
4 end;
5 /
Package created
SQL>
SQL> create package body dim_pag is
2 procedure update_sal(name varchar2,newSal number)
3 is
4 begin
5 update emp set sal=newSal where ename=name;
6 end;
7 function total_income(name varchar2)
8 return number is
9 all_sal number;
10 begin
11 select sal*12+nvl(comm,0) into all_sal from emp
12 where ename=name;
13 return all_sal;
14 end;
15 end;
16 /
Package body created
SQL> exec dim_pag.update_sal('SCOTT',200);
带有输入输出参数:
--输入参数 in(默认) 输出参数用out
create or replace procedure dim_inout(v_no in number,v_name out varchar2,v_sal out number)
is
begin
select ename,sal into v_name,v_sal from emp where empno=&v_no;
end;
在java中调用:
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection
("jdbc:oracle:thin:@localhost:1521:ORCL","SCOTT","pass");
CallableStatement cs = con.prepareCall("{call dim_inout(?,?,?)}");
cs.setInt(1, 7788);
//给第二个?赋值
cs.registerOutParameter(2, oracle.jdbc.OracleTypes.VARCHAR);
cs.registerOutParameter(3, oracle.jdbc.OracleTypes.NUMBER);
cs.execute();
String name = cs.getString(2);
double sal = cs.getDouble(3);
System.out.println("7788的用户名是:"+name+"工资是:"+sal);
} catch (Exception e) {
e.printStackTrace();
}
一般情况下,我们使用返回结果集的方式得到
只有拥有dba 或是拥有create datebase权限的用户可以创建
SQL> create tablespace demon001 datafile 'd:\demon001.dbf' size 2m uniform size 128k;(这里的
uniform就是我们所指的区)
向指定表空间中添加表
create table mypart(deptno number(4),dname varchar2(14),loc varchar2(13)) tablespace demon001;
改变表空间状态 一般还是特权用户或是dba
(1)使表空间脱机
alter tablespace 表空间名 offline
(2)使表空间联机
alter tablespace 表空间名 online
(3)只读表空间,当建立表空间时,表空间可以读写,如果不希望该表空间上执行update,delete
,insert 操作,那么可以将表空间改为只读状态
alter tablespace 表空间名 read only;
如果要恢复则 alter tablespace 表空间名 read write;
(4)知道表空间得到其下面的表
select * from all_tables where tablespace_name='DEMON001';
(5) 知道一个表,查看属于哪个表空间
SQL> select tablespace_name,table_name from user_tables where table_name='表名';
(6)删除表空间
drop tablespace '表空间名' Including contends and datafiles;
说明:在删除表空间时,会把所有的数据对象和数据库文件也删除;
(7)当表空间达到足够大时,就增加不了数据了。这时候可以使用三种方式来增加表空间大小;
a.增加数据文件的数量
alter tablespace demon001 add datafile 'd:\demon002.dbf' size 20m;
b.增加数据文件大小
alter tablespace '表空间名' resize 20m;
c.设置文件的自动增长
alter tablespace '表空间名' autoextend on next 10m maxsize 500m;
(8)移动数据文件
如果你的数据文件所在的磁盘损坏时,该数据文件将不再使用,为了能够重新使用,需要将这些文件的副本移动到
其他磁盘,然后恢复
下面以demon001.dbf 为例说明 :
a.确定数据文件所在的表空间
select tablespace_name from dba_data_files where file_name='d:\demon001.dbf';
b.使表空间脱机,确保数据文件的一致性,将表空间转换为offline的状态
alter tablespace demon001 offline;
c.使用命令移动数据文件到指定的目标位置
host move d:\demon001.dbf e:\demon001.dbf
d.在物理上移动数据后,还必须执行alter tablespace 命令对数据文件进行逻辑修改
alter tablespace demon001 rename datafile 'd:\demon001.dbf' to 'e:\demon001.dbf';
e.在移动数据文件后,为了使用户可以访问该表空间,必须将其转化成online状态
alter tablespace '表空间名' online
.权限
1.系统权限 (用户针对数据库的一些操作如建库 建表 创建用户 )
system---》tom授权(登录)--》ken 当回收tom权限时,ken 是否可以再登录
系统权限不是级联回收
2.对象权限(对表的增删改查 ,索引等等操作)
对象权限是级联回收的
角色:是一些相关联权限的结合
预定义角色:是oracle所提供的角色,是执行一些特定的管理任务。
下面介绍三个常见的预定义角色:
a.resource:
b.connect
c.dba
自定义角色:一般是dba或是有create role 权限的用户
create role 角色名 not identified;
grant create session to 角色名 with admin option;
grant select on scott.emp to 角色名;
.........;
授角色(一般是dba 或是拥有grand any role 的权限)
grant 角色名 to 用户 with admin option;
消除角色 drop role 角色名 执行完该命令后,将不会再有登录权限
plsql
存储过程:
create table mytest(username varchar2(10),password varchar2(10));
创建:SQL> create or replace procedure insert_prol is//后面的or replace 是可选的
2 begin
3 insert into mytest values('dim','123');
4 end;
5 /
删除 drop procedure insert_prol;
执行 exec insert_prol;
call insert_prol;
例1:最简单的块
SQL> set serveroutput on;
SQL> begin
2 dbms_output.put_line('hell');//和java中的包中含有方法和函数相似
3 end;
4 /
例2:定义变量(假如输入为7788)
SQL> declare
2 v_name varchar(9);
3 v_sal number(5);
4 begin
5 select ename,sal into v_name,v_sal from emp where EMPNO=&no;// &是从控制台输入变量
6 dbms_output.put_line('用户名是:'||v_name||' 工资:'||v_sal);//"||"是连接符
exception
7 when no_data_found then
8 dbms_output.put_line('输入有误!');
9 end;
10 /
用户名是:SCOTT 工资:3000
2.1 定义常量的方法:“:=”
SQL> declare
2 c_tax_rate number(3,2):=0.03;
3 v_tax_sal number(7,2);
4 v_name varchar2(5);
v_sal number(7,2);
6 begin
7 select ename,sal into v_name,v_sal from emp where empno=&no;
8 v_tax_sal := v_sal*c_tax_rate;
9 dbms_output.put_line('姓名:'||v_name ||'工资:' ||v_sal ||'纳税:' ||v_tax_sal);
10 end;
11 /
标量:%type 解决字符串的不匹配:
还是上面的例子,如果我们得到的名字的个数大于5 那么就会报错(numeric or value error: character
string buffer too small),这是可以使用
declare
c_tax_rate number(3,2):=0.03;
v_tax_sal number(7,2);
v_name emp.ename%type;//这里是表示该变量的到的buffer大小和emp表中ename的大小相同
v_sal number(7,2);
begin
select ename,sal into v_name,v_sal from emp where empno=&no;
v_tax_sal := v_sal*c_tax_rate;
dbms_output.put_line('姓名:'||v_name ||'工资:' ||v_sal ||'纳税:' ||v_tax_sal);
end;
复合类型--pl/sql 记录实例【相当java中的结构体
declare
--定义一个pl/sql的记录类型emp_record_type 包含三个部分 name,salary,title
type emp_record_type is record(name emp.ename%type,salary emp.sal%type,title emp.job%type);
--定义一个emp_record_type类型的变量
dim_record emp_record_type;
begin
select ename,sal,job into dim_record from emp where empno=7788;
dbms_output.put_line('该记录的用户名是:'||dim_record.name);
end;
该记录的用户名是:SCOTT
如果没有显示结果,可能是没有设置:set serveroutput on;
复合类型--pl/sql 表实例 【相当java中的数组
SQL>
SQL> declare
2 --定义一个pl/sql的表类型 存放的类型是:emp.ename%type
3 --index by binary_integer 表示下标是整数
4 type emp_table_type is table of emp.ename%type index by binary_integer;
5 --定义一个emp_table_type类型的变量
6 dim_table emp_table_type;
7 begin
8 select ename into dim_table(-1) from emp where empno=7788;
9 dbms_output.put_line('该记录的用户名是:'||dim_table(-1));
10 end;
11 /
该记录的用户名是:SCOTT
【在这里如果把where 后的去掉就会出现错误 ,因为返回的个数大于一 :解决问题如下:使用游标
declare
2 --定义游标类型dim_emp_cursor
3 type dim_emp_cursor is ref cursor;
4 --定义一个游标变量
5 test_cursor dim_emp_cursor;
6 --定义变量
7 v_ename emp.ename%type;
8 v_sal emp.sal%type;
9 begin
10 --把test_cursor 和一个select 结合
11 open test_cursor for select ename,sal from emp where deptno=&no;
12 --循环取出
13 loop
14 fetch test_cursor into v_ename,v_sal;
15 exit when test_cursor%notfound;
16 dbms_output.put_line('名字:'||v_ename||'工资:'||v_sal);
17 end loop;
18 --关闭游标
19 close test_cursor;
20 end;
21 /
函数:
create function dim_fun1 (s_name varchar2) return
2 number is yearSal number(7,2);
3 begin
4 select sal*12+nvl(comm,0)*12 into yearSal from emp where ename=s_name;
5 return yearSal;
6 end;
7 /
执行:SQL> var year_sal number;
SQL> call dim_fun1('SCOTT') into:year_sal;
Method called
year_sal
---------
36000
包的创建 包体的创建 及包的使用
create package dim_pag is
2 procedure update_sal (name varchar2,newSal number);
3 function total_income(name varchar2) return number;
4 end;
5 /
Package created
SQL>
SQL> create package body dim_pag is
2 procedure update_sal(name varchar2,newSal number)
3 is
4 begin
5 update emp set sal=newSal where ename=name;
6 end;
7 function total_income(name varchar2)
8 return number is
9 all_sal number;
10 begin
11 select sal*12+nvl(comm,0) into all_sal from emp
12 where ename=name;
13 return all_sal;
14 end;
15 end;
16 /
Package body created
SQL> exec dim_pag.update_sal('SCOTT',200);
带有输入输出参数:
--输入参数 in(默认) 输出参数用out
create or replace procedure dim_inout(v_no in number,v_name out varchar2,v_sal out number)
is
begin
select ename,sal into v_name,v_sal from emp where empno=&v_no;
end;
在java中调用:
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection
("jdbc:oracle:thin:@localhost:1521:ORCL","SCOTT","pass");
CallableStatement cs = con.prepareCall("{call dim_inout(?,?,?)}");
cs.setInt(1, 7788);
//给第二个?赋值
cs.registerOutParameter(2, oracle.jdbc.OracleTypes.VARCHAR);
cs.registerOutParameter(3, oracle.jdbc.OracleTypes.NUMBER);
cs.execute();
String name = cs.getString(2);
double sal = cs.getDouble(3);
System.out.println("7788的用户名是:"+name+"工资是:"+sal);
} catch (Exception e) {
e.printStackTrace();
}
一般情况下,我们使用返回结果集的方式得到
发表评论
-
oracle 学习笔记上
2011-06-20 19:00 10861.oracle 安装完成后,会 ... -
jquery 对select中的option操作
2011-06-15 16:28 6263Jquery的功能很强大,下面 ... -
MySQL实现分页技术
2011-06-09 08:29 906先给出servlet package com.ourchr.s ... -
servlet cookie jsp
2011-05-19 18:21 915首先是登陆界面,其中有mes_zh等国际化 这个不重要 < ... -
java学习日记(线程)
2011-05-18 18:38 813java学习日记(线程) 一 ... -
Java Servlet和JSP 处理Cookie
2011-05-18 13:28 19529.1 Cookie概述 Cookie是服务器发送给浏 ... -
简单的qq实现
2011-05-17 18:42 742很好用 简洁 -
简单的日历控件
2011-05-17 18:40 798package Exception; import java ... -
完整的JDBC 简单列子
2011-05-17 18:38 690package dao; import java.sql.Co ... -
jsp jstl 标签3
2011-05-13 17:38 698<c:import> 作用:导入一个url的资源, ... -
jsp jstl 标签2
2011-05-13 17:38 742c:forEach 用于循环的<c:forEach&g ... -
jsp jstl 标签1
2011-05-13 17:36 1193一、引入包: jstl.jar (1 ... -
js 中this用发小结
2011-03-09 09:19 703js中this的总结 在面向对 ... -
js 正则表达式
2011-02-24 15:12 632js正则表达式 exec 方法 用正则表达式模式在字符串中运 ... -
WEB innerHTML中div 和span
2011-02-24 13:58 1243使用innerHTML属性来控制DIV和SPAN<$lo ... -
Myeclipse 快捷键打总结
2011-01-08 13:01 727xml、jsp、jsf、js等等,我们没有必要全部都去自动校验 ... -
java基础知识
2011-01-07 17:35 708 -
java文件夹之间的复制
2011-01-06 14:58 656package Exception; import java. ...
相关推荐
这个是我学习网上的视频做的oracle笔记,对于oracle一窍不通的菜鸟可能有用吧,大家有需要可以看看
李兴华Oracle全部笔记是一份详细记录了Oracle相关知识的学习资料,涵盖了从基础概念到高级特性的全面讲解。这些笔记可能是李兴华在深入研究Oracle后的心得体会,对于想要学习或提升Oracle技能的人来说是一份宝贵的...
### Oracle学习笔记知识点详解 #### 一、Oracle简介 Oracle是一家知名的软件公司,以其数据库管理系统闻名全球。该公司成立于1977年,总部位于美国加利福尼亚州。Oracle不仅提供数据库解决方案,还涉及中间件、...
标题“2011Oracle笔记(李兴华视屏教程笔记)”揭示了文档的用途,它是作为2011年李兴华Oracle教学视频课程的学习笔记。这种笔记通常包括了课程中的重点概念、Oracle数据库基础知识、实际操作案例以及配合视频教程的...
这篇史上最全的Oracle笔记将为你提供全面的学习指导。 一、数据库基础 数据库(DataBase)是存储数据的系统,Oracle数据库允许用户以表格的形式组织和管理数据。在Oracle中,数据主要以表的形式存在,表是数据库中...
《MLDN最经典的ORACLE笔记》是李兴华老师倾力打造的一份全面而深入的Oracle学习资源,专为对数据库技术感兴趣的读者精心准备。Oracle作为全球广泛使用的数据库管理系统,其强大功能和复杂性使得深入理解和掌握Oracle...
### 韩顺平Oracle笔记知识点详解 #### 一、Oracle认证及与其他数据库的比较 - **Oracle认证**:Oracle提供了多种级别的认证体系,包括OCA(Oracle Certified Associate)、OCP(Oracle Certified Professional)、...
马士兵oracle笔记,浅显易懂。
在达内的Oracle笔记中,可能会详细讲解SELECT语句用于数据检索,INSERT、UPDATE、DELETE用于数据增删改,以及CREATE、ALTER、DROP用于数据库对象管理的语法和用法。 3. **数据库设计**:良好的数据库设计是确保系统...
根据提供的信息,我们可以总结出以下关于Oracle的相关知识点: ### Oracle基础知识与分类 #### DDL (Data Definition Language) 数据定义语言 - **DDL** 主要用于创建、修改或删除数据库对象,如表、索引等。 ###...
oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记oracle adg安装个人笔记...
本资源“oracle笔记+资料.rar”包含了丰富的Oracle学习资料,适合不同水平的学习者,无论你是初学者还是资深DBA,都能从中受益。下面将详细解析其中可能涵盖的知识点。 1. **Oracle基础知识**:这部分内容可能会...
正常情况下,卸载前需要停止所有Oracle相关服务,并从Oracle安装的主界面选择卸载选项。在卸载过程中,应按照提示操作以确保数据库的正确卸载,避免数据丢失。 9. 免费使用与版权问题 Oracle数据库虽然是付费软件,...
oracle笔记创建和管理表,增加列,删除列,修改列,修改列名和数据类型和长度,修改表名等等操作,有代码案例!
在Oracle学习笔记中,我们关注的关键概念主要包括以下几个方面: 1. **数据缓冲区**:这是Oracle内存架构的重要组成部分,用于存储从磁盘数据文件中读取的数据。所有用户共享这个缓冲区,当数据被服务器进程读入后...
Oracle学习笔记 Oracle学习笔记是李兴华老师编写的Oracle从入门到精通的学习笔记,涵盖了 Oracle 的多表查询、连接、组函数和分组统计等知识点。在本篇笔记中,李兴华老师详细介绍了多表查询的基本语法、左右连接...
根据给定的文件信息,以下是从“韩顺平老师oracle笔记”中提炼出的关键知识点,主要涉及Oracle数据库的基础概念、用户管理以及SQL*Plus的基本操作。 ### Oracle数据库基础 1. **Oracle数据库的角色与权限**: - *...
比较全的Oracle学习笔记
记录Oracle学习过程中的各种笔记,比较实用的总结.可以查询常用的Oracle信息
以下是对"Oracle笔记"中的关键知识点的详细说明: 1. **Oracle认证与安装**:Oracle提供了一系列的认证,如OCP(Oracle Certified Professional),表明用户具备相应级别的Oracle数据库技能。在安装Oracle时,系统...