4.与数据库的连接


Posted in PHP onOctober 09, 2006

4.据库连接 

通过PHP你可以轻松的连接到数据库,请求数据并将其显示在你的web站点中,甚至修改数据库中的数据。MySQL是一种很流行的数据库,并且在互联网中有许多有关PHP与MySQL的教程。MySQL是免费的,这一点也许就吸引了不少人。由于其广泛应用,我就不想在这里赘述MySQL的使用方法了。Oracle被大量在企业应用中采用,因此我们就利用Oracle来介绍PHP与数据库的连接。我们当然不会提及Oracle数据库的设计原理,原因是这已经超出了我们的讨论范围。

PHP提供了两套函数与Oracle连接,分别是ORA_和OCI函数。其中ORA_函数略显陈旧。OCI函数更新据说更好一些。两者的使用语法几乎相差无几。如前所述,你的PHP安装选项应该可以支持两者的使用。

想获得更多有关在Microsoft Windows平台上安装支持PHP3的Apache服务器的知识以及更多有关Oracle数据库的知识,请查阅以下URL:www.csoft.net/~vsbabu/articles/oraphp.html。

4.1 连接

<? 

if ($conn=Ora_Logon("user@TNSNAME","password")) 

{

echo "<B>SUCCESS ! Connected to database<B>\n";

else 

{

echo "<B>Failed :-( Could not connect to database<B>\n";

}

Ora_Logoff($conn);

phpinfo();

?>

以上代码使用TNSNAME(在你的tnsnames.ora文件中指明)定义的Oracle数据库名称、用户名称和密码连接数据库。在成功连接的基础上,ora_logon函数返回一个非零的连接ID并储存在变量$conn中。

4.2 查询

假设与数据库已经连接就绪,下面我们就来实际的应用对数据库的查询。下面的代码演示了一个连接并查询的典型例子:

<?

/*

* 连接数据库并执行查询

*/

function printoraerr($in_cur)

{

// 检查Oracle是否出错

// 如果存在错误则显示

// 当指针被激活时每次请求Oracle后调用该函数

if(ora_errorcode($in_cur))

echo "Oracle code - ".ora_error($in_cur)."\n";

return;

}

/** 主程序 */

if (!($conn=ora_logon("user@TNSNAME","password"))) 

{

echo "Connection to database failed\n";

exit;

}

echo "Connected as connection - <b>$conn</b><br>\n";

echo "Opening cursor ...<br>\n";

$cursor=ora_open($conn); printoraerr($cursor);

echo "Opened cursor - <b>$cursor</b><br>\n";

$qry="select user,sysdate from dual";

echo "Parsing the query <b>$qry</b> ...<br>\n";

ora_parse($cursor,$qry,0); printoraerr($cursor);

echo "Query parsed <br>\n";

echo "Executing cursor ...<br>\n";

ora_exec($cursor); printoraerr($cursor);

echo "Executed cursor<br>\n";

echo "Fetching cursor ...<br>\n";

while(ora_fetch($cursor))

{

$user=ora_getcolumn($cursor,0); printoraerr($cursor);

$sysdate=ora_getcolumn($cursor,1); printoraerr($cursor);

echo " row = <B>$user, $sysdate </B><br>\n";

}

echo "Fetched all records<br>\n";

echo "Closing cursor ...<br>\n";

ora_close($cursor);

echo "Closed cursor<br>\n";

echo "Logging off from oracle... <br>\n";

ora_logoff($conn);

echo "Logged off from oracle <br>\n";

?>

(译者注:以上代码段缺少注释,请读者参考PHP Manual的Oracle数据库函数部分)

4.3 显示结果

以下代码演示了怎样查询数据库并将结果输出:

<?

function printoraerr($in_cur, $conn)

{

// 检查Oracle是否出错

// 如果存在错误则显示

// 当指针被激活时每次请求Oracle后调用该函数

// If it encountered an error, we exit immediately

if(ora_errorcode($in_cur)) 

{

echo "Oracle code - ".ora_error($in_cur)."<br>n";

ora_logoff($conn);

exit;

}

return;

}

function exequery($w_qry,$conn) 

{

$cursor=ora_open($conn); printoraerr($cursor,$conn);

ora_parse($cursor,$w_qry,0); printoraerr($cursor,$conn);

ora_exec($cursor); printoraerr($cursor,$conn);

$numrows=0;

$w_numcols=ora_numcols($cursor);

// 显示头部

echo "

<TABLE WIDTH=\"100%\" BORDER=\"0\" CELLSPACING=\"1\" 
CELLPADDING=\"2\">

<TR>\n";

for ($i=0;$i<$w_numcols;$i++)

{

$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";

echo "\t<TH VALIGN=TOP ALIGN=$align>".ora_columnname($cursor,$i)."</TH>\n";

}

echo "</TR>\n";

while(ora_fetch($cursor))

{

echo "<TR>\n";

for ($i=0;$i<$w_numcols;$i++) 

{

$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";

if(ora_columntype($cursor,$i)=="LONG")

echo "<TD VALIGN=TOP ALIGN=$align><PRE>".

ora_getcolumn($cursor,$i)."</PRE></TD>\n";

else

echo "<TD VALIGN=TOP ALIGN=$align>".ora_getcolumn($cursor,$i)."</TD>\n";

printoraerr($cursor,$conn);

}

$numrows++;

echo "</TR>\n";

}

if ($numrows==0)

echo "<TR><TD COLSPAN=\"$w_numcols\"><B>Query 
returned no records

</B></TD></TR>\n";

else 

{

echo "<TR>\n";

echo "<TH COLSPAN=\"".($w_numcols-1)."\" ALIGN=RIGHT>Count</TH>\n";

echo "<TH ALIGN=RIGHT>$numrows</TH>\n";

echo "</TR>\n";

}

echo "</TABLE>\n";

ora_close($cursor);

return;

}

// 主程序

if(!($conn=ora_logon("user@SID","password"))) 

{

echo "Error: Cannot connect to database\n";

exit;

}

$qry="SELECT

deptno \"Dept\"

,empno \"Emp\"

,empnm \"Name\"

,salary \"Salary\"

FROM

employee

ORDER BY 1,2";

exequery($qry);

ora_logoff($conn);

?>

(译者注:以上代码段缺少注释,请读者参考PHP Manual的Oracle数据库函数部分)

4.4 基于HTTP的Oracle登录

将以下代码加在PHP页面代码之前以确认Oracle登录。注意你必须正确设定$ SID。

<? 

if(!isset($PHP_AUTH_USER)) 

{

Header("WWW-authenticate: basic realm=\"$SID\"");

Header("HTTP/1.0 401 Unauthorized");

$title="Login Instructions";

echo "<blockquote>

You are not authorized to enter the site

</blockquote> \n";

exit;

else 

{

if (!($conn=ora_logon("$PHP_AUTH_USER@$SID",$PHP_AUTH_PW))) 

{

Header("WWW-authenticate: basic realm=\"$SID\"");

Header("HTTP/1.0 401 Unauthorized");

$title="Login Instructions";

echo "<blockquote>

You are not authorised to enter the site

</blockquote> \n";

exit;

}

}

?>

PHP 相关文章推荐
php开发环境配置记录
Jan 14 PHP
深入PHP FTP类的详解
Jun 13 PHP
三种php连接access数据库方法
Nov 11 PHP
php中require和require_once的区别说明
Feb 27 PHP
ThinkPHP中的三大自动简介
Aug 22 PHP
PHP调试函数和日志记录函数分享
Jan 31 PHP
Symfony2学习笔记之插件格式分析
Mar 17 PHP
完美解决phpdoc导出文档中@package的warning及Error的错误
May 17 PHP
PHP微信支付开发实例
Jun 22 PHP
php和vue配合使用技巧和方法
May 09 PHP
Laravel 6 将新增为指定队列任务设置中间件的功能
Aug 06 PHP
Laravel基础-关于引入公共文件的两种方式
Oct 18 PHP
利用PHP创建动态图像
Oct 09 #PHP
ip签名探针
Oct 09 #PHP
PHP默认安装产生系统漏洞
Oct 09 #PHP
把PHP安装为Apache DSO
Oct 09 #PHP
PHP4中实现动态代理
Oct 09 #PHP
phpmyadmin操作流程
Oct 09 #PHP
一个用于MySQL的PHP XML类
Oct 09 #PHP
You might like
虹吸壶煮咖啡26个注意事项
2021/03/03 冲泡冲煮
php实现比较两个字符串日期大小的方法
2015/05/12 PHP
在openSUSE42.1下编译安装PHP7 的方法
2015/12/24 PHP
Joomla调用系统自带编辑器的实现方法
2016/05/05 PHP
Yii2.0使用阿里云OSS的SDK上传图片、下载、删除图片示例
2017/09/20 PHP
PHP面向对象程序设计子类扩展父类(子类重新载入父类)操作详解
2019/06/14 PHP
使用Git实现Laravel项目的自动化部署
2019/11/24 PHP
javascript 关于# 和 void的区别分析
2009/10/26 Javascript
jQuery EasyUI 开源插件套装 完全替代ExtJS
2010/03/24 Javascript
jQuery Uploadify 上传插件出现Http Error 302 错误的解决办法
2015/12/12 Javascript
asp.net+jquery.form实现图片异步上传的方法(附jquery.form.js下载)
2016/05/05 Javascript
js 判断各种数据类型的简单方法(推荐)
2016/08/29 Javascript
js实现表单及时验证功能 用户信息立即验证
2016/09/13 Javascript
移动端点击态处理的三种实现方式
2017/01/12 Javascript
webpack构建react多页面应用详解
2017/09/15 Javascript
浅谈Angular 的变化检测的方法
2018/03/01 Javascript
Vue中使用ElementUI使用第三方图标库iconfont的示例
2018/10/11 Javascript
js的新生代垃圾回收知识点总结
2019/08/22 Javascript
openlayers4实现点动态扩散
2020/08/17 Javascript
Python字符串的encode与decode研究心得乱码问题解决方法
2009/03/23 Python
Python程序员鲜为人知但你应该知道的17个问题
2014/06/04 Python
python实现多线程抓取知乎用户
2016/12/12 Python
Python中安装easy_install的方法
2018/11/18 Python
Python pandas实现excel工作表合并功能详解
2019/08/29 Python
Tensorflow中k.gradients()和tf.stop_gradient()用法说明
2020/06/10 Python
美国知名奢侈美容品牌零售商:Cos Bar
2017/04/21 全球购物
留学自荐信的技巧
2013/10/17 职场文书
中学家长会邀请函
2014/02/03 职场文书
股份合作协议书
2014/04/12 职场文书
雏鹰争章活动总结
2014/05/09 职场文书
整顿机关作风心得体会
2014/09/10 职场文书
村党的群众路线教育实践活动工作总结
2014/10/25 职场文书
2014年煤矿安全工作总结
2014/12/04 职场文书
2016年度优秀辅导员事迹材料
2016/02/26 职场文书
2016年村干部公开承诺书(公开承诺事项)
2016/03/25 职场文书
公文写作:工伤事故分析报告怎么写?
2019/11/05 职场文书