您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/2/26 20:48:22发布9次查看
这篇文章主要介绍了php中使用匿名函数操作数据库的例子,本文直接给出类的代码、使用例子、继承例子,需要的朋友可以参考下
复制代码 代码如下:
base dao class illustrating the usefulness of closures.
* handles opening and closing of connections.
* adds slashes sql
* type checking of sql parameters and casts as appropriate
* provides hook for processing of result set and emitting one or more objects.
* provides hook for accessing underlying link and result objects.
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, $params, $callback)    {
        return $this->executequery($sql, $params, 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, $params, $callback)    {
        return $this->executequery($sql, $params, function($result, $link) use ($callback) {
            if ($row = mysql_fetch_assoc($result))
                $obj = $callback($row);
            return $obj;
        });
    }
}
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product