时间:2021-07-01 10:21:17 帮助过:40人阅读
本文实例讲述了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 "<BR>"; }
看个完整的例子,如果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 '<table border="1">'; while($row = oci_fetch_array($stid, OCI_RETURN_NULLS)) { print '<tr>'; foreach($row as $item) { print '<td>'.($item?htmlentities($item):' ').'</td>'; } print '</tr>'; } print '</table>'; 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']."<br>"; echo " name:".$tmp['NAME']."<br>"; echo " age:".$tmp['AGE']."<hr>" } // }}} // {{{ 显示翻页链结 echo $pager->page. " / ".$pager->totalpage." 共 ".$pager->total. "条记录 "; if ($pager->prev != 0) echo " <a href=$PHP_SELF?page=".$pager->prev.">上一页</a> "; else echo " 上一页 "; if ($pager->next != 0) echo " <a href=$PHP_SELF?page=".$pager->next.">下一页</a> "; else echo " 下一页 "; // }}} ?> <?@OCILogoff($conn)?>
以上就是php连接oracle数据库及查询数据实现分页的方法的详细内容,更多请关注Gxl网其它相关文章!