0

0

Oracle基础教程知识点总结

php中文网

php中文网

发布时间:2016-06-07 17:30:00

|

1084人浏览过

|

来源于php中文网

原创

1. dba,sysdba,sysoper 区别 dba 是一种角色;角色可以包含系统权限,对象权限和角色;dba不包含sysdba,sysoper权限; sysdba ,

1. dba,sysdba,sysoper 区别
 
dba 是一种角色;角色可以包含系统权限,对象权限和角色;dba不包含sysdba,sysoper权限;
 
sysdba ,sysoper 是两种系统权限;这两种权限比较大最好以sys,system登陆管理,不要赋给普通用户;
 

2. Oracle的public
 
public 可以理解为所有用户的集合;
 
grant dba to public ; 相当于所有用户都是dba;
 


---plsql编程:
 

plsql可以编写:过程,函数,触发器;
 
过程,函数,触发器在oracle中;
 
plsql是非常强大的数据库过程语言;
 
过程,函数可以在java中调用;
 

plsql优点:
 
提高性能;(传统的jdbc连库,执行sql,编译成数据库语言,返回值,关闭连接,多次调用多次编译,写成过程只编译一次,对调随用;)
 
模块化设计思想;(分页过程,订单的过程,转账的过程)
 
减少网络传输量;(本来需要传个大sql,现在传个过程名字就行了)
 
安全性高;(oracle数据库的保护,字段什么的都在库里面)
 
plsql缺点:
 
移植性不好;(oracle语言写的过程,这些过程在DB2上是没法使用的)
 


1.创建一个存储过程
 
create or replace procedure p1 is
 
begin
 
insert into mytable values('gao','123456');
 
end;
 
/
 
2.存储过程编程报错,查看错误:
 
show errors;
 
3.如何执行存储过程
 
exec p1;
 

------编写规范
 
1.单行注释: --
 
多行注释:/*...*/ (java中一样)
 
2.标示符号的命名规范:
 
变量:v_ (v_val)
 
常量:c- (c_val)
 
游标:-cursor (emp_cursor)
 
例外:e_ (e_error)
 

3.块结构示意图
 
pl/sql 块有三部分组成:定义部分,执行部分,例外部分
 
declear /* 定义部分-定义常量,变量,例外,复杂数据类型*/
 
begin /* 执行部分-要执行的pl/sql语句和sql语句*/ 必须有
 
exception /*例外处理部分-处理运行的各种错误*/可选
 

public static void main(Sting args){
 

int a; //定义部分
 
try{
 

a++; //执行部分
 
}catch(Exception e){ //异常处理部分
 

}
 

PHP编程(基础知识点汇总)课件
PHP编程(基础知识点汇总)课件

PHP编程(基础知识点汇总)课件

下载

}
 

--只包含执行快部分的块
 
set serveroutput on --打开输出服务;
 
begin
 
dbms_output.put_line('hello,World!');
 
end;
 
/
 
--包含声明和执行部分的pl/sql块;
 
declare
 
v_passwd varchar2(10);
 
v_name varchar2(20);
 
begin
 
select passwd ,name into v_passwd ,v_name from mytable where name=&name; --地址符表示从控制台接受变量;
 
dbms_output.put_line(v_name||'的密码为:'||v_passwd);
 
end;
 
/
 

--包含声明,执行和 异常部分的pl/sql块
 
declare
 
v_passwd varchar2(10);
 
v_name varchar2(20);
 
begin
 
select passwd ,name into v_passwd ,v_name from mytable where name=&name; --地址符表示从控制台接受变量;
 
dbms_output.put_line(v_name||'的密码为:'||v_passwd);
 
exception

when no_data_found then
 
dbms_output.put_line('输入的用户名不存在!');
 
end;
 

----过程
 

过程用于执行特定的操作;可以有输入参数和输出参数,
 
--eg4:
 
create procedure changepasswd(name1 varchar2,passwd1 varchar2) is
 
begin
 
--根据用户名修改密码
 
update mytable set passwd=passwd1 where name=name1;
 
end;

-- plsql中执行

call changepasswd('wucaiming','123');
 
--在java中调用存储工程
 
//加载驱动
 
Class.forName("oracle.jdbc.driver.OracleDriver");
 
//得到连接
 
Connection c=DriverManager.getConnection("jdbc:oracle:thin:@192.168.100.145:1521:SDZC","omgap","omgap");
 
//创建CallableStatement
 
CallableStatement cs=c.prepareCall("{call changepasswd(?,?)}");
 
//给?赋值
 
cs.setString(1,"wucaiming");
 
cs.setString(2,"123");
 
//执行
 
cs.execute();
 
/* 如何使用过程返回值?*/
 

函数用于返回特定的数据。
 
--eg5:
 
create or replace function f_returnpasswd(name1 varchar2) return varchar2 is
 
pwd varchar2(30);
 
begin
 
select passwd into pwd from mytable where name=name1;
 
return pwd;
 

end;
 

--plsql中的调用
 
var a varchar2(30);
 
call f_returnPasswd('wucaiming') into:a;
 

包用于在逻辑上组合过程和函数,它有包规范和包体两部分组成。
 
--创建包
 
create package p_package is
 
procedure changepasswd(name1 varchar2,passwd1 varchar2);
 
function f_returnpasswd(name1 varchar2) return varchar2;
 
end;
 
--实现包体
 
create or replace package body p_package is
 
procedure changepasswd(name1 varchar2,passwd1 varchar2) is
 
begin
 
--根据用户名修改密码
 
update mytable set passwd=passwd1 where name=name1;
 
end;

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

0

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

1

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

0

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

0

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

61

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

52

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

25

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

10

2026.01.31

Golang人工智能合集
Golang人工智能合集

本专题整合了Golang人工智能相关内容,阅读专题下面的文章了解更多详细内容。

7

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 5.2万人学习

JavaScript
JavaScript

共185课时 | 22.3万人学习

SQL 教程
SQL 教程

共61课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号