知识大全 用PHP连mysql和oracle数据库性能比较

Posted 函数

篇首语:愁人苦夜长,志士惜日短。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 用PHP连mysql和oracle数据库性能比较相关的知识,希望对你有一定的参考价值。

用PHP连mysql和oracle数据库性能比较  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  使用PHP编程的最大好处是学习这种编程语言非常容易以及其丰富的库 即使对需要使用的函数不是十分了解 我们也能够猜测出如何完成一个特定的任务     尽管PHP非常简单易学 但我们仍然需要花费一点时间来学习PHP的一些编程技巧 尤其是与性能和内存占用相关的技巧 在PHP中 有许多小技巧能够使我们减少内存的占用 并提高应用程序的性能 在本篇文章中 我们将对PHP应用程序的分析 如何改变脚本代码以及比较优化前后的各种参数值进行简要的介绍     通过在程序中设置计时的程序 并反复执行这些代码 我们可以获得有关程序执行速度的一组数据 这些数据可以可以用来发现程序中的瓶颈 以及如何进行优化 提高应用程序的性能     也许读者曾经听说过PEAR库吧 我们将使用PEAR库创建在分析时需要使用的例子 这也是对现有的代码进行分析的最简单的方法 它使我们无需使用商用产品就能对代码进行分析     我们要使用的库的名字是PEAR::Benchmark 它对于对代码进行分析和性能测试非常有用 这个库提供一个名字为Benchmark_Timer()的类 能够记录一个函数调用和下一个函数调用之间的时间 在对代码的性能进行测试时 我们可以得到一个详细的脚本执行结果 它非常简单 如下所示     include_once( Benchmark/Timer php );  $bench = new Benchmark_Timer;    $bench >start();  $bench >setMarker( Start of the script );    // 现在处于睡眠状态几分钟  sleep( );    $bench >stop();    // 从计时器中获得分析信息  print_r($bench >getProfiling());  ?>    上面代码执行后的输出如下所示     Array  (  [ ] => Array  (  [name] => Start  [time] =>   [diff] =>   [total] =>   )    [ ] => Array  (  [name] => Start of the script  [time] =>   [diff] => E   [total] => E   )    [ ] => Array  (  [name] => Stop  [time] =>   [diff] =>   [total] =>   )    )    上面的数字似乎是一组杂乱无章的数字 但如果程序的规模更大 这些数字就十分地有用了     也许广大读者也能猜测到 数组的第一个表目是实际调用Benchmark_Timer()类的方法 例如    $bench >start() $bench >setMarker()和$bench >stop() 与这些表目有关的数字是相当简单的   现在我们来仔细地研究这些数字   [ ] => Array    (    [name] => Start    [time] =>     [diff] =>     [total] =>     )    time表目指的是何时对Benchmark_Timer()的start()方法调用的UNIX的timestamp diff表目表示这次调用和上次调用之间的时间间隔 由于这里没有上一次 因此显示出了一个破折号 total表目指的是自测试开始到这一特定的调用之前代码运行的总的时间 下面我们来看看下一个数组的输出     [ ] => Array    (    [name] => Start of the script    [time] =>     [diff] => E     [total] => E     )    从上面的数字我们可以看出 在调用$bench >start()之后 程序运行了 E 秒(也就是     秒)后开始调用$bench >setMarker( )      一次真实的性能测试经历  尽管上面的例子不错 但在对于决定如何优化你的站点代码设计方面 它真的不能算是一个好例子 下面我将用我自己作为网站技术人员的一段亲身经历来说明如何解决性能方面存在的问题     我并不大理解网站使用的代码 因为它是根据特殊的需求 历经多年开发而成的━━其中的一个模块包括网站转换代码 另一个模块记录网站的使用情况 其他的模块也各有各的作用 我和网站的主要开发者都意识到网站的代码需要优化 但又不清楚问题出在哪儿     为了尽快地完成任务 我开始研究网站的主要脚本代码 并在全部脚本代码以及其包含文件中添加了一些    $bench >setMarker()命令 然后分析$bench >getProfiling()的输出 并对得到的结果大吃一惊 原来问题出在一个与获得特定语言名字(例如en代表english)的转换代码的函数调用中 该函数在每个页面上都会被使用数百次 每次调用该函数时 脚本代码都会对一个MySQL数据库进行查询 从一个数据库表中获得真正的语言名字     于是我们这一类的信息创建了一个缓冲系统 经过短短 天时间的工作 我们使系统的性能得到了很大的提高 第一周内页面的浏览量也因此而增加了 % 当然了 这只是一个有关分析代码能够提高互联网应用或互联网网站性能的例子      性能测试函数调用  在分析一个脚本或网页(以及其包含文件)时 尽管Benchmark_Timer()特别有用 但它并不科学 因为要获得分析的数据我们必须多次加载脚本 而且它也不是针对某个类或函数调用的     PEAR::Benchmark库中的另一个被称作Benchmark_Iterator的类能够很好地解决这一个问题 它能够针对特定的函数或类的方法 显示其分析信息 它的用途是能够能够从测试中获得一致的结果 因为我们知道 如果运行一段脚本一次 其运行时间为 秒 并不意味着它每次的运行时间总是 秒     In any case let s see some examples:    // 连接数据库的代码  include_once( DB php );  $dsn = array(   phptype => mysql    hostspec => localhost    database => database_name    username => user_name    password => password   );  $dbh = DB::connect($dsn);    function getCreatedDate($id)    global $dbh;    >$stmt = SELECT created_date FROM users WHERE id=$id ;  // 在这里使用PEAR::DB  $created_date = $dbh >getOne($stmt);  if ((PEAR::isError($created_date)) ||  (empty($created_date)))   return false;   else   return $created_date;        include_once Benchmark/Iterate php ;  $bench = new Benchmark_Iterate;    // 运行getDate函数 次  $bench >run( getCreatedDate );    // 打印分析信息  print_r($bench >get());  ?>    运行上面的代码能够产生与下面相似的结果     Array  (  [ ] =>   [ ] =>   [ ] =>   [ ] =>   [ ] =>   [ ] =>   [ ] =>   [ ] =>   [ ] =>   [ ] =>   [mean] =>   [iterations] =>   )    上面的这些数字很好理解 mean条目表示getCreatedDate()函数 次运行的平均时间 在进行实际测试时 应该至少运行 次 但这个例子得出的结果已经足够说明问题了      结束语  希望广大读者能够通过本篇文章掌握如何迅速地对PHP代码进行分析的基本方法 在这里我还还要提醒广大读者的是 对代码进行分析不是一件简单的事儿 因为我们必须掌握大量的有关该种语言的特性 在代码中添加计时用的代码有助于找出运行速度缓慢的函数 利用多次重复的方法使我们能够发现对代码进行正确优化的方法 cha138/Article/program/MySQL/201311/29504

相关参考

知识大全 用MySQL和PHP创建XML

用MySQL和PHP创建XML  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  XML是作为数据交

知识大全 正规化的表格设计能提升应用性能(一)

在动态网站的设计中数据库设计的重要性不言而喻如果设计不当查询起来就非常吃力程序的性能也会受到影响无论你使用的是MySQL或者Oracle数据库通过进行正规化的表格设计可以令你的PHP代码更具可读性更容

知识大全 mysql和oracle常用内容比较

  注释  oracle使用的是–(两个)批量注释/**/  mysql使用的是#批量注释/**/  通配符的使用  mysql和oracle都支持通配符%用以模糊查询mysql还可以用instr(p

知识大全 用PHP操纵Oracle的LOB类型的数据

用PHP操纵Oracle的LOB类型的数据  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!《PHP+

知识大全 mysql性能的检查和调优方法

  我一直是使用mysql这个数据库软件它工作比较稳定效率也很高在遇到严重性能问题时一般都有这么几种可能  索引没有建好  sql写法过于复杂  配置错误  机器实在负荷不了  索引没有建好  如果看

知识大全 mysql性能的检查和调优方法[1]

   我一直是使用mysql这个数据库软件它工作比较稳定效率也很高在遇到严重性能问题时一般都有这么几种可能   索引没有建好 &n

知识大全 用Oracle中的Statspack诊断数据库性能实例

用Oracle中的Statspack诊断数据库性能实例  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧

知识大全 php 对 mysql数据库的增,删,该,查

  php对mysql数据库的增删该查  $dbhost=localhost;  $dbuser=admin;  $dbpass=;  $dbname=lch;  $conn=mysql_connec

知识大全 PHP+MySQL数据库论坛简易通

PHP+MySQL数据库论坛简易通  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  校园论坛是校园

知识大全 建立PHP与MySQL数据库的连接

建立PHP与MySQL数据库的连接  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! &nb