Ecshop 数据库操作方法getRow、getAll、getOne区别

ECShop没有使用一些开源的数据库操作类,比如adodb或者PEAR,而是封装了自己的实现。这样做的好处是实现非常轻量,大大减小了分发包的文件大小。另外,当网站需要做memcached缓存时,也可以很方便的实现。

当然,这样做的后果就是数据库的选择非常狭窄,无法实现其它的非MySQL数据库。

ECShop的数据操作类文件是includes/cls_mysql.php,类名是cls_mysql。

该类主要提供了下面 一些比较有用的方法:

getAll($sql)和getAllCached($sql, $cached = 'FILEFIRST'):获取所有记录

function getAll($sql)

    {

        $res = $this->query($sql);

        if ($res !== false)

        {

            $arr = array();

            while ($row = mysql_fetch_assoc($res))

            {

                $arr[] = $row;

            }



            return $arr;

        }

        else

        {

            return false;

        }

    }

getRow($sql, $limited = false)和getRowCached($sql, $cached = 'FILEFIRST'):获取单行记录。

 


getCol($sqlse)和getColCached($sql, $cached = 'FILEFIRST'):获取某栏位的所有值。
getOne($sql, $limited = false)和getOneCached($sql, $cached = 'FILEFIRST'):获取单个数值。

function getOne($sql, $limited = false)

    {

        if ($limited == true)

        {

            $sql = trim($sql . ' LIMIT 1');

        }



        $res = $this->query($sql);

        if ($res !== false)

        {

            $row = mysql_fetch_row($res);



            if ($row !== false)

            {

                return $row[0];

            }

            else

            {

                return '';

            }

        }

        else

        {

            return false;

        }

    }

  


query($sql):执行数据库查询。
autoExecute($table, $field_values, $mode = 'INSERT', $where = ''):数据库表操作。

你可能感兴趣的:(ecshop)