网站地图    收藏   

主页 > php专栏 > php应用 >

php连接oracle数据库并查询数据sql - php高级应用

来源:自学PHP网    时间:2014-11-27 22:16 作者: 阅读:

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

php连接oracle数据库并查询数据sql

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是服务名,代码如下:

  1. $sql = "select * from table_exmaple" 
  2. $ora_test = oci_parse($conn,$sql);  //编译sql语句 
  3. oci_execute($ora_test,OCI_DEFAULT);  //执行 
  4. while($r=oci_fetch_row($ora_test))  //取回结果 
  5. echo $ora_test[0]; 
  6. echo "<BR>";   

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

oci_connect ( username, password , dbname )

例子,代码如下:

  1. <?php 
  2.  
  3. $conn = oci_connect('hr''hr''orcl'); // 建立连接 
  4.  
  5. if (!$conn) { 
  6.  
  7. $e = oci_error(); 
  8.  
  9. print htmlentities($e['message']); 
  10.  
  11. exit
  12.  
  13.  
  14. $query = 'SELECT * FROM DEPARTMENTS'// 查询语句 
  15.  
  16. $stid = oci_parse($conn$query); // 配置SQL语句,准备执行 
  17.  
  18. if (!$stid) { 
  19.  
  20. $e = oci_error($conn); 
  21.  
  22. print htmlentities($e['message']); 
  23.  
  24. exit
  25.  
  26.  
  27. $r = oci_execute($stid, OCI_DEFAULT); // 执行SQL。OCI_DEFAULT表示不要自动commit 
  28.  
  29. if(!$r) { 
  30.  
  31. $e = oci_error($stid); 
  32.  
  33. echo htmlentities($e['message']); 
  34.  
  35. exit
  36.  
  37.  
  38. // 打印执行结果 
  39.  
  40. print '<table border="1">'
  41.  
  42. while($row = oci_fetch_array($stid, OCI_RETURN_NULLS)) { 
  43.  
  44. print '<tr>'
  45.  
  46. foreach($row as $item) { 
  47.  
  48. print '<td>'.($item?htmlentities($item):' ').'</td>'
  49. //开源代码phpfensi.com 
  50.  
  51. print '</tr>'
  52.  
  53.  
  54. print '</table>'
  55.  
  56. oci_close($conn); 
  57.  
  58. ?>

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论