有朋友下载了PHP5.3,PHP5.4版本想加载mysql支持的时候发现没有libmysql.dll文件,无法完成mysql配置,其实PHP5.3版本开始,使用mysqlnd库,不再使用libmysql.dll用来访问MySQL数据库,大大提升了PHP的数据库访问性能。且默认支持mysql,无需像libmysql.dll要手动复制到windows/system32目录下。

以前版本的PHP访问MySQL数据库,是通过MySQL数据库的libmysql client库,这个libmysql client是用C/C++编写的,虽然一直以来PHP通过libmysql访问数据库性能也一直很好,但却无法利用PHP本身的很多特性。

新的mysqlnd提供了和Zend引擎高度的集成性,更加快速的执行速度,更少的内存消耗,利用了PHP的Stream API,以及客户段缓存机制。由于mysqlnd是透过Zend引擎,因此提供提供更多高级特性,以及有效利用Zend进行加速

libmysql是直接访问数据库的,而mysqlnd是通过Zend访问数据库。

以上内容,摘自http://www.51itz.com/?p=467,是对PHP5.3没有libmysql.dll的很好说明,这在PHP手册中也有详细说明。

以下是由此带来的困扰,尤其是对新手而言。

1.在阅读一些过时的PHP教程时,会提到libmysql.dll文件,甚或提到要将该文件和php5ts.dll复制到Windows的system32目录下,于是,新手在此时却发现下载的PHP5.3包里没有libmysql.dll文件,于是很困惑。实际上,PHP是有意去除libmysql.dll文件的,因为它提供了更好的替代方式,就是内嵌的php模块“mysqlnd”,也正是由于“mysqlnd”是内嵌的,所以不需要多余的类似libmysql.dll的文件。同时,这对于mysql、mysqli、PDO的使用也是没有影响的,因为这只是对mysql底层交互的方式的更新,php程序员不用管它,原来的还是一样用。

2.在Windows中配置php.ini的extension_dir选项时,一定要确保它可用,然后再去测试某个扩展是否有用。这是做事的顺序问题,不是技术问题。本人多次因使用相对路径而非绝对路径而浪费了很多调试时间!PHP手册中提到该选项可用相对路径或者绝对路径,而本人发现在Windows下只能使用绝对路径,这个请一定注意!

3.从mysql官网http://www.mysql.com/downloads/的“MySQL Connectors”一节可以看出,mysql提供了针对C++、Java、.Net、C、ODBC等通信接口,而对C的接口就是libmysql.dll,它可以用于PHP,因为PHP是用C写的。由此也可以知道,libmysql.dll是一个通用的C接口模块,而不是只对PHP适用。相比,PHP自己研发的mysqlnd模块则是PHP专有的,是遵从它自己的发布协议的。

php 没有libmysql.dll,PHP5.3以上版本没有libmysql.dll,以及由此带来的困扰相关推荐

  1. PHP5.3以上版本没有libmysql.dll,以及由此带来的困扰

    有朋友下载了PHP5.3,PHP5.4版本想加载mysql支持的时候发现没有libmysql.dll文件,无法完成mysql配置,其实PHP5.3版本开始,使用mysqlnd库,不再使用libmysq ...

  2. c mysql dll_PHP5.3以上版本没有libmysql.dll,以及由此带来的困扰

    有朋友下载了PHP5.3,PHP5.4版本想加载mysql支持的时候发现没有libmysql.dll文件,无法完成mysql配置,其实PHP5.3版本开始,使用mysqlnd库,不再使用libmysq ...

  3. php5.6 win2008 mssql,Php5.6.31连接sqlserver 2008R2数据库问题sqlsrv(php5.3及以上版本)与mssql(php5.3以前版本)②...

    Php5.6.31连接sqlserver2008R2数据库 1.环境配置 Win7(win8.1)  64 +Apache2.4 + PHP5.6.31 + SQL Server 2008 R2数据库 ...

  4. php5.5 wamp,wamp环境单独安装(windows下apache2.4、mysql5.5、php5.5的版本)

    Apache2.4.10 x86版本 2.VC11的依赖(vc2012 x86) 安装顺序: 1.vc2012(x86版本)  选择vc2012中的"vcredist_x86.exe&quo ...

  5. php 5.3 iis 配置,PHP5.3x+IIS6完全配置方法,PHP5.3以上版本全新配置IIS方法 | 博客水木...

    由于PHP5.3 的改进,原有的IIS 通过isapi 方式解析PHP脚本已经不被支持,PHP从5.3.0 以后的版本开始使用微软的 fastcgi 模式,这是一个更先进的方式,运行速度更快,更稳定. ...

  6. php5.5 zend optimizer,PHP5.3以上版本安装ZendOptimizer扩展

    搜索热词 <PHP5.3以上版本安装ZendOptimizer扩展>要点: 本文介绍了PHP5.3以上版本安装ZendOptimizer扩展,希望对您有用.如果有疑问,可以联系我们. PH ...

  7. 制作TortoiseSVN最新版本的中文DLL(转)

    转自:http://blog.donews.com/feihu/archive/2005/05/13/377920.aspx 自从发现了SVN后,我在自己的项目中总是使用SVN来做源代码管理,在win ...

  8. dedecms php5.4 无法退出后台,解决更换PHP5.4以上版本后Dedecms后台登录空白问题的方法...

    为什么会出现更换PHP5.4以上版本后Dedecms后台登录空白的情况,本文将给大家详细分析,找出真正原因以及解决办法. 把PHP的版本从5.2.14升到了5.4.15,升级完后dedecms后台却打 ...

  9. php5.2 json,php5.2以上版本json_encode兼容性

    php5.2以下版本json_encode兼容性 php5.1版本通过编译加载的json.so,在使用json_encode时会把键名为空的数组 $arr =array(''=>array('i ...

最新文章

  1. Eval和Bind的区别
  2. 说说JSON和JSONP
  3. nginx连接uwsgi使用web.py框架构造pythonweb项目
  4. C++ STL之Set
  5. Java LinkedList公共布尔boolean offerLast(Object o)方法(带示例)
  6. 4个优化方法,让你能了解join计算过程更透彻
  7. PlaceholderImageView
  8. 更改ubuntu的mysql版本为指定版本
  9. 关于C#关闭窗体后,依旧有后台进程在运行的解决方法
  10. JDRefresh 轻简下拉刷新框架
  11. 使用梯度下降与牛顿法求解最小平方和问题
  12. 利用Python高效自动化运维巡检网络设备
  13. 海信65E7G Pro评测
  14. cd linux menu.lst,Windows 7 中使用 grldr + menu.lst 引導 linux系統和win7.
  15. oracle怎么截取long类型,如何把long类型的值取出来
  16. 植物大战僵尸存档关卡和金币修改
  17. 小马哥--高仿三星G9200 主板型号A208刷机拆机主板图
  18. 中兴微型计算机,售价2698元起!中兴首款5G视频手机AR线上发布
  19. 三大web服务器比较
  20. java.double和 floa 的区别

热门文章

  1. SGU 187 - Twist and whirl -- want to cheat
  2. linux——线程(2)
  3. Tableau数据分析:NC Retail Order Data(英)Data Science Program Lab#1(GTI)
  4. 【剑指offer】面试题11:旋转数组的最小数字(java)
  5. 2017年网易校招题 末尾0的个数
  6. python自己创建模块路径_python之本地模块/包使用和创建
  7. python3.7和2.7_为两个python版本(2.7和3.7)Windows 10安装pip
  8. 图像拼接2 特征匹配
  9. HTML CSS JS(一)
  10. CSAPP--整数的表示