亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? peardb.php

?? PhpWiki是sourceforge的一個(gè)開源項(xiàng)目
?? PHP
?? 第 1 頁 / 共 4 頁
字號(hào):
<?php // -*-php-*-rcs_id('$Id: PearDB.php,v 1.87 2005/02/10 19:04:24 rurban Exp $');require_once('lib/WikiDB/backend.php');//require_once('lib/FileFinder.php');//require_once('lib/ErrorManager.php');class WikiDB_backend_PearDBextends WikiDB_backend{    var $_dbh;    function WikiDB_backend_PearDB ($dbparams) {        // Find and include PEAR's DB.php. maybe we should force our private version again...        // if DB would have exported its version number, it would be easier.        @require_once('DB/common.php'); // Either our local pear copy or the system one        // check the version!        $name = check_php_version(5) ? "escapeSimple" : strtolower("escapeSimple");        if (!in_array($name, get_class_methods("DB_common"))) {            $finder = new FileFinder;            $dir = dirname(__FILE__)."/../../pear";            $finder->_prepend_to_include_path($dir);            include_once("$dir/DB/common.php"); // use our version instead.            if (!in_array($name, get_class_methods("DB_common"))) {                $pearFinder = new PearFileFinder("lib/pear");                $pearFinder->includeOnce('DB.php');            } else {                include_once("$dir/DB.php");            }        } else {          include_once("DB.php");        }        // Install filter to handle bogus error notices from buggy DB.php's.        // TODO: check the Pear_DB version, but how?        if (0) {            global $ErrorManager;            $ErrorManager->pushErrorHandler(new WikiMethodCb($this, '_pear_notice_filter'));            $this->_pearerrhandler = true;        }                // Open connection to database        $this->_dsn = $dbparams['dsn'];	$this->_dbparams = $dbparams;        $this->_lock_count = 0;        // persistent is usually a DSN option: we override it with a config value.        //   phptype://username:password@hostspec/database?persistent=false        $dboptions = array('persistent' => DATABASE_PERSISTENT,                           'debug' => 2);        //if (preg_match('/^pgsql/', $this->_dsn)) $dboptions['persistent'] = false;        $this->_dbh = DB::connect($this->_dsn, $dboptions);        $dbh = &$this->_dbh;        if (DB::isError($dbh)) {            trigger_error(sprintf("Can't connect to database: %s",                                  $this->_pear_error_message($dbh)),                          E_USER_ERROR);        }        $dbh->setErrorHandling(PEAR_ERROR_CALLBACK,                               array($this, '_pear_error_callback'));        $dbh->setFetchMode(DB_FETCHMODE_ASSOC);        $prefix = isset($dbparams['prefix']) ? $dbparams['prefix'] : '';        $this->_table_names            = array('page_tbl'     => $prefix . 'page',                    'version_tbl'  => $prefix . 'version',                    'link_tbl'     => $prefix . 'link',                    'recent_tbl'   => $prefix . 'recent',                    'nonempty_tbl' => $prefix . 'nonempty');        $page_tbl = $this->_table_names['page_tbl'];        $version_tbl = $this->_table_names['version_tbl'];        $this->page_tbl_fields = "$page_tbl.id AS id, $page_tbl.pagename AS pagename, $page_tbl.hits AS hits";        $this->version_tbl_fields = "$version_tbl.version AS version, $version_tbl.mtime AS mtime, ".            "$version_tbl.minor_edit AS minor_edit, $version_tbl.content AS content, $version_tbl.versiondata AS versiondata";        $this->_expressions            = array('maxmajor'     => "MAX(CASE WHEN minor_edit=0 THEN version END)",                    'maxminor'     => "MAX(CASE WHEN minor_edit<>0 THEN version END)",                    'maxversion'   => "MAX(version)",                    'notempty'     => "<>''",                    'iscontent'    => "content<>''");            }        /**     * Close database connection.     */    function close () {        if (!$this->_dbh)            return;        if ($this->_lock_count) {            trigger_error( "WARNING: database still locked " . '(lock_count = $this->_lock_count)' . "\n<br />",                          E_USER_WARNING);        }        $this->_dbh->setErrorHandling(PEAR_ERROR_PRINT);	// prevent recursive loops.        $this->unlock('force');        $this->_dbh->disconnect();        if (!empty($this->_pearerrhandler)) {            $GLOBALS['ErrorManager']->popErrorHandler();        }    }    /*     * Test fast wikipage.     */    function is_wiki_page($pagename) {        $dbh = &$this->_dbh;        extract($this->_table_names);        return $dbh->getOne(sprintf("SELECT $page_tbl.id as id"                                    . " FROM $nonempty_tbl, $page_tbl"                                    . " WHERE $nonempty_tbl.id=$page_tbl.id"                                    . "   AND pagename='%s'",                                    $dbh->escapeSimple($pagename)));    }            function get_all_pagenames() {        $dbh = &$this->_dbh;        extract($this->_table_names);        return $dbh->getCol("SELECT pagename"                            . " FROM $nonempty_tbl, $page_tbl"                            . " WHERE $nonempty_tbl.id=$page_tbl.id");    }    function numPages($filter=false, $exclude='') {        $dbh = &$this->_dbh;        extract($this->_table_names);        return $dbh->getOne("SELECT count(*)"                            . " FROM $nonempty_tbl, $page_tbl"                            . " WHERE $nonempty_tbl.id=$page_tbl.id");    }        function increaseHitCount($pagename) {        $dbh = &$this->_dbh;        // Hits is the only thing we can update in a fast manner.        // Note that this will fail silently if the page does not        // have a record in the page table.  Since it's just the        // hit count, who cares?        $dbh->query(sprintf("UPDATE %s SET hits=hits+1 WHERE pagename='%s'",                            $this->_table_names['page_tbl'],                            $dbh->escapeSimple($pagename)));        return;    }    /**     * Read page information from database.     */    function get_pagedata($pagename) {        $dbh = &$this->_dbh;        //trigger_error("GET_PAGEDATA $pagename", E_USER_NOTICE);        $result = $dbh->getRow(sprintf("SELECT hits,pagedata FROM %s WHERE pagename='%s'",                                       $this->_table_names['page_tbl'],                                       $dbh->escapeSimple($pagename)),                               DB_FETCHMODE_ASSOC);        return $result ? $this->_extract_page_data($result) : false;    }    function  _extract_page_data($data) {        if (empty($data)) return array();        elseif (empty($data['pagedata'])) return $data;        else {            $data = array_merge($data, $this->_unserialize($data['pagedata']));            unset($data['pagedata']);            return $data;        }    }    function update_pagedata($pagename, $newdata) {        $dbh = &$this->_dbh;        $page_tbl = $this->_table_names['page_tbl'];        // Hits is the only thing we can update in a fast manner.        if (count($newdata) == 1 && isset($newdata['hits'])) {            // Note that this will fail silently if the page does not            // have a record in the page table.  Since it's just the            // hit count, who cares?            $dbh->query(sprintf("UPDATE $page_tbl SET hits=%d WHERE pagename='%s'",                                $newdata['hits'], $dbh->escapeSimple($pagename)));            return;        }        $this->lock(array($page_tbl), true);        $data = $this->get_pagedata($pagename);        if (!$data) {            $data = array();            $this->_get_pageid($pagename, true); // Creates page record        }                @$hits = (int)$data['hits'];        unset($data['hits']);        foreach ($newdata as $key => $val) {            if ($key == 'hits')                $hits = (int)$val;            else if (empty($val))                unset($data[$key]);            else                $data[$key] = $val;        }        /* Portability issue -- not all DBMS supports huge strings          * so we need to 'bind' instead of building a simple SQL statment.         * Note that we do not need to escapeSimple when we bind        $dbh->query(sprintf("UPDATE $page_tbl"                            . " SET hits=%d, pagedata='%s'"                            . " WHERE pagename='%s'",                            $hits,                            $dbh->escapeSimple($this->_serialize($data)),                            $dbh->escapeSimple($pagename)));        */        $sth = $dbh->query("UPDATE $page_tbl"                           . " SET hits=?, pagedata=?"                           . " WHERE pagename=?",                           array($hits, $this->_serialize($data), $pagename));        $this->unlock(array($page_tbl));    }    function get_cached_html($pagename) {        $dbh = &$this->_dbh;        $page_tbl = $this->_table_names['page_tbl'];        return $dbh->GetOne(sprintf("SELECT cached_html FROM $page_tbl WHERE pagename='%s'",                                    $dbh->escapeSimple($pagename)));    }    function set_cached_html($pagename, $data) {        $dbh = &$this->_dbh;        $page_tbl = $this->_table_names['page_tbl'];        $sth = $dbh->query("UPDATE $page_tbl"                           . " SET cached_html=?"                           . " WHERE pagename=?",                           array($data, $pagename));    }    function _get_pageid($pagename, $create_if_missing = false) {                // check id_cache        global $request;        $cache =& $request->_dbi->_cache->_id_cache;        if (isset($cache[$pagename])) {            if ($cache[$pagename] or !$create_if_missing) {                return $cache[$pagename];            }        }        $dbh = &$this->_dbh;        $page_tbl = $this->_table_names['page_tbl'];                $query = sprintf("SELECT id FROM $page_tbl WHERE pagename='%s'",                         $dbh->escapeSimple($pagename));        if (!$create_if_missing)            return $dbh->getOne($query);        $id = $dbh->getOne($query);        if (empty($id)) {            $this->lock(array($page_tbl), true); // write lock            $max_id = $dbh->getOne("SELECT MAX(id) FROM $page_tbl");            $id = $max_id + 1;            $dbh->query(sprintf("INSERT INTO $page_tbl"                                . " (id,pagename,hits)"                                . " VALUES (%d,'%s',0)",                                $id, $dbh->escapeSimple($pagename)));            $this->unlock(array($page_tbl));        }        return $id;    }    function get_latest_version($pagename) {        $dbh = &$this->_dbh;        extract($this->_table_names);        return            (int)$dbh->getOne(sprintf("SELECT latestversion"                                      . " FROM $page_tbl, $recent_tbl"                                      . " WHERE $page_tbl.id=$recent_tbl.id"                                      . "  AND pagename='%s'",                                      $dbh->escapeSimple($pagename)));    }    function get_previous_version($pagename, $version) {        $dbh = &$this->_dbh;        extract($this->_table_names);                return            (int)$dbh->getOne(sprintf("SELECT version"                                      . " FROM $version_tbl, $page_tbl"                                      . " WHERE $version_tbl.id=$page_tbl.id"                                      . "  AND pagename='%s'"                                      . "  AND version < %d"                                      . " ORDER BY version DESC",                                      /* Non portable and useless anyway with getOne                                      . " LIMIT 1",                                      */                                      $dbh->escapeSimple($pagename),                                      $version));    }        /**     * Get version data.     *     * @param $version int Which version to get.     *     * @return hash The version data, or false if specified version does not     *              exist.     */    function get_versiondata($pagename, $version, $want_content = false) {        $dbh = &$this->_dbh;        extract($this->_table_names);        extract($this->_expressions);        assert(is_string($pagename) and $pagename != "");        assert($version > 0);                //trigger_error("GET_REVISION $pagename $version $want_content", E_USER_NOTICE);        // FIXME: optimization: sometimes don't get page data?        if ($want_content) {            $fields = $this->page_tbl_fields                 . ",$page_tbl.pagedata as pagedata,"                 . $this->version_tbl_fields;        }        else {            $fields = $this->page_tbl_fields . ","                . "mtime, minor_edit, versiondata,"                . "$iscontent AS have_content";        }        $result = $dbh->getRow(sprintf("SELECT $fields"                                       . " FROM $page_tbl, $version_tbl"                                       . " WHERE $page_tbl.id=$version_tbl.id"                                       . "  AND pagename='%s'"                                       . "  AND version=%d",                                       $dbh->escapeSimple($pagename), $version),                               DB_FETCHMODE_ASSOC);        return $this->_extract_version_data($result);    }    function _extract_version_data($query_result) {        if (!$query_result)            return false;        $data = $this->_unserialize($query_result['versiondata']);                $data['mtime'] = $query_result['mtime'];        $data['is_minor_edit'] = !empty($query_result['minor_edit']);                if (isset($query_result['content']))            $data['%content'] = $query_result['content'];        elseif ($query_result['have_content'])            $data['%content'] = true;        else            $data['%content'] = '';        // FIXME: this is ugly.        if (isset($query_result['pagedata'])) {            // Query also includes page data.            // We might as well send that back too...            unset($query_result['versiondata']);            $data['%pagedata'] = $this->_extract_page_data($query_result);        }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品午夜久久久| 亚洲欧美另类久久久精品2019| www.亚洲色图| 美女国产一区二区| 亚洲精品第1页| 国产日韩视频一区二区三区| 欧美日韩国产中文| 99在线精品免费| 国内成+人亚洲+欧美+综合在线| 一区二区三区四区高清精品免费观看 | 免费人成网站在线观看欧美高清| 国产精品欧美综合在线| 日韩欧美一区二区免费| 欧美四级电影网| 99视频精品在线| 国产精品主播直播| 日本aⅴ亚洲精品中文乱码| 亚洲欧美激情小说另类| 精品一区二区三区在线播放| 亚洲精品一卡二卡| 国产精品视频麻豆| 久久尤物电影视频在线观看| 欧美日韩国产一级片| 91行情网站电视在线观看高清版| 高清国产午夜精品久久久久久| 麻豆国产欧美日韩综合精品二区 | 国产成人av一区二区三区在线| 日本欧美一区二区| 一个色综合网站| 亚洲精品综合在线| 日韩久久一区二区| 成人免费在线播放视频| 亚洲国产高清在线| 国产精品少妇自拍| 国产精品欧美久久久久无广告| 久久久777精品电影网影网 | 欧美精品三级在线观看| 欧美视频自拍偷拍| 欧美三级蜜桃2在线观看| 色噜噜狠狠成人网p站| 一本久久a久久免费精品不卡| 99re66热这里只有精品3直播 | 日韩电影一区二区三区四区| 一区二区三区在线观看动漫| 一区二区三区中文在线| 亚洲一区二区视频在线观看| 亚洲夂夂婷婷色拍ww47| 亚洲一级不卡视频| 三级影片在线观看欧美日韩一区二区| 亚洲777理论| 日韩av中文在线观看| 另类人妖一区二区av| 国产一区二区三区不卡在线观看| 国内偷窥港台综合视频在线播放| 国产乱子伦视频一区二区三区| 国产盗摄一区二区三区| 91在线免费视频观看| 在线中文字幕一区二区| 91精品国产综合久久福利| 精品少妇一区二区三区在线播放| 久久久亚洲欧洲日产国码αv| 日本一区二区三区dvd视频在线| 国产精品乱人伦| 亚洲综合色在线| 免费人成精品欧美精品| 国产美女在线精品| 91美女视频网站| 91精品福利在线一区二区三区 | 欧美色图在线观看| 日韩精品一区二区三区在线播放| 久久狠狠亚洲综合| 成人免费毛片aaaaa**| 日本高清不卡视频| 欧美一区二区黄| 中文字幕精品—区二区四季| 亚洲免费观看高清完整版在线 | 亚洲九九爱视频| 蜜桃精品视频在线| gogogo免费视频观看亚洲一| 欧美亚州韩日在线看免费版国语版| 制服丝袜在线91| 国产精品丝袜一区| 日韩精品一级中文字幕精品视频免费观看 | 91视频观看免费| 69久久夜色精品国产69蝌蚪网| 久久久蜜桃精品| 亚洲成人第一页| 成人午夜精品在线| 3atv在线一区二区三区| 国产精品无圣光一区二区| 五月婷婷色综合| 不卡一卡二卡三乱码免费网站| 欧美高清视频一二三区| 国产精品国产三级国产专播品爱网 | 国产精品久久久久影院老司| 天天操天天色综合| av在线不卡电影| 日韩一区二区视频| 亚洲精品日产精品乱码不卡| 久久99国产精品久久| 日本韩国一区二区三区视频| 精品日韩99亚洲| 亚洲第一搞黄网站| 99国产精品视频免费观看| 精品三级在线看| 亚洲国产精品久久久久秋霞影院| 国产精品亚洲人在线观看| 欧美精品自拍偷拍动漫精品| 日本一二三四高清不卡| 日本中文一区二区三区| 国产精品一卡二卡| 91精品午夜视频| 爽好多水快深点欧美视频| 91色.com| 亚洲成人你懂的| 91一区二区在线| 17c精品麻豆一区二区免费| 欧美日韩精品二区第二页| 精品国产成人在线影院 | 精品国产精品一区二区夜夜嗨| 亚洲视频在线观看一区| 高清在线成人网| 国产午夜精品一区二区三区视频 | 亚洲精品综合在线| 99久久夜色精品国产网站| 久久久久久久综合狠狠综合| 免费观看一级欧美片| 亚洲欧美韩国综合色| 暴力调教一区二区三区| 国产日产精品一区| 国产一区 二区 三区一级| 欧美不卡在线视频| 美日韩黄色大片| 日韩欧美123| 久久精品国产久精国产| 日韩一区二区三区高清免费看看| 亚洲成人动漫一区| 欧美高清视频在线高清观看mv色露露十八 | 欧美日韩国产精选| 亚洲h在线观看| 欧美高清一级片在线| 日韩有码一区二区三区| 91精品蜜臀在线一区尤物| 日韩激情中文字幕| 日韩欧美在线1卡| 极品少妇xxxx精品少妇| 久久综合久久久久88| 国产一区不卡精品| 中文字幕不卡一区| 91免费看`日韩一区二区| 亚洲免费观看高清完整版在线观看 | 亚洲无线码一区二区三区| 欧美系列在线观看| 午夜精品福利一区二区蜜股av | 国产精品一区专区| 国产精品久久久久久久久免费樱桃| 成人的网站免费观看| 中文字幕亚洲综合久久菠萝蜜| 99国产精品久久久久久久久久久 | 91国偷自产一区二区三区观看| 亚洲精选视频免费看| 欧美久久久久久久久| 久久精工是国产品牌吗| 国产欧美日韩视频一区二区| 99久久精品免费精品国产| 亚洲一区免费观看| 日韩免费在线观看| 成人国产精品免费观看视频| 亚洲裸体在线观看| 91精品国产麻豆| 国产凹凸在线观看一区二区| 亚洲欧美日韩精品久久久久| 欧美日韩国产精选| 国产精品系列在线观看| 成人av电影在线| 天堂午夜影视日韩欧美一区二区| 精品国产电影一区二区| 色综合中文综合网| 亚洲一区二区三区不卡国产欧美| 777久久久精品| 国产成人在线看| 五月婷婷久久丁香| 欧美韩日一区二区三区| 91久久精品一区二区二区| 久久福利视频一区二区| 亚洲另类在线一区| 久久蜜桃香蕉精品一区二区三区| 91免费版在线| 国产综合久久久久影院| 亚洲午夜在线视频| 久久精品网站免费观看| 欧美三区在线观看| 国产v综合v亚洲欧| 秋霞av亚洲一区二区三| 亚洲视频香蕉人妖| 久久免费的精品国产v∧| 欧美人妖巨大在线| 91免费视频观看| 国产91清纯白嫩初高中在线观看 | 蜜桃久久av一区|