加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP中使用匿名函数操作数据库的例子

发布时间:2020-12-12 20:29:46 所属栏目:PHP教程 来源:网络整理
导读:代码如下: define("userName","root");define("password","root");define("dbName","ahcdb");define("hostName","localhost"); class BaseDao { function getConnection() { $link = mysql_connect(hostName,userName,password); if (!$link) die("Could not

代码如下:

define("userName","root"); define("password","root"); define("dbName","ahcdb"); define("hostName","localhost");

class BaseDao {

function getConnection() { $link = mysql_connect(hostName,userName,password); if (!$link) die("Could not connect: " . mysql_error()); if (!mysql_select_db(dbName)) die("Could not select database: " . mysql_error()); return $link; }

function setParams(& $sql,$params) {
if($params != null)
$sql = vsprintf($sql,array_map(function($n) {
if(is_int($n))
return (int)$n;
if(is_float($n))
return (float)$n;
if(is_string($n))
return "'".mysql_real_escape_string($n)."'";
return mysql_real_escape_string($n);
},$params));
}

function executeQuery($sql,$params,$callback = null) { $link = $this->getConnection(); $this->setParams($sql,$params); $return = null; if(($result = mysql_query($sql,$link)) != null) if($callback != null) $return = $callback($result,$link); if($link != null) mysql_close($link); if(!$result) die("Fatal Error: Invalid query '$sql' : " . mysql_error()); return $return; }

function getList($sql,$callback) {
return $this->executeQuery($sql,function($result,$link) use ($callback) {
$idx = 0;
$list = array();
while ($row = mysql_fetch_assoc($result))
if($callback != null)
$list[$idx] = $callback($idx++,$row);
return $list;
});
}

function getSingle($sql,$link) use ($callback) {
if ($row = mysql_fetch_assoc($result))
$obj = $callback($row);
return $obj;
});
}
}

class Example { var $id; var $name;

function Example($id,$name){
$this->id = $id;
$this->name = $name;
}

function setId($id){
$this->id = $id;
}
}

class ExampleDao extends BaseDao {

function getAll(){
return parent::getList("select * from nodes",null,function($idx,$row) {
return new Example($row["id"],$row["name"]);
});
}

function load($id){
return parent::getSingle("select * from nodes where id = %1$s",array($id),function($row) {
return new Example($row["id"],$row["name"]);
});
}

function update($example){
return parent::executeQuery("update nodes set name = '' where id = -1",$link){
return $result;
});
}

function insert(& $example){
return parent::executeQuery("insert into nodes",$link) use ($example){
$id = mysql_insert_id($link);
$example->setId($id);
return $result;
});
}
}

$exampleDao = new ExampleDao();

$list = $exampleDao->getAll());

$exampleObject = $exampleDao->load(1));

$exampleDao->update($exampleObject);

?>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读