php 连接oracle查询,php连接oracle数据库及查询数据实现分页的方法

这篇文章主要介绍了php连接oracle数据库及查询数据的方法,以实例形式较为详细的分析了php操作oracle数据库的使用技巧,具有一定的参考借鉴价值,需要的朋友可以参考下

本文实例讲述了php连接oracle数据库及查询数据的方法。分享给大家供大家参考。具体分析如下:

php有强大的功能不但可以支持mysql,mssql,mysqli之个我们还可以与oracle数据连接,要让php支持oracle非常的简单我们只要把php.ini中的;extention = php_oci8.dll分号去掉即可.

php支持oracle连接函数

php.ini文件中的配置,去掉 ;extention = php_oci8.dll,去掉前面的分号,重启apache就可以了,如果不行,我们再把php目录中的php_oci8.dll拷到windows系统的system32下面去吧.

oracle数据库建立链接,代码如下:

1.

代码如下:$conn = oci_connect('username','password',"(DEscriptION=(ADDRESS=(PROTOCOL =TCP)(HOST=192.168.1.100)(PORT = 1521))(CONNECT_DATA =(SID=test)))");

2.

代码如下:$conn = oci_connect('username','password','192.168.1.100/test');

3.Oracle 连接方法:

代码如下:set adocon=Server.Createobject("adodb.connection")

adocon.open"Driver={microsoft odbc for oracle};server=oraclesever.world;uid=admin;pwd=pass;"

4.Oracle OLE DB 连接方法:

代码如下:set adocon=Server.Createobject("adodb.connection")

adocon.open"Provider=OraOLEDB.Oracle;data source=dbname;user id=admin;password=pass;"

有的时候第一种方式不行,使用第二种,里面的几个参数分别是用户名、密码、oracle服务地址,其中test是服务名,代码如下:

代码如下:$sql = "select * from table_exmaple"

$ora_test = oci_parse($conn,$sql); //编译sql语句

oci_execute($ora_test,OCI_DEFAULT); //执行

while($r=oci_fetch_row($ora_test)) //取回结果

{

echo $ora_test[0];

echo "
";

}

看个完整的例子,如果PHP版本>5.0,那么使用下面的函数:

代码如下:oci_connect ( username, password , dbname )

例子,代码如下:

代码如下:<?php

$conn = oci_connect('hr', 'hr', 'orcl'); // 建立连接

if (!$conn) {

$e = oci_error();

print htmlentities($e['message']);

exit;

}

$query = 'SELECT * FROM DEPARTMENTS'; // 查询语句

$stid = oci_parse($conn, $query); // 配置SQL语句,准备执行

if (!$stid) {

$e = oci_error($conn);

print htmlentities($e['message']);

exit;

}

$r = oci_execute($stid, OCI_DEFAULT); // 执行SQL。OCI_DEFAULT表示不要自动commit

if(!$r) {

$e = oci_error($stid);

echo htmlentities($e['message']);

exit;

}

// 打印执行结果

print '

while($row = oci_fetch_array($stid, OCI_RETURN_NULLS)) {

print '

';

foreach($row as $item) {

print '

'.($item?htmlentities($item):' ').'';

}

print '

';

}

print '

';

oci_close($conn);

?>

下面是分页示例程序,看起来可能比较繁琐,但其实你只要用一下就会发现,一切原来如此简单

example.php<?php

$conn = ociplogon("test","123456","test123");

include_once "pager.inc.php";

?><?php

/** 分页测试开始 */

// {{{ 初始分页对象

$pager = new pager();

/** 将 select id,name,age from test where age>20 order by id desc 拆分 */

$sqlArr = array('conn' => $conn, // 数据库连结

'fields' => " id,name,age ", // 查询主语句

'table' => "test", // 表名

'condition' => " age>20 ", // 查询条件

'order' => " order by id desc " // 排序方式

);

if (!$pager->listn($sqlArr,10,$page)) // 每页显示10条

{

$pager->errno = 10;

die($pager->errmsg());

}

//}}}

// {{{ 数据显示

for( $i = 0; $i < count($pager->result); $i++)

{

$tmp = $pager->result[$i];

echo " id:".$tmp['ID']."
";

echo " name:".$tmp['NAME']."
";

echo " age:".$tmp['AGE']."


"

}

// }}}

// {{{ 显示翻页链结

echo $pager->page. " / ".$pager->totalpage." 共 ".$pager->total. "条记录 ";

if ($pager->prev != 0)

echo " prev.">上一页 ";

else

echo " 上一页 ";

if ($pager->next != 0)

echo " next.">下一页 ";

else

echo " 下一页 ";

// }}}

?>

@OCILogoff($conn)?>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值