php连接oracle数据库及查询数据的方法

来源:互联网 发布:免费网站源码论坛 编辑:程序博客网 时间:2024/05/17 01:47
本文实例讲述了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);


  ?>
0 0
原创粉丝点击