> 백엔드 개발 > PHP 튜토리얼 > php的mysql函数仿pdo操作数据库类_PHP教程

php的mysql函数仿pdo操作数据库类_PHP教程

WBOY
풀어 주다: 2016-07-13 17:47:44
원래의
738명이 탐색했습니다.

 

PDO显然将成为php的标准数据库操作方式。虽然国内的很多php空间或主机都已支持php5.2以上的版本了,但由于普及和技术上的原因还是有部分不支持pdo的。

 

由于从今年开始 哈尔滨智华软件的php课程在数据库操作的学习改为以pdo为主(当然课程在学习和最后实训时还是有mySQL函数操作数据库训练的),在实际开发中,我的学生不可避免的遇到了 采用pdo开发的程序,在程序实施时却发现服务器不支持pdo,好在都是客户的服务器,重新升级安装了一下php的新版本就解决了。

 

但这样却提出了一个问题?

要么开发用mySQL函数方式,

要么开发用pdo而后升级php版本,

要么发现用pdo开发无法升级php版本,用mySQL函数方式重写原有pdo方式代码

 

看来开发用开发用mySQL函数方式 似乎又成了最好的解决办法,这不又回到起始点,难道非要等到pdo都普及了再用pdo开发么,如果这样 就意味着我的php课程将教授学生一个已经开始淘汰的开发方式,学生学习完以后,几年内又要不得不放弃已经习惯的mySQL函数开发方式,再适应新的pdo开发方式。

 

有没有一个折中方案,既可以让学生学到新的pdo开发方式,在工作中又可以应对老得mySQL函数开发方式呢?那天学生问起 忽发奇想写个类,类的方法都是pdo的方式,然后将mySQL函数的操作 都封装到 这个类的方法里不就可以了么。

 

解决初衷 是开发是都采用pdo方式操作,如果需要mySQL函数方式 只要将连库的文件替换成mySQL函数连库代码,然后在后边加上这个类 并实例化对象为pdo的那个操作对象不就可以实现pdo方式改为mySQL函数方式了

 

pdo的增删改都一样的,代码如下:

 

 

require "./connDB.php" ; 

 

require ’./Deep.Class.MySQLfunction4PDO.php’; 

$db = new Deep_MySQLfunction4PDO(); 

 

$sql="insert into guestbook(guestName,guestDatetime)values(’lvhaipeng zhihuasoft".mt_rand(1,100)." ’,’".date(’Y-m-d H:i:s’)."’)"; 

 

//2 exec方法 

$count = $db->exec($sql); 

 

echo $count; 

?> 

查询代码如下:

 

 

require ’./connDB.php’; 

 

require ’./Deep.Class.MySQLfunction4PDO.php’; 

$db = new Deep_MySQLfunction4PDO(); 

 

//2 query查询 

$stmt = $db->query("SELECT * FROM guestbook" );  

 

// 1条记录 

// $row =$stmt->fetch(); 

//echo $row[’guestName’],"
"; 

 

while($row = $stmt->fetch()) 

echo $row[’guestName’],"
"; 

?> 

 

 

 

大家会发现我在连库文件后 ,添加了2行代码(当然工作时将这两行写在连库文件里刚好了)

 

 

require ’./Deep.Class.MySQLfunction4PDO.php’; 

$db = new Deep_MySQLfunction4PDO(); 

 

这样通过Deep_MySQLfunction4PDO类我就实现了不用更改现有的pdo代码,实现MySQL函数方式的操作了

 

Deep_MySQLfunction4PDO类文件代码如下:

 

 

/*

模仿pdo方式的一个mysql函数的操作类。

哈尔滨智华软件培训学校 吕海鹏2011-11-25 

 

调用:在mysql连库函数后调用

require ’./Deep.Class.MySQLfunction4PDO.php’;

$db = new Deep_MySQLfunction4PDO();

 

*/ 

 

// 仿PDO class 

class Deep_MySQLfunction4PDO{ 

 

//插入 删除 修改  

public function exec($sql){ 

@mysql_query( $sql ) or die("SQL语句执行错误!"); 

return mysql_affected_rows(); 

 

//查询 

public function query($sql){ 

$stmt=new Deep_MySQLfunction4PDO_stmt(); 

$stmt->query=@mysql_query( $sql ) or die("SQL语句执行错误!"); 

return $stmt; 

 

 

 

// 仿PDOStatement class 

class Deep_MySQLfunction4PDO_stmt{ 

var $query; 

public function fetch(){ 

return mysql_fetch_array($this->query); 

 

?> 

 

 

 

前一段时间课程比较多 今日周末有空 整理记录如上, 又有学生提出 仿pdo的类遇到查询 不用这个while($row =$stmt->fetch())用foreach( $stmt as $row)不行 我这改了改这个类实现了,这是那个代码写法有些古怪 待我有空再 整理 做这篇文章的后续说明吧

 

作者 吕海鹏

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478490.htmlTechArticlePDO显然将成为php的标准数据库操作方式。虽然国内的很多php空间或主机都已支持php5.2以上的版本了,但由于普及和技术上的原因还是有部分...
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿