首页 后端开发 php教程 php数据库连接_PHP教程

php数据库连接_PHP教程

Jul 21, 2016 pm 04:05 PM
php web 可以 数据 数据库 显示 请求 轻松 连接 通过

通过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  "SUCCESS  !  Connected  to  database\n";   
}     
else     
{   
echo  "Failed  :-(  Could  not  connect  to  database\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  -  $conn
\n";   
echo  "Opening  cursor  ...
\n";   
$cursor=ora_open($conn);  printoraerr($cursor);   
echo  "Opened  cursor  -  $cursor
\n";   
$qry="select  user,sysdate  from  dual";   
echo  "Parsing  the  query  $qry  ...
\n";   
ora_parse($cursor,$qry,0);  printoraerr($cursor);   
echo  "Query  parsed   
\n";   
echo  "Executing  cursor  ...
\n";   
ora_exec($cursor);  printoraerr($cursor);   
echo  "Executed  cursor
\n";   
echo  "Fetching  cursor  ...
\n";   
while(ora_fetch($cursor))   
{   
$user=ora_getcolumn($cursor,0);  printoraerr($cursor);   
$sysdate=ora_getcolumn($cursor,1);  printoraerr($cursor);   
echo  "  row  =  $user,  $sysdate   
\n";   
}   
echo  "Fetched  all  records
\n";   
echo  "Closing  cursor  ...
\n";   
ora_close($cursor);   
echo  "Closed  cursor
\n";   
echo  "Logging  off  from  oracle...   
\n";   
ora_logoff($conn);   
echo  "Logged  off  from  oracle   
\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)."
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  "   

  \n";   
for  ($i=0;$i{   
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";   
echo  "\t  ".ora_columnname($cursor,$i)."  \n";   
}   
echo  "   
\n";   
while(ora_fetch($cursor))   
{   
echo  "  \n";   
for  ($i=0;$i{   
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";   
if(ora_columntype($cursor,$i)=="LONG")   
echo  "  ".
ora_getcolumn($cursor,$i)."
  \n";   
else   
echo  "  ".ora_getcolumn($cursor,$i)."  \n";   
printoraerr($cursor,$conn);   
}   
$numrows++;   
echo  "   
\n";   
}   
if  ($numrows==0)   
echo  "  Query  returned  no  records   

\n";   
else     
{   
echo  "  \n";   
echo  "  Count  \n";   
echo  "  $numrows  \n";   
echo  "   
\n";   
}   
echo  "  \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  "


You  are  not  authorized  to  enter  the  site   

\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  "

You  are  not  authorised  to  enter  the  site   

\n";   
exit;   
}   
}   
?>   

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/315543.htmlTechArticle通过PHP你可以轻松的连接到数据库,请求数据并将其显示在你的web站点中,甚至修改数据库中的数据。MySQL是一种很流行的数据库,并且在互...
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
<🎜>掩盖:探险33-如何获得完美的色度催化剂
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1677
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
甲骨文在商业世界中的作用 甲骨文在商业世界中的作用 Apr 23, 2025 am 12:01 AM

Oracle不仅是数据库公司,还是云计算和ERP系统的领导者。1.Oracle提供从数据库到云服务和ERP系统的全面解决方案。2.OracleCloud挑战AWS和Azure,提供IaaS、PaaS和SaaS服务。3.Oracle的ERP系统如E-BusinessSuite和FusionApplications帮助企业优化运营。

如果session_start()被多次调用会发生什么? 如果session_start()被多次调用会发生什么? Apr 25, 2025 am 12:06 AM

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

IIS和PHP的兼容性:深度潜水 IIS和PHP的兼容性:深度潜水 Apr 22, 2025 am 12:01 AM

IIS和PHP可以兼容,通过FastCGI实现。1.IIS通过配置文件将.php文件请求转发给FastCGI模块。2.FastCGI模块启动PHP进程处理请求,提高性能和稳定性。3.实际应用中需注意配置细节、错误调试和性能优化。

REDIS:了解其架构和目的 REDIS:了解其架构和目的 Apr 26, 2025 am 12:11 AM

Redis是一种内存数据结构存储系统,主要用作数据库、缓存和消息代理。它的核心特点包括单线程模型、I/O多路复用、持久化机制、复制与集群功能。 Redis在实际应用中常用于缓存、会话存储和消息队列,通过选择合适的数据结构、使用管道和事务、以及进行监控和调优,可以显着提升其性能。

作曲家:通过AI的帮助开发PHP 作曲家:通过AI的帮助开发PHP Apr 29, 2025 am 12:27 AM

AI可以帮助优化Composer的使用,具体方法包括:1.依赖管理优化:AI分析依赖关系,建议最佳版本组合,减少冲突。2.自动化代码生成:AI生成符合最佳实践的composer.json文件。3.代码质量提升:AI检测潜在问题,提供优化建议,提高代码质量。这些方法通过机器学习和自然语言处理技术实现,帮助开发者提高效率和代码质量。

session_start()函数的意义是什么? session_start()函数的意义是什么? May 03, 2025 am 12:18 AM

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

H5:HTML5的关键改进 H5:HTML5的关键改进 Apr 28, 2025 am 12:26 AM

HTML5带来了五个关键改进:1.语义化标签提升了代码清晰度和SEO效果;2.多媒体支持简化了视频和音频嵌入;3.表单增强简化了验证;4.离线与本地存储提高了用户体验;5.画布与图形功能增强了网页的可视化效果。

PHP和IIS:让他们一起工作 PHP和IIS:让他们一起工作 Apr 21, 2025 am 12:06 AM

在IIS上配置和运行PHP需要以下步骤:1)下载并安装PHP,2)配置IIS并添加FastCGI模块,3)创建并设置应用池,4)创建网站并绑定到应用池。通过这些步骤,你可以在Windows服务器上轻松部署PHP应用,并通过配置扩展和优化性能来提升应用的稳定性和效率。

See all articles