php使用存储过程,php存储过程应用场景

本文目录一览:

php调用mysql存储过程,如何实现。 我的代码如下:

mysql存储过程返回2个资源,第一个是执行信息,第二个是存储过程返回结果。

mysql_*系列函数无法获取超过1个资源,需使用mysqli或PDO代替。

PDO:

        $stmt = $db-prepare(“CALL pro_rb_save(?,?,@return_msg);”);  

        $stmt-bindParam(1, $a);

        $stmt-bindParam(2, $b);

        $stmt-execute ();

        $outputArray = $db-query(“select @return_msg”)-fetch(PDO::FETCH_ASSOC);

        

        var_export($return_msg);

php调用oracle存储过程与函数

对于存储过程的源代码,开始都需要先定义接受的参数,例如:

PROCEDURE edit_entry(

status_out OUT NUMBER,

status_msg_out OUT VARCHAR2,

id_inout IN OUT INTEGER,

title_in IN VARCHAR2,

text_out OUT CLOB,

categories_in IN list_of_numbers

);

从 PHP 中调用存储过程 对于要从 PHP 中执行以调用过程的 SQL 语句而言,您将通常在 Oracle BEGIN …END; 块(称作匿名块)中嵌入调用。例如:

?php

// etc.

//$sql = ‘BEGIN sayHello(:name, :message); END;’;

//然后,通过调用 oci_bind_by_name() 将参数绑定到 PHP 变量。 如果使用以下 DDL 语句定义了 sayHello

//:

//CREATE OR REPLACE PROCEDURE

//sayHello (name IN VARCHAR2, greeting OUT VARCHAR2)

//AS

//BEGIN

//greeting := ‘Hello ‘ || name;

//END;

//

//注意,您可以使用 SQL*Plus 命令行运行上面的语句。将该语句保存到文件 (SAYHELLO.SQL)。接下来,使用

//SQL*Plus 登录:

 // $ sqlplus username@SID

 // 然后,使用 START 命令创建该过程:

 // SQL START /home/username/SAYHELLO.SQL

 // 以下 PHP 脚本调用该过程:

$conn = oci_connect(‘SCOTT’,’TIGER’) or die;

$sql = ‘BEGIN sayHello(:name, :message); END;’;

$stmt = oci_parse($conn,$sql);

// Bind the input parameter

oci_bind_by_name($stmt,’:name’,$name,32);

// Bind the output parameter

oci_bind_by_name($stmt,’:message’,$message,32);

// Assign a value to the input

$name = ‘Harry’;

oci_execute($stmt);

// $message is now populated with the output value

print “$message\n”;

?

调用程序包中的过程时,将使用句号来分隔程序包名称与过程名称。 可以使用以下语句指定 blog 程序包:

CREATE OR REPLACE PACKAGE blog AS

TYPE cursorType IS REF CURSOR RETURN blogs%ROWTYPE;

/*

Fetch the latest num_entries_in from the blogs table, populating

entries_cursor_out with the result

*/

PROCEDURE latest(

num_entries_in IN NUMBER,

entries_cursor_out OUT cursorType

);

/*

Edit a blog entry.If id_inout is NULL, results in an INSERT, otherwise

attempts to UPDATE the existing blog entry. status_out will have the value

1 on success, otherwise a negative number on failure with status_msg_out

containing a description

categories_in is a collection where list_of_numbers is described by

TYPE list_of_numbers AS VARRAY(50) OF NUMBER;

*/

PROCEDURE edit_entry(

status_out OUT NUMBER,

status_msg_out OUT VARCHAR2,

id_inout IN OUT INTEGER,

title_in IN VARCHAR2,

text_out OUT CLOB,

categories_in IN list_of_numbers

);

END blog;

/

php 什么时候用mysql 存储过程

实现原理

首先,需要知道怎么写mysql存储过程,了解mysq存储过程语言,

其次,使用mysql工具创建存储过程。

最后,通过mysql_query()函数执行mysql变量的设置和mysql存储过程及返回值。

具体代码如下:

mysql存储过程代码

create procedure pro_name(user_id int)

begin

………

end

2. PHP代码

$host = “localhost”;

$user = “root”;

$password = “232412”;

$db = “user_db”;

$dblink = mysql_connect($host,$user,$password)or die(“can’t connect to mysql”);

mysql_select_db($db,$dblink)or die(“can’t select user_db”);

$user_id = 1;

$res = mysql_query(“set @a=$user_id”,$dblink);

$res = mysql_query(“call pro_name(@a)”,$dblink);

php存储过程调用实例代码

复制代码

代码如下:

//比如要调用的存储过程为gxtj(a,b)

$db=new

mysqli(“localhost”,”ssss”,”aaaaa”,”bbbb”);

mysqli_query($db,”SET

NAMES

utf8″);

$result=$db-query(“call

gxtj($year,$jd)”);

//

gxtj是mysql的存储过程名称

[color=gray][/color]

while(

$row

=

$result-fetch_array(MYSQLI_ASSOC))

//完成从返回结果集中取出一行

{

while

($key=key($row)){

//依次取得字段名

$value=current($row);

//依次取得字段值

}

}

实例一:无参的存储过程

复制代码

代码如下:

$conn

=

mysql_connect(‘localhost’,’root’,’root’)

or

die

(“数据连接错误!!!”);

mysql_select_db(‘test’,$conn);

$sql

=

create

procedure

myproce()

begin

INSERT

INTO

user

(id,

username,

sex)

VALUES

(NULL,

‘s’,

‘0’);

end;

“;

mysql_query($sql);//创建一个myproce的存储过程

$sql

=

“call

test.myproce();”;

mysql_query($sql);//调用myproce的存储过程,则数据库中将增加一条新记录。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/183944.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-25 05:50
下一篇 2024-11-25 05:51

相关推荐

  • PHP和Python哪个好找工作?

    PHP和Python都是非常流行的编程语言,它们被广泛应用于不同领域的开发中。但是,在考虑择业方向的时候,很多人都会有一个问题:PHP和Python哪个好找工作?这篇文章将从多个方…

    编程 2025-04-29
  • Unity3D 创建没有 Terrain Tile 的场景

    这篇文章将会介绍如何在 Unity3D 中创建一个没有 Terrain Tile 的场景,同时也让读者了解如何通过编程实现这个功能。 一、基础概念 在 Unity3D 中,Terr…

    编程 2025-04-29
  • PHP怎么接币

    想要在自己的网站或应用中接受比特币等加密货币的支付,就需要对该加密货币拥有一定的了解,并使用对应的API进行开发。本文将从多个方面详细阐述如何使用PHP接受加密货币的支付。 一、环…

    编程 2025-04-29
  • Python强制转型的实现方法和应用场景

    本文主要介绍Python强制转型的实现方法和应用场景。Python强制转型,也叫类型转换,是指将一种数据类型转换为另一种数据类型。在Python中,强制转型主要通过类型构造函数、转…

    编程 2025-04-29
  • 使用PHP foreach遍历有相同属性的值

    本篇文章将介绍如何使用PHP foreach遍历具有相同属性的值,并给出相应的代码示例。 一、基础概念 在讲解如何使用PHP foreach遍历有相同属性的值之前,我们需要先了解几…

    编程 2025-04-28
  • PHP获取301跳转后的地址

    本文将为大家介绍如何使用PHP获取301跳转后的地址。301重定向是什么呢?当我们访问一个网页A,但是它已经被迁移到了另一个地址B,此时若服务器端做了301重定向,那么你的浏览器在…

    编程 2025-04-27
  • Access执行按钮的实现方法及应用场景

    本文将详细介绍Access执行按钮的实现方法及其在实际应用场景中的使用方法。 一、创建Access执行按钮的方法 在Access中,创建执行按钮的方法非常简单。只需要按照以下步骤进…

    编程 2025-04-27
  • PHP登录页面代码实现

    本文将从多个方面详细阐述如何使用PHP编写一个简单的登录页面。 1. PHP登录页面基本架构 在PHP登录页面中,需要包含HTML表单,用户在表单中输入账号密码等信息,提交表单后服…

    编程 2025-04-27
  • 用Python绘制樱花飘落场景

    本文介绍如何用Python绘制一个带有樱花飘落特效的场景,通过本文的学习,您将了解到如何使用Python的turtle库来绘制图形,以及如何运用数学和物理知识来实现樱花的飘落效果。…

    编程 2025-04-27
  • PHP与Python的比较

    本文将会对PHP与Python进行比较和对比分析,包括语法特性、优缺点等方面。帮助读者更好地理解和使用这两种语言。 一、语法特性 PHP语法特性: <?php // 简单的P…

    编程 2025-04-27

发表回复

登录后才能评论