设为首页 收藏本站
查看: 1109|回复: 0

[经验分享] 如何在PHP5中通过PDO连接SQLite3数据库

[复制链接]

尚未签到

发表于 2015-11-17 14:26:09 | 显示全部楼层 |阅读模式
如何在PHP5中通过PDO连接SQLite3数据库

通过PHPPDO配置SQLite数据库是一件很繁琐的事情,经过一下午的研究,终于理清了里面的思路。现在拿出来跟大家共享。初学,错误请指出。
  

首先我们先选择要使用的web server 软件,由于从兼容性跟性能方面的需求,我选择了目前来说最新版的apache
  


第二步,我们要使用目前最新版本的PHP zip package .这里提示大家一下,经过我痛苦的反复的实验跟查看资料,如果大家想要使用PDO扩展连接到SQLite数据库的话,请你一定不要选择安装包,因为它不支持很多PHP的扩展库文件。   

第三步,我们要去http://pecl4win.php.net/ext.php/php_pdo_sqlite.dllhttp://pecl4win.php.net/ext.php/php_pdo.dll下载PDO的两个扩展库文件,文件名各自为:php_pdo.dll php_pdo_sqlite.dll 。下来以后保存在一边,我们稍候会使用到。顺便提一下哦,关于PHP_PDO的驱动资料请大家查阅 http://pecl4win.php.net/index.php里面有详细的不同平台的安装信息。   

  

最后一步,大家需要到SQLite官方网站去下载SQLite的文件包。地址为:   

http://www.sqlite.org/download.html  选择适合自己的版本即可。我用的是:sqlite_analyzer-3_2_1.zip   

  
       好了,预备工作做好了,我们开始工作吧!首先,请大家按照上面介绍的顺序安装Apache 安装过程很简单,不赘述.一路的next直到完成。但是有一些小细节需要说一些,正是这些小细节让我吃了不少苦。需要注意的是大家如果原来的系统上安装了微软的IIS的话,可能会安装出现冲突,具体的是在端口绑定方面的问题。如果可以的话,请尽量将IIS卸载掉,如果大家有避免冲突的方法,可以拿出来讨论一下。

  

       下面开始将下载下来的PHP 5.0.4 zip package 解压缩出来,放到C:/PHP 文件夹下面,也可以放在自己想要的地方,最后在各个配置文件里面修改一下即可。我们把C:/PHP文件夹下面的php5ts.dll 文件放到C:/Windows/System32下面,如果是NT或者2000系统的话,就放在C:/Winnt/System32下面。然后将C:/PHP文件夹下面的php.ini-recommended文件复制到C:/Windows/下面并改名为php.ini 。把我们下载下来的两个PDO桥驱动文件(   

php_pdo.dll php_pdo_sqlite.dll)放到C:/PHP/ext里面。这个文件夹是PHP专门存放扩展库的地方,大家仔细看就可以发现很多熟悉的面孔哦^_^   

  

打开我们刚才存放在C:/Windows/下面php.ini文件,开始配置信息了。找寻下面的行。   

;Windows Extensions   

;Note that ODBC support is built in, so no dll is needed for it.   

;   

我们在两行后面可以发现众多的扩展库文件,对,这里就是php启动时加载扩展库的地方,我们要把我们需要加载的PDO扩展库放到这里面,让PHP当作模块加载,我们才能使用阿~~   

加载方法很简单,在所有的库文件后面添加上如下两句:   

  

;手动添加的phppdo的驱动扩展支持   

extension=php_pdo.dll   

extension=php_pdo_sqlite.dll   

  

下面还有一个很重要的工作,就是我们要把扩展库的路径告诉php否则,PHP不知道去哪里找这些小宝贝了^_^ ,我们查找到如下的行:(查找关键字:extension_dir):   

  

; Directory in which the loadable extensions (modules) reside.   

extension_dir = "c:/php/ext"   

把它设置为动态库存方的路径,我们这里是:c:/php/ext   

好了PHP的配置文件我们修改好了,保存关闭。   

  

我们下面开始右击状态栏里面那个小羽毛的图标,选择“Open Apache Monitor”打开Apache监视窗口,我们选择右边一列按钮里面的“Stop”按钮,将服务暂时关掉。然后我们打开“开始-〉程序-Apache HTTP Server 2.0.54-Configure Apache Server-Edit the Apache httpd.conf Configuration File”菜单,打开Apache的配置文件httpd.conf。在这里面我们要把php当作Apache的一个模块加载进来。我们在配置文件的最后面加上如下两句。请注意路径问题哦:   

  

LoadModule php5_module "c:/php/php5apache2.dll"   

AddType application/x-httpd-php .php   

  

这样当Apache启动的时候就把PHP加载进来了。再寻找下面的行   

(查找关键字:DocumentRoot):   

#   

DocumentRoot "D:/website"   

设置我们站点的根目录。我选在D:/website下面。   

  

我们还要寻找如下的行:(查找关键字:DirectoryIndex   

#   

DirectoryIndex index.html index.html.var   

这里我们可以设置自己的首页名称,在后面加上我们使用的文件名即可.中间使用空格分隔。   

例如:   

#   

DirectoryIndex index.html index.html.var index.php default.php   

至此,我们所有的配置完成了,请大家保存关闭。然后再次启动Apache监视窗口,选择右边的“Start”按钮,启动Apache服务器,   

  

最后拉~~   

如果要测试SQLite数据库的话,我们使用一些SQLite建表工具,建一个数据库跟一些表,然后输入一些数据字段,最后使用自己喜欢的编辑器,在里面输入如下代码:   


}   

?>   

(注意:PHP5自身带的SQLite是2版本,不能执行3版本的连接跟操作,POD就是解决这个问题的桥梁,它使PHP5连接并且操作3版本的SQLite,因此,PHP5自身带的SQLite 函数库是无法操作SQLIte3的,必须使用PHP5手册里面PDO的函数来间接驱动SQLite3数据库)   

保存到我们站点的根目录下面,比如叫做:default.php 如果不出其他问题的话,我们启动IE,在地址栏里输入http://localhost/ 回车后,看看出现了什么。^_^   

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-140386-1-1.html 上篇帖子: 【引用】Linux应用程序开发(一)---移植thttpd+Sqlite3+PHP5到arm linux(3) 下篇帖子: APPWEB + PHP5 + SQLITE3 + MATRIXSSL移植到ARM LINUX
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表