快速业务通道

PHP脚本数据库功能详解(上)

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-24
务器的主机名(也可以是IP)、数据库用户名和用户密码。函数返回值用于表示这个数据库连接。

  从这个命令可以看到,我们可以指定并非本机的机器名作为数据库服务器。这样,就为数据的异地存放、数据库的安全隔离提供了可能。外界用户往往具有WWW服务器的直接访问权限,如果数据库系统直接放置在WWW服务器上,就可能会带来安全隐患。而如果将数据库系统放置于一台防火墙后面的计算机上,PHP可以通过局域网访问数据库,而局域网内部的计算机对外部是不可见的。这样,就保证了数据库不受外来攻击的可能。

  函数前面的“@”符号,用于限制这个命令的出错信息的显示。如果函数调用出错,将执行or后面的语句。die( )函数表示向用户输出引号中的内容后,程序终止执行。这样做是为了防止数据库连接出错时,用户看到一堆莫名其妙的专业名词,而是提示定制的出错信息。不过在调试的时候,我们还是可以不要屏蔽出错信息,免得出错后,难以找到到底哪里有问题。

  (2) 数据库选择

  一个数据库系统可以包含多个数据库。在建立了和数据库服务器的连接后,我们就要告诉系统,我们将要用到的数据库是哪个。选择数据库的命令如下:

  〈?

  @mysql_select_db("ResumeDB",$LinkID) or die("选择数据库出错,可能是您指定的数据库不存在!");

  ?〉

  选择数据库时,要提供的参数是数据库的名称、和服务器连接号。

  当我们只使用一台数据库服务器时,$LinkID可以省略,系统自动查找最近的一个数据库连接然后使用它。但是,当你要实现大型站点的时候,必不可少的要遇到多主机、多数据库系统的情况。这时,数据库连接参数就不能省略了。

  (3) 数据库访问

  好了,我们已经建立了到数据库的连接,选定了数据库,接下了来的一切就是执行SQL语句了。SQL语句的易用而强大的功能,将完成我们绝大部分的数据库操作动作。

  我们可以首先向数据库里写入一条个人信息记录,然后把它显示出来。

  〈?

  $Name= "OpenBall"; //实际操作中,$Name、$Intro为从浏览器表单传来的值

  $Intro = "OpenBall的个人简介……";

  $query = "insert into Resume(Name,Intro) values(''$Name'', ''$Intro'')"; //生成SQL语句

  $result = @mysql_query("$query",$LinkID); //执行

  if(! $result)

   echo "数据插入失败!";

  $query= "select ID,Name,Intro from Resume"; //生成SQL语句

  $result = mysql_query($query,$LinkID); //执行,结果集保存到变量$result中

  $num= mysql_num_rows($result); //取得查询返回的记录行数

  if($num == 0)

  {

   echo "没有找到任何记录";

   exit();

  }

  while($row=mysql_fetch_array($result)) //取结果集的下一行数据到数组$row中

  {

   echo $row["ID"]." ".$row["Name"]." ".$row["Intro"]."〈br〉";

  //以字段名为索引访问数组变量的值

  }

  ?〉

  上面的操作,共执行了两次数据库操作。第一次为插入操作,第二次为查询操作。程序首先插入当前用户的一天记录,然后,显示所有数据库中的个人情况。

  (4)资源释放

  操作的最后,是释放结果集,释放结果集和数据库连接资源。

  〈?

  @mysql_free_result($result);

  @mysql_close($LinkID);

  ?〉

  如果在多个网页中都要频繁进行数据库访问,则可以建立与数据库服务器的持续连接来提高效率。因为每次与数据库服务器

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多
上一篇: 其他功能下一篇: 网络资源

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号