當前位置: 首頁>>代碼示例>>PHP>>正文


PHP resource::execute方法代碼示例

本文整理匯總了PHP中resource::execute方法的典型用法代碼示例。如果您正苦於以下問題:PHP resource::execute方法的具體用法?PHP resource::execute怎麽用?PHP resource::execute使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在resource的用法示例。


在下文中一共展示了resource::execute方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: execute

    /**
     * execute method
     *
     * If there is no query or the query is true, execute has probably been called as part of a
     * db-agnostic process which does not have a mongo equivalent, don't do anything.
     *
     * @param mixed $query
     * @param array $params array()
     * @return void
     * @access public
     */
    public function execute($query, $params = array()) {
        if (!$this->isConnected()) {
            return false;
        }

        if (!$query || $query === true) {
            return;
        }
        $this->_prepareLogQuery($Model); // just sets a timer
        $return = $this->_db
                        ->execute($query, $params);
        if ($this->fullDebug) {
            if ($params) {
                $this->logQuery(":query, :params",
                        compact('query', 'params')
                );
            } else {
                $this->logQuery($query);
            }
        }
        if ($return['ok']) {
            return $return['retval'];
        }
        return $return;
    }
開發者ID:nishant-shrivastava,項目名稱:test-mongo-db,代碼行數:36,代碼來源:mongodb_source.php

示例2: _tables

 /**
  * Gets the tables list
  * @return array
  * @uses $connection
  */
 protected function _tables()
 {
     $tables = $this->connection->execute(sprintf('SHOW TABLES;'))->fetchAll();
     return array_map(function ($table) {
         return firstValue($table);
     }, $tables);
 }
開發者ID:mirko-pagliai,項目名稱:me-cms,代碼行數:12,代碼來源:BaseUpdateShell.php

示例3: query

 /**
  * Make a query.
  *
  * Should be used for insert and update queries, but also can be used as iterator for select queries.
  *
  * @example models\Db::query('INSERT INTO posts (title) VALUES (?)', ['New post title'], 'pgsql1');
  * @example $query = models\Db::query('SELECT * FROM posts', null, 'pgsql1');<br />
  *          foreach ($query as $item)<br />
  *          {<br />
  *              // Do something with the $item<br />
  *          }
  * @access public
  * @static
  * @param  string       $query
  * @param  mixed[]      $data  (default: null)
  * @param  string       $name  (default: 'default')
  * @return PDOStatement Returns statement created by query.
  */
 public static function query($query, $data = null, $name = 'default')
 {
     $db_link =& self::$db_links[$name]['link'];
     if (empty($query)) {
         return null;
     }
     if (empty($db_link)) {
         throw new \Exception('No connection to database');
     }
     // Do request
     if (!empty(self::$db_links[$name]['config']['debug'])) {
         Load::startTimer();
     }
     self::$last_statement = $db_link->prepare($query);
     self::$last_statement->execute((array) $data);
     if (!empty(self::$db_links[$name]['config']['debug'])) {
         $log = $query;
         if (!empty($data)) {
             $log_data = array_map(function ($item) {
                 return is_integer($item) == true ? $item : "'" . $item . "'";
             }, (array) $data);
             $log = str_replace(array_pad([], substr_count($query, '?'), '?'), $log_data, $query);
         }
         Load::stopTimer($log);
     }
     // Return last statement
     return self::$last_statement;
 }
開發者ID:gintsmurans,項目名稱:staticphp,代碼行數:46,代碼來源:Db.php

示例4: log

 /**
  * Inserts $message to the currently open database.  Calls open(),
  * if necessary.  Also passes the message along to any Log_observer
  * instances that are observing this Log.
  *
  * @param mixed  $message  String or object containing the message to log.
  * @param string $priority The priority of the message.  Valid
  *                  values are: PEAR_LOG_EMERG, PEAR_LOG_ALERT,
  *                  PEAR_LOG_CRIT, PEAR_LOG_ERR, PEAR_LOG_WARNING,
  *                  PEAR_LOG_NOTICE, PEAR_LOG_INFO, and PEAR_LOG_DEBUG.
  * @return boolean  True on success or false on failure.
  * @access public
  */
 function log($message, $priority = null)
 {
     /* If a priority hasn't been specified, use the default value. */
     if ($priority === null) {
         $priority = $this->_priority;
     }
     /* Abort early if the priority is above the maximum logging level. */
     if (!$this->_isMasked($priority)) {
         return false;
     }
     /* If the connection isn't open and can't be opened, return failure. */
     if (!$this->_opened && !$this->open()) {
         return false;
     }
     /* If we don't already have a statement object, create one. */
     if (!is_object($this->_statement) && !$this->_prepareStatement()) {
         return false;
     }
     /* Extract the string representation of the message. */
     $message = $this->_extractMessage($message);
     /* Build our set of values for this log entry. */
     $values = array('id' => $this->_db->nextId($this->_sequence), 'logtime' => MDB2_Date::mdbNow(), 'ident' => $this->_ident, 'priority' => $priority, 'message' => $message);
     /* Execute the SQL query for this log entry insertion. */
     $this->_db->expectError(MDB2_ERROR_NOSUCHTABLE);
     $result =& $this->_statement->execute($values);
     $this->_db->popExpect();
     /* Attempt to handle any errors. */
     if (PEAR::isError($result)) {
         /* We can only handle MDB2_ERROR_NOSUCHTABLE errors. */
         if ($result->getCode() != MDB2_ERROR_NOSUCHTABLE) {
             return false;
         }
         /* Attempt to create the target table. */
         if (!$this->_createTable()) {
             return false;
         }
         /* Recreate our prepared statement resource. */
         $this->_statement->free();
         if (!$this->_prepareStatement()) {
             return false;
         }
         /* Attempt to re-execute the insertion query. */
         $result = $this->_statement->execute($values);
         if (PEAR::isError($result)) {
             return false;
         }
     }
     $this->_announce(array('priority' => $priority, 'message' => $message));
     return true;
 }
開發者ID:sergiobelli,項目名稱:jecon,代碼行數:63,代碼來源:mdb2.php

示例5: execute

 /**
  * execute method
  *
  * @param mixed $query
  * @param array $params array()
  * @return void
  * @access public
  */
 public function execute($query, $params = array())
 {
     $this->_prepareLogQuery($Model);
     // just sets a timer
     $result = $this->_db->execute($query, $params);
     if ($this->fullDebug) {
         if ($params) {
             $this->logQuery(":query, :params", compact('query', 'params'));
         } else {
             $this->logQuery($query);
         }
     }
     if ($result['ok']) {
         return $result['retval'];
     }
     return $result;
 }
開發者ID:r0mk1n,項目名稱:cakephp-mongodb,代碼行數:25,代碼來源:mongodb_source.php

示例6: connect

 /**
  * DBに接続する
  *
  * @return	boolean	DB接続の処理結果(true/false)
  * @access	public
  */
 function connect()
 {
     if ($this->_conn != null) {
         return true;
     }
     if (!$this->_dsn) {
         return false;
     }
     $option = "";
     $prefix = "?";
     foreach ($this->_options as $key => $value) {
         if (is_bool($value)) {
             $option .= "{$prefix}{$key}";
         } else {
             $option .= "{$prefix}{$key}={$value}";
         }
         if ($prefix == "?") {
             $prefix = "&";
         }
     }
     $this->_conn =& NewADOConnection($this->_dsn . $option);
     if (!is_object($this->_conn)) {
         return false;
     }
     $this->_conn->SetFetchMode(ADODB_FETCH_ASSOC);
     if (strstr($this->_dsn, "mysql")) {
         $server_info = $this->_conn->ServerInfo();
         //if($server_info["version"] > )
         if (floatval($server_info["version"]) >= 4.01) {
             $result = $this->_conn->execute("SET NAMES " . DATABASE_CHARSET . ";");
             if (!$result) {
                 $log =& LogFactory::getLog();
                 $log->error("文字コード変換に失敗しました", "DbObjectAdodb#connect");
             }
         }
         // クライアントの文字セットを設定する。
         // mysql_set_charset は PHP 5.2.3、MySQL 5.0.7 以降
         // http://php.net/manual/ja/function.mysql-set-charset.php
         if (version_compare(phpversion(), '5.2.3', '>=') && $server_info['version'] >= '5.0.7') {
             mysql_set_charset(DATABASE_CHARSET);
         }
     }
     //$this->_conn->SetCharSet(DATABASE_CHARSET);
     return true;
 }
開發者ID:RikaFujiwara,項目名稱:NetCommons2,代碼行數:51,代碼來源:DbObjectAdodb.class.php

示例7: testOr

 /**
  * testOr method
  *
  * @return void
  * @access public
  */
 public function testOr()
 {
     $mongoVersion = $this->mongodb->execute('db.version()');
     $shouldSkip = version_compare($mongoVersion, '1.5.3', '<');
     if ($this->skipIf($shouldSkip, '$or tests require at least version mongo version 1.5.3, currently using ' . $mongoVersion . ' %s')) {
         return;
     }
     $MongoArticle = ClassRegistry::init('MongoArticle');
     $MongoArticle->create();
     for ($i = 1; $i <= 20; $i++) {
         $data = array('title' => "Article {$i}", 'subtitle' => "Sub Article {$i}");
         $saveData['MongoArticle'] = $data;
         $MongoArticle->create();
         $MongoArticle->save($saveData);
     }
     $expected = $MongoArticle->find('all', array('conditions' => array('title' => array('$in' => array('Article 1', 'Article 10'))), 'order' => array('number' => 'ASC')));
     $this->assertTrue(count($expected), 2);
     $result = $MongoArticle->find('all', array('conditions' => array('$or' => array(array('title' => 'Article 1'), array('title' => 'Article 10'))), 'order' => array('number' => 'ASC')));
     $this->assertEqual($result, $expected);
 }
開發者ID:ZachGambino-GG,項目名稱:cakephp-mongodb,代碼行數:26,代碼來源:mongodb_source.test.php

示例8: executePreparedQuery

 /**
  * Execute prepared query
  * Warning : this function is buggy when it used with serialised datas into an insert or an update statement
  * Use it only for select.
  *
  * @param string $sql : the prepared query to execute
  * @param array $params : the parameters for the query
  * @return void
  * @access private
  */
 public function executePreparedQuery($sql, $params)
 {
     $this->_sql = trim($sql);
     $this->_result = $this->_db->prepare($this->_sql);
     if ($this->_result) {
         if ($this->_result->execute($params)) {
             //the last inserted id only has a sense if it's an insert query
             if (preg_match("#^insert#i", $this->_sql)) {
                 $this->_lastInsertedID = $this->_db->lastInsertId();
             }
             return true;
         }
     }
     $clean_sql = str_replace("\n", "", $this->_sql);
     $clean_sql = preg_replace("#\t+#", " ", $clean_sql);
     $errorInfos = $this->_db->errorInfo();
     $errorInfo = isset($errorInfos[2]) ? $errorInfos[2] : 'no error returned';
     $this->raiseError('Prepared query failed : ' . $errorInfo . "\nQuery : " . $clean_sql . "\nParameters : " . print_r($params, true));
     return false;
 }
開發者ID:davidmottet,項目名稱:automne,代碼行數:30,代碼來源:query.php

示例9: create_tables

/**
 * 創建數據表
 * @param  resource $db 數據庫連接資源
 */
function create_tables($db, $prefix = '')
{
    //讀取SQL文件
    $sql = file_get_contents(MODULE_PATH . 'Data/install.sql');
    $sql = str_replace("\r", "\n", $sql);
    $sql = explode(";\n", $sql);
    //替換表前綴
    $orginal = C('ORIGINAL_TABLE_PREFIX');
    $sql = str_replace(" `{$orginal}", " `{$prefix}", $sql);
    //開始安裝
    show_msg('開始安裝數據庫...');
    foreach ($sql as $value) {
        $value = trim($value);
        if (empty($value)) {
            continue;
        }
        if (substr($value, 0, 12) == 'CREATE TABLE') {
            $name = preg_replace("/^CREATE TABLE IF NOT EXISTS `(\\w+)` .*/s", "\\1", $value);
            $msg = "創建數據表{$name}";
            if (false !== $db->execute($value)) {
                show_msg($msg . '...成功');
            } else {
                show_msg($msg . '...失敗!', 'error');
                session('error', true);
            }
        } else {
            $db->execute($value);
        }
    }
}
開發者ID:fishling,項目名稱:chatPro,代碼行數:34,代碼來源:function.php

示例10: update_tables

/**
 * 更新數據表
 * @param  resource $db 數據庫連接資源
 * @author lyq <605415184@qq.com>
 */
function update_tables($db, $prefix = '')
{
    //讀取SQL文件
    $sql = file_get_contents(MODULE_PATH . 'Data/update.sql');
    $sql = str_replace("\r", "\n", $sql);
    $sql = explode(";\n", $sql);
    //替換表前綴
    $sql = str_replace(" `wp_", " `{$prefix}", $sql);
    //開始安裝
    show_msg('開始升級數據庫...');
    foreach ($sql as $value) {
        $value = trim($value);
        if (empty($value)) {
            continue;
        }
        if (substr($value, 0, 12) == 'CREATE TABLE') {
            $name = preg_replace("/^CREATE TABLE `(\\w+)` .*/s", "\\1", $value);
            $msg = "創建數據表{$name}";
            if (false !== $db->execute($value)) {
                show_msg($msg . '...成功');
            } else {
                show_msg($msg . '...失敗!', 'error');
                session('error', true);
            }
        } else {
            if (substr($value, 0, 8) == 'UPDATE `') {
                $name = preg_replace("/^UPDATE `(\\w+)` .*/s", "\\1", $value);
                $msg = "更新數據表{$name}";
            } else {
                if (substr($value, 0, 11) == 'ALTER TABLE') {
                    $name = preg_replace("/^ALTER TABLE `(\\w+)` .*/s", "\\1", $value);
                    $msg = "修改數據表{$name}";
                } else {
                    if (substr($value, 0, 11) == 'INSERT INTO') {
                        $name = preg_replace("/^INSERT INTO `(\\w+)` .*/s", "\\1", $value);
                        $msg = "寫入數據表{$name}";
                    }
                }
            }
            if ($db->execute($value) !== false) {
                show_msg($msg . '...成功');
            } else {
                show_msg($msg . '...失敗!', 'error');
                session('error', true);
            }
        }
    }
}
開發者ID:chenpusn,項目名稱:haozhixian_bak,代碼行數:53,代碼來源:function.php

示例11: copyTable

 /**
  * Copies the contents of from_table in the first database into the
  * to a to_table of suitable schema in a second database. It assumes the
  * table exists in both databases
  *
  * @param string $from_table name of the table to be copied from
  * @param resource $from_dbm database resource for the from table
  * @param resource $to_table name of the table to be copied to
  * @param resource $to_dbm database resource for the to table
  */
 static function copyTable($from_table, $from_dbm, $to_table, $to_dbm)
 {
     $sql = "SELECT * FROM {$from_table}";
     if (($result = $from_dbm->execute($sql)) === false) {
         return false;
     }
     while ($row = $from_dbm->fetchArray($result)) {
         $statement = "INSERT INTO {$to_table} VALUES (";
         $comma = "";
         foreach ($row as $col => $value) {
             $statement .= $comma . " '" . $to_dbm->escapeString($value) . "'";
             $comma = ",";
         }
         $statement .= ")";
         if ($to_dbm->execute($statement) === false) {
             return false;
         }
     }
     return true;
 }
開發者ID:yakar,項目名稱:yioop,代碼行數:30,代碼來源:datasource_manager.php

示例12: update

 /**
  * Performs an UPDATE on a single table
  * @param string table name
  * @param array associative of field_name => type
  * @param string (optional) SQL where clause
  * @param array associative (optional)  of field_name => value
  * @return boolean true on success, false on failure
  * @access public
  */
 function update($table, $fields, $where = NULL, $extrafields = NULL)
 {
     $query = 'UPDATE ' . $table . $this->buildAssignmentSQL($fields, $extrafields, 'update');
     if (!is_null($where)) {
         $query .= ' WHERE ' . $where;
     }
     return (bool) $this->Connection->execute($query);
 }
開發者ID:ballistiq,項目名稱:revive-adserver,代碼行數:17,代碼來源:mysql.inc.php

示例13: create_tables

/**
 * 創建數據表
 * @param  resource $db 數據庫連接資源
 */
function create_tables($db, $prefix = '')
{
    //讀取SQL文件
    $sql = file_get_contents(MODULE_PATH . 'Data/install.sql');
    show_msg(write_install_log('讀取安裝所需的sql文件:' . MODULE_PATH . 'Data/install.sql'));
    if (file_exists(MODULE_PATH . 'Data/data.sql')) {
        $sql .= "\n" . file_get_contents(MODULE_PATH . 'Data/data.sql');
        show_msg(write_install_log('自動讀取檢測到的表數據文件:' . MODULE_PATH . 'Data/data.sql'));
    }
    if (file_exists(MODULE_PATH . 'Data/patch.sql')) {
        $sql .= "\n" . file_get_contents(MODULE_PATH . 'Data/patch.sql');
        show_msg(write_install_log('自動讀取檢測到的補丁sql文件:' . MODULE_PATH . 'Data/patch.sql'));
    }
    $other_patch = glob(MODULE_PATH . 'Data/patch_*.sql');
    if ($other_patch) {
        foreach ($other_patch as $value) {
            $sql .= "\n" . file_get_contents($value);
            show_msg(write_install_log('自動讀取檢測到的補丁sql文件:' . $value));
        }
    }
    //替換表前綴
    $orginal = C('ORIGINAL_TABLE_PREFIX');
    $sql = str_replace(" `{$orginal}", " `{$prefix}", $sql);
    $sql = str_replace("\r", "\n", $sql);
    $sql = explode(";\n", $sql);
    //開始安裝
    show_msg(write_install_log('開始安裝數據庫...'));
    foreach ($sql as $value) {
        $value = trim($value);
        if (empty($value)) {
            continue;
        }
        $value = preg_replace('/[\\r\\n]+[ \\t]*--[^\\n]*\\n/', '', $value);
        $value = preg_replace('/^[ \\t]*--[^\\n]*\\n/', '', $value);
        $value = trim($value);
        if (empty($value)) {
            continue;
        }
        if (substr($value, 0, 12) == 'CREATE TABLE') {
            $name = preg_replace("/^CREATE TABLE IF NOT EXISTS `(\\w+)` .*/s", "\\1", $value);
            $msg = "創建數據表{$name}";
            if (false !== $db->execute($value)) {
                show_msg(write_install_log($msg . '...成功'));
            } else {
                show_msg(write_install_log($msg . '...失敗!'), 'error');
                session('error', true);
            }
        } else {
            if (false !== $db->execute($value)) {
                write_install_log($value . '...成功');
            } else {
                write_install_log($value . '...失敗');
            }
        }
    }
}
開發者ID:admpub,項目名稱:OpenCenter,代碼行數:60,代碼來源:function.php

示例14: execute

 /**
  * Execute the SQL statement.
  *
  * @return  mixed  A database cursor resource on success, boolean false on failure.
  *
  * @since   1.0
  * @throws  \Exception
  * @throws  \RuntimeException
  */
 public function execute()
 {
     static $isReconnecting = false;
     $this->connect();
     if (!is_object($this->connection)) {
         throw new \RuntimeException($this->errorMsg, $this->errorNum);
     }
     // Take a local copy so that we don't modify the original query and cause issues later
     $sql = $this->replacePrefix((string) $this->sql);
     if ($this->limit > 0 || $this->offset > 0) {
         // @TODO
         $sql .= ' LIMIT ' . $this->offset . ', ' . $this->limit;
     }
     // Increment the query counter.
     $this->count++;
     // If debugging is enabled then let's log the query.
     if ($this->debug) {
         // Add the query to the object queue.
         $this->log[] = $sql;
     }
     // Reset the error values.
     $this->errorNum = 0;
     $this->errorMsg = '';
     // Execute the query.
     $this->executed = false;
     if ($this->prepared instanceof \PDOStatement) {
         // Bind the variables:
         if ($this->sql instanceof ADatabaseQueryPreparable) {
             $bounded =& $this->sql->getBounded();
             foreach ($bounded as $key => $obj) {
                 $this->prepared->bindParam($key, $obj->value, $obj->dataType, $obj->length, $obj->driverOptions);
             }
         }
         $this->executed = $this->prepared->execute();
     }
     // If an error occurred handle it.
     if (!$this->executed) {
         // Get the error number and message before we execute any more queries.
         $errorNum = (int) $this->connection->errorCode();
         $errorMsg = (string) 'SQL: ' . implode(", ", $this->connection->errorInfo());
         // Check if the server was disconnected.
         if (!$this->connected() && !$isReconnecting) {
             $isReconnecting = true;
             try {
                 // Attempt to reconnect.
                 $this->connection = null;
                 $this->connect();
             } catch (\RuntimeException $e) {
                 // Get the error number and message.
                 $this->errorNum = (int) $this->connection->errorCode();
                 $this->errorMsg = (string) 'SQL: ' . implode(", ", $this->connection->errorInfo());
                 // Throw the normal query exception.
                 throw new \RuntimeException($this->errorMsg, $this->errorNum);
             }
             // Since we were able to reconnect, run the query again.
             $result = $this->execute();
             $isReconnecting = false;
             return $result;
         } else {
             // Get the error number and message from before we tried to reconnect.
             $this->errorNum = $errorNum;
             $this->errorMsg = $errorMsg;
             // Throw the normal query exception.
             throw new \RuntimeException($this->errorMsg, $this->errorNum);
         }
     }
     return $this->prepared;
 }
開發者ID:akeeba,項目名稱:angie,代碼行數:77,代碼來源:pdo.php

示例15: executeMultiple

 /**
  * This function does several execute() calls on the same statement handle.
  * $params must be an array indexed numerically from 0, one execute call is
  * done for every 'row' in the array.
  *
  * If an error occurs during execute(), executeMultiple() does not execute
  * the unfinished rows, but rather returns that error.
  *
  * @param resource $stmt query handle from prepare()
  * @param array $params numeric array containing the
  *        data to insert into the query
  * @return mixed a result handle or MDB2_OK on success, a MDB2 error on failure
  * @access public
  * @see prepare(), execute()
  */
 function executeMultiple(&$stmt, $params = null)
 {
     for ($i = 0, $j = count($params); $i < $j; $i++) {
         $stmt->bindParamArray($params[$i]);
         $result = $stmt->execute();
         if (PEAR::isError($result)) {
             return $result;
         }
     }
     return MDB2_OK;
 }
開發者ID:BackupTheBerlios,項目名稱:wcms,代碼行數:26,代碼來源:Extended.php


注:本文中的resource::execute方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。