Oracle系统学习摘要
对于企业级大型系统,Oracle数据库的重要性不言而喻,作为长期使用Sql server的developer,花了点时间学习了一个Oracle的系列课程,总结一下。
1.oracle一些基础命令
sql*plus是操作Oracle的常用工具,以下一些常用命令:
(1)连接数据库:conn 用户名/密码 as sysdba/sysoper
(2)关闭连接:disc
(3)改密码:psssw, alter user *** identified by ***
(4)显示当前用户: show user
(5)创建用户:create user identified by pwd,删除用户: drop user [cascade]
2.Oracle的表,数据对象,权限管理和角色,数据字典
Oracle数据类型:
字符类型: char 定长,最大2000字符; varchar2 变长,最大4000字符; clob 字符型大对象,最大4G。
数字类型:number(n,m)
日期: date
权限和角色
方案(schema):讲权限之前,这里有个方案的概念,每个用户建立的时候,都对应一个方案,其名称与用户名相同。oracle的表,存储过程,函数,视图,触发器,游标等等,称为数据对象,每个用户的方案下面都会包含其自身的数据对象。
权限:执行特定的sql命令或者访问对象的权利。oracle包括系统权限、对象权限2大类。
系统权限:系统权限是指执行特定类型sql命令的权利。它用于控制用户可以执行的一个或是一组数据库操作。比如当用户具有create table权限时,可以在其方案中建表,当用户具有create any table权限时,可以在任何方案中建表。oracle提供了100多种系统权限。比如,常用的有: create session 连接数据库 create table 建表 ;create view 建视图 ;create procedure 建过程、函数、包;create trigger 建触发器;create cluster 建簇等。
显示系统权限sql语句:select * from system_privilege_map order by name;
授予/回收系统权限:
grant create session,create table to user*** with admin option -- with admin option表示被授权的用户可以继续向下授予相应权限。
revoke create session from user*** (系统权限不级联回收,也即A->B->C,当A收回B的权限是,C的不回收。)
对象权限:访问其他方案的对象的权利。常用的有:alter, delete, select, insert, update, execute等。
查看对象权限:
select distinct privilege from dba_tab_privs ---查看所有的对象权限
select grantor, owner, table_name, privilege from dba_tab_privs where grantee = 'AAA'; ---查看AAA用户的对象权限
授予/回收对象权限
grant select,delete on TableA to AAA;
revoke select on TableA from AAA; ---(级联回收)
角色
角色就是相关权限命令的集合,使用角色的目的就是为了简化权限管理。角色有预定义角色和自定义角色2类。
预定义角色,比如, connect角色包含: alter session, create cluster, create database link, create session, create table, create view, create sequence权限。
自定义角色, create role 名称 identified by 密码
给角色增加权限: grant 权限 to 角色名 (with admin option).
分配角色给用户: grant 角色名 to 用户名 with admin option.
数据字典
数据字典:记录了数据库的静态信息,包括只读表和视图,其所有者为sys用户。包括:user_XXX, all_XXX, dba_XXX 3种类型。
user_tables:显示当前用户的所有表,只返回用户的方案的表。 select table_name from user_tables.
all_tables: 显示用户可以访问的所有表,包括其他方案的表。select table_name from all_tables.
dba_tables: 显示所有方案的所有表,当时只有dba角色的用户或拥有select any table权限的用户才能查询。
dba_users: 所有用户; dba_sys_privs:所有系统权限; dba_tab_privs:所有对象权限;dba_col_privs:所有列权限;dba_role_privs:所有角色。
3.PL/SQL编程,包,存储过程,函数,游标等。
Package,store procedure, function 模板:
包声明:
create or replace package PackageAAA is
procedure procedureAAA(par1 varchar2, par2 number);
function functionAAA(par1 varchar2);
end;
包体:
create or replace package body PackageAAA is
procedure procedureAAA(par1 varchar2, par2 number) is
begin /* 内容*/ end;
function functionAAA(par1 varchar2) is
begin /*内容*/ end;
end;
PL/SQL程序中的变量和复合类型
1.标量类型 2.复合类型 3.参照类型 4.lob(large object)
标量类型:也即常用类型,定义语法如下: identifier [constant] datatype [not null] [:=default value],比如:v_sal2 number(6,2):=5.4;定义一个数字
类型,默认赋值5.4。 使用%type类型, 比如 v_name tableAAA.Col1%type,定义v_name变量,类型和tableAAA的col1相同。
复合类型:有 pl/sql记录,pl/sql表,嵌套表,varray等。
type emp_record_type is record(name emp.ename%type, salary emp.sal%type, title emp.job%type); --定义pl/sql记录类型
参照变量:用于存放数值指针的变量。通过使用参照变量,可以使得应用程序共享相同对象,从而降低占用的空间。在编写pl/sql程序时,可以使用游标变量(ref cursor)和对象类型变量(ref obj_type)两种参照变量类型。
--定义游标sp_emp_cursor
type sp_AAA_cursor is ref cursor;
--定义一个游标变量
test_cursor sp_AAA_cursor;
--定义变量
v_par1 AAA.Col1%type;
v_par2 AAA.Col2%type;
begin
--执行
open test_cursor for select Col1,Col2 from AAA where Col3=&?;
--循环取出
loop
fetch test_cursor into v_par1,v_par2;
--判断是否test_cursor为空
exit when test_cursor%notfound;
dbms_output.put_line('Column1:'||v_par1||' Column2:'||v_par2);
end loop;
PL/SQL 分页存储过程:
create or replace package testpackage as
TYPE test_cursor is ref cursor;
end testpackage;
#NAME?
create or replace procedure paging
(
tableName in varchar2,
Pagesize in number,--一页显示记录数
pageNow in number,
myrows out number,--总记录数
myPageCount out number,--总页数
p_cursor out testpackage.test_cursor--返回的记录集
) is
--定义sql语句参数
v_sql varchar2(1000);
#定义开始和结尾数
v_begin number:=(pageNow-1)*Pagesize+1;
v_end number:=pageNow*Pagesize;
begin
--主要逻辑
v_sql:='select * from (select t1.*, rownum rn from (select * from '||tableName||') t1 where rownum<='||v_end||') where rn>='||v_begin;
#关联sql和游标
open p_cursor for v_sql;
--计算myrows和myPageCount
--组织sql
v_sql:='select count(*) from '||tableName;
--执行sql,并把返回的值,赋给myrows;
execute inmediate v_sql into myrows;
--计算myPageCount
if mod(myrows,Pagesize)=0 then
myPageCount:=myrows/Pagesize;
else
myPageCount:=myrows/Pagesize+1
end if;
--关闭游标
close p_cursor;
end;
Oracle系统学习摘要的更多相关文章
- 零基础如何系统学习Java Web
零基础如何系统学习Java Web? 我来给你说一说 你要下决心,我要转行做开发,这样你才能学成. 你要会打字,我公司原来有一个程序员,打字都是两个手一指禅,身为程序员你一指禅怎么写出的代码,半个 ...
- Oracle RAC学习笔记:基本概念及入门
Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章] oracle 10g real applica ...
- Oracle GoldenGate学习之Goldengate介绍
Oracle GoldenGate学习之Goldengate介绍 (2012-10-02 17:07:27) 标签: 检查点 数据传输 队列 进程 分类: Goldengate Goldengate介 ...
- Oracle RAC学习笔记01-集群理论
Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...
- Hibernate的系统 学习
Hibernate的系统 学习 一.Hibernate的介绍 1.什么是Hibernate? 首先,hibernate是数据持久层的一个轻量级框架.数据持久层的框架有很多比如:iBATIS,myBat ...
- CSS学习摘要-定位
CSS学习摘要-定位 注:全文摘自MDN-CSS定位 定位允许您从正常的文档流布局中取出元素,并使它们具有不同的行为,例如放在另一个元素的上面,或者始终保持在浏览器视窗内的同一位置. 本文解释的是定位 ...
- redhat5.8系统学习
# redhat5.8系统学习 ### 简介-----------------------------redhat操作系统是红帽公司的收费版操作系统 ### 查看系统版本号-------------- ...
- Oracle RMAN 学习:恢复
Oracle RMAN 学习:恢复 6 rman恢复 Rman中的恢复对应restore,recover Restore,数据修复,利用备份集的数据文件来替换已损坏的数据文件或将其恢复到另外一个位置, ...
- Oracle RMAN 学习:演练进阶篇
Oracle RMAN 学习:演练进阶篇 5 Rman备份演练进阶篇 5.1 是否选择增量备份 Backup命令生成的备份集中只备份了那些使用了的数据块,备份集实际大小已经较目标数据库的数据文件小了很 ...
随机推荐
- github:如何获取项目源代码
github是流行的源码管理平台.这上面有很多开源的项目.作为普通的用户,如何获取这些开源项目的源码呢? 1.首先需要注册一个github账号. 2.安装windows下的git工具:下载地址: ht ...
- zend studio 的使用
1.将php项目导入到zend studio 中的方式为:http://my.oschina.net/maomi/blog/86077: 2.zend studio中将php项目导出的方式为:如果你会 ...
- thinkphp在模型中自动完成session赋值
相信用过thinkphp的用户都知道thinkphp的模型可以完成很多辅助功能,比 如自动验证.自动完成等,今天在开发中遇到自动完成中需要获取session值 然后自动赋值的功能,具体看代码:clas ...
- Codeforces Round #170 (Div. 2)
A. Circle Line 考虑环上的最短距离. B. New Problem \(n\) 个串建后缀自动机. 找的时候bfs一下即可. C. Learning Languages 并查集维护可以沟 ...
- [NOIP2015] 子串(dp)
题目描述 有两个仅包含小写英文字母的字符串 A 和 B.现在要从字符串 A 中取出 k 个互不重叠的非空子串,然后把这 k 个子串按照其在字符串 A 中出现的顺序依次连接起来得到一 个新的字符串,请问 ...
- OSX unable to write 'random state'
openssl ca -gencrl -config ./config/openssl.cnf -out ./CA/crl/cacrl.pem -passin pass:'password' unab ...
- svn import后,服务器上少了所有*.a文件的问题解决
转载自:http://blog.csdn.net/lwl_ls/article/details/20222051 将本地代码import到svn服务器. svn co出代码,编译却报错少了这个那个*. ...
- Linux--02软件安装、防火墙设置
防火墙设置: With RHEL / CentOS , firewalld was introduced to manage iptables. IMHO, firewalld is more sui ...
- 手机网页调试利器: Chrome
新开发的网页需要在手机或是模拟机上运行测试, 可以借助 Chrome提供的手机网页预览程序进行简单调试.查看 制作的网页是否能够适合各种手机型号使用. 下面所以下如何使用Chrome调试多类型手机网页 ...
- 使用.net 创建windows service
最近公司项目需要,写了个windows 服务,windows 服务的内容可以在VS 中新建一个"windows服务项目", (1)服务中的主要代码: public partial ...