用PHP调用Oracle存储过程的方法_php技巧

但是使用存储过程至少有两个最明显的优点:速度和效率。使用存储过程的速度显然更快。在效率上,如果应用一次需要做一系列sql操作,则需要往返于php与oracle,不如把该应用直接放到数据库方以减少往返次数,增加效率。但是在internet应用上,速度是极度重要的,所以很有必要使用存储过程。偶也是使用php调用存储过程不久,做了下面这个列子。
  代码

复制代码 代码如下:

  //建立一个test表
  create table test (
  id number(16) not null,
  name varchar2(30) not null,
  primary key (id)
  );
  //插入一条数据
  insert into test values (5, 'php_book');
  //建立一个存储过程
  create or replace procedure proc_test (
  p_id in out number,
  p_name out varchar2
  ) as
  begin
  select name into p_name
  from test
  where id = 5;
  end proc_test;

  php代码  

复制代码 代码如下:

<?php
  //建立数据库连接
  $user = "scott"; //数据库用户名
  $password = "tiger"; //密码
  $conn_str = "tnsname"; //连接串(cstr : connection_string)
  $remote = true //是否远程连接
  if ($remote) {
  $conn = ocilogon($user, $password, $conn_str);
  }
  else {
  $conn = ocilogon($user, $password);
  }
  //设定绑定
  $id = 5; //准备用以绑定的php变量 id
  $name = ""; //准备用以绑定的php变量 name
  /** 调用存储过程的sql语句(sql_sp : sql_storeprocedure)
  * 语法:
  * begin 存储过程名([[:]参数]); end;
  * 加上冒号表示该参数是一个位置
  **/
  $sql_sp = "begin proc_test(:id, :name); end;";
  //parse
  $stmt = ociparse($conn, $sql_sp);
  //执行绑定
  ocibindbyname($stmt, ":id", $id, 16); //参数说明:绑定php变量$id到位置:id,并设定绑定长度16位
  ocibindbyname($stmt, ":name", $name, 30);
  //execute
  ociexecute($stmt);
  //结果
  echo "name is : $name<br>";
  ?>

时间: 2024-10-26 00:46:27

用PHP调用Oracle存储过程的方法_php技巧的相关文章

php调用mysql存储过程实例分析_php技巧

本文实例分析了php调用mysql存储过程的方法.分享给大家供大家参考.具体分析如下: Mysql存储过程创建语法,代码如下: CREATE PROCEDURE和CREATE FUNCTION : 复制代码 代码如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]])       [characteristic ...] routine_body   CREATE FUNCTION sp_name ([func_parameter[,...]])

C/C++封装库ocicpplib调用Oracle存储过程的方法

工作这么多年,一直使用Mysql, Oracle数据库没有接触过, 这次要使用C/C++语言来调用Oracle的存储过程, 懒得自己去看OCI的API了, 直接上网找别人封装的库, 最后发现了这个ocicpplib, 下载了看了一下, 还不错, 使用起来比较简单.下面就对我使用这个库来调用存储过程的例子说明一下, 对应调用其他的sql语句就不说了, 自己看demo, 很简单的. ocicpplib库的下载地址为 :http://ocicpplib.sourceforge.net/ 下面使用这个简

php计划任务之验证是否有多个进程调用同一个job的方法_php技巧

本文实例讲述了php计划任务之验证是否有多个进程调用同一个job的方法.分享给大家供大家参考,具体如下: 在使用计划任务的时候,公司有一次出现过2个进程跑同一个计划任务的情况,导致很多job都执行了2次,为了预防这种情况需要对linux的进程做一个限制,同一时间如果有进程在调用这个计划任务,那么就不允许另一个进程再进行调用了,下面是具体的代码. // $pro 方法名字 private function _verifyPsAux($pro) { $arrProcess = array( $pro

PHP使用NuSOAP调用Web服务的方法_php技巧

本文实例讲述了PHP使用NuSOAP调用Web服务的方法.分享给大家供大家参考.具体如下: Steps: 1. Download nusoap library from internet. 2. Pass parameter list in your $client->call and enjoy. <?php require_once('./lib/nusoap.php'); $client = new soapclientnusoap('http://www.devtrackn.com/w

java调用Oracle存储过程的方法实例_java

 1.测试添加数据的procedure 复制代码 代码如下: public void testProcedure() {        Connection con = getConnction();         // **1.测试添加数据的procedure          String procedure = "{call users_insert_proc(?,?,?,?) }";         CallableStatement cs = null;        tr

PHP MSSQL 存储过程的方法_php技巧

复制代码 代码如下: function generateDocCode() { $wf_id = self::WORKFLOW_ID; $doc_code = ""; $link = mssql_connect($this->cfg->db->params->host, $this->cfg->db->params->username, $this->cfg->db->params->password) or di

php在页面中调用fckeditor编辑器的方法_php技巧

刚才在论坛上看到一个童鞋分享的方法,感觉不是很全面,现在分享下我的! 复制代码 代码如下: PHP页面: /* 编辑器 */ include_once "../include/fckeditor/fckeditor.php";//把编辑器引进来 $editor = new FCKeditor('content');//表单项的名称 $editor->BasePath = "/fckeditor/";//编辑器所在目录 $editor->ToolbarSe

详解PHP实现异步调用的4种方法_php技巧

浏览器和服务器之间是通过 HTTP 协议进行连接通讯的.这是一种基于请求和响应模型的协议.浏览器通过 URL 向服务器发起请求,Web 服务器接收到请求,执行一段程序,然后做出响应,发送相应的html代码给客户端. 这就有了一个问题,Web 服务器执行一段程序,可能几毫秒就完成,也可能几分钟都完不成.如果程序执行缓慢,用户可能没有耐心等下去,就关闭浏览器了. 而有的时候,我们更本不关心这些耗时的脚本的返回结果,但却还要等他执行完返回,才能继续下一步. 那么有没有什么办法,只是简单的触发调用这些耗

jsp中调用Bean,然后在Bean中调用oracle存储过程

新手在写程序时,一定要胆大心细,而且要有耐心,不妥协,不懂就翻书,网上查资料,问朋友,坚决进行到底. 最近一直凭着ASP的知识在摸索中前进,一跑坎坷,自不用说了.言归正传. 建立一个登录系统,要求达到以下目的. 1.用户通过Bean来认证以及得到得到用户信息. 2.记录用户登录信息,如用户登录次数,最后登录时间. 3.记录操作日志. 未解决及疑惑的问题: 1.用户登录后的Session是否可以通过Bean来判断. 2.通过Bean调用ORACLE存储过程,返回select后的记录集. 操作步骤: