一个php处理oracle的,php oracle

本文目录一览:

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如何连接oracle数据库

首先你要在php.ini文件中找到

extension=php_oci8.dll 前面的注释符号“;”去掉,使php能够加载支持oracle的模块;

下面的代码是调试通过的,可直接使用的:

html

body

?php

$dbconn=OCILogon(“root”,”pass”,”(DESCRIPTION=(ADDRESS=(PROTOCOL =TCP)(HOST=远程IP)(PORT = 1521))(CONNECT_DATA =(SID=GZXNCW)))”);

if($dbconn!=false)

{

echo “连接成功”;

if(OCILogOff($dbconn)==true)

{

echo “关闭连接成功!”;

}

}

else

{

echo “连接失败”;

}

?

/body

/html

?php

$dbconn=oci_connect(“你的账号”,”你的密码”,”你的数据库名称”);//请把中文件设置为你的值;

$stmt=oci_parse($dbconn, “select * from scott.hallo”);

oci_execute($stmt, OCI_DEFAULT);

echo $conn.”—-selecting\n\n”;

while (oci_fetch($stmt))

{

echo ($conn.”[“.oci_result($stmt, “TEST”).”]\n\n”);

}

echo ($conn . “—-done\n\n”);

?

php 连接oracle数据库语句怎么写?

以系统为windowns为例,

1、先PHP.INI中的oracle扩展也开启了

PHP下php.ini(注意,有时是在windows目录)修改下下

其中的

extension=php_oci8.dll 去掉前面的“;”号

extension=php_oracle.dll 去掉前面的“;”号

把php_oci8.dll 、和php_oracle.dll 文件复制到windwos的system32下

2、系统中应当有安装ORCALE的系统,然后配制远程ORACLE的的监听。就是你能用你配好的ORACLE系统访问远程的数据库。

{例:

在ORACLE安装目录下找到tnsnames.ora,然后按下面的例子配置一下

BASETEST 命名=

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = XX.XX.XX.XX服务器IP地址)(PORT = 1521端口))

)

(CONNECT_DATA = (SERVICE_NAME = masprod 实例ID))

)

}

3.在你的PHP网页目录下写个测试连接的程序试试

?php

$dbconn=OCILogon(“username”,”pwd”,”(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = [远程服务器IP])(PORT = 1515))

)

(CONNECT_DATA =

(SERVICE_NAME = [数据库名字])

))”);

if($dbconn!=false)

{

echo “连接成功”;

if(OCILogOff($dbconn)==true)

{

echo “关闭连接成功!”;//=这里有问题

}

}

else

{

echo “连接失败”;

}

?

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 13:03
下一篇 2024-12-12 13:03

相关推荐

  • PHP和Python哪个好找工作?

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

    编程 2025-04-29
  • 如何将Oracle索引变成另一个表?

    如果你需要将一个Oracle索引导入到另一个表中,可以按照以下步骤来完成这个过程。 一、创建目标表 首先,需要在数据库中创建一个新的表格,用来存放索引数据。可以通过以下代码创建一个…

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

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

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

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

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

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

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

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

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

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

    编程 2025-04-27
  • Oracle Start With详解

    一、Start With概述 Start With是Oracle中连接查询的一个重要语句,它允许我们在一个递归查询中借助树结构进行查询,并且支持多种关联查询方式。通过Start W…

    编程 2025-04-25
  • Oracle Table函数详解

    一、概览 Table函数是Oracle中一种高级SQL操作,它可以将复杂的表达式转换成虚拟表来供查询使用。使用Table函数,可以作为输入多个行,返回一张临时表。Table函数可以…

    编程 2025-04-25
  • Oracle更新的全面阐述

    一、概述 Oracle是业界著名的关系型数据库,无论在企业级应用开发还是数据管理方面,都有着广泛的应用。更新是Oracle中一个非常重要的操作,它可以实现数据的修改、添加、删除等操…

    编程 2025-04-25

发表回复

登录后才能评论