- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一:PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extension 而言,本身也增加了安全性。而 PDO (PHP Data Object) 则是提供了一个 Abstraction Layer 来操作资料库,用讲的其实看不出来有有什麽差别,所以就直接看程式吧…首先,先来看一段用 PHP-MySQL 写成的程式码,这类的范例常用在世界各地:代码如下:?phpmysql_connect($db_host, $db_user, $db_password);mysql_select_db($dn_name);$result = mysql_query(SELECT `name` FROM `users` WHERE `location` = $location);while ($row = mysql_fetch_array($result, MYSQL_ASSOC)){echo $row[name];}mysql_free_result($result);?乍看之下没什麽问题,但其实背后有些学问…这种方式不能 Bind Column ,以前例的 SQL 叙述来说,$location 的地方容易被 SQL Injection。后来于是发展出了 mysql_escape_string() (备注:5.3.0之后弃用) 以及 mysql_real_escape_string() 来解决这个问题,不过这麽一搞,整个叙述会变得}杂且丑陋,而且如果栏位多了,可以想见会是怎样的情形…代码如下:?php$query = sprintf(SELECT * FROM users WHERE user=%s AND password=%s,mysql_real_escape_string($user),mysql_real_escape_string($password));mysql_query($query);?在 PHP-MySQLi 中有了不少进步,除了透过 Bind Column 来解决上述问题,而且也多援 Transaction, Multi Query ,并且同时提供了 Object oriented style (下面这段 PHP-MySQLi 范例的写法) 和 Procedural style (上面 PHP-MySQL 范例的写法)两种写法…等等。代码如下:?php$mysqli = new mysqli($db_host, $db_user, $db_password, $db_name);$sql = INSERT INTO `users` (id, name, gender, location) VALUES (?, ?, ?, ?);$stmt = $mysqli-prepare($sql);$stmt-bind_param(dsss, $source_id, $source_name, $source_gender, $source_location);$stmt-execute();$stmt-bind_result($id, $name, $gender, $location);while ($stmt-fetch()){echo $id . $name . $gender . $location;}$stmt-close();$mysqli-close();?但看到这边又发现了一些缺点,例如得 Bind Result,这个就有点多馀,不过这其实无关紧要,因为最大的问题还是在于这不是一个抽象(Abstraction)的方法,所以当后端更换资料库的时候,就是痛苦的开始…于是 PDO 就出现了(备注:目前 Ubuntu 和 Debian 来说,PDO 并没有直接的套件可以安装,而是必须透过 PECL 安装)。代码如下:roga@carlisten-lx:~$ pecl search pdo=======================================Package Stable/(Latest) LocalPDO 1.0.3 (stable) PHP Data Objects Interface.PDO_4D 0.3 (beta) PDO driver for 4D-SQL databasePDO_DBLIB 1.0 (stable) FreeTDS/Sybase/MSSQL driver for PDOPDO_FIREBIRD 0.2 (beta) Firebird/
您可能关注的文档
- PHP+mysql分页原理和实例应用.doc
- php+mysql建立虚拟目录wamp篇.doc
- PHP+MYSQL留言板代码.doc
- Php+Mysql注入专题.doc
- PHPCMS2008 SP3 采集教材.doc
- PHPCMS2008二次开发,有实例.doc
- Phpcms v9模板 如何修改调用id。详细图文版.doc
- phplib基本手册.doc
- phpnow绑定域名教程.doc
- PHPnow搭建php环境.doc
- 贵州贵州省建设投资集团有限公司招聘考试真题附答案详解(研优卷).docx
- 河南南阳师范学院2021年招聘25名硕士研究生冲刺卷一(附答案与详解)及答案详解(名校卷).docx
- 陕西延长石油 (集团) 有限责任公司 所属单位招聘笔试题库及答案详解(必刷).docx
- 贵州民航产业集团有限公司招聘笔试题库含答案详解(基础题).docx
- 广汉市2025年公开招聘社区专职工作者(125人)考试备考题库含答案详解(考试直接用).docx
- 邢台市水务发展集团有限公司招聘真题附答案详解(实用).docx
- 新华保险总部人力资源部(党委组织部)招聘笔试题库含答案详解(预热题).docx
- 贵州苔茶产业发展集团有限公司招聘笔试题库含答案详解(b卷).docx
- 广汉市2025年公开招聘社区专职工作者(125人)考试备考题库附答案详解(综合题).docx
- 贵州城乡产业发展集团有限公司招聘笔试题库附答案详解(实用).docx
文档评论(0)