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


PHP mysqli::multi_query方法代碼示例

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


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

示例1: change_database_structure

 /**
  * Do NOT use in code, to be used by database_manager only!
  * @param string|array $sql query
  * @param array|null $tablenames an array of xmldb table names affected by this request.
  * @return bool true
  * @throws ddl_change_structure_exception A DDL specific exception is thrown for any errors.
  */
 public function change_database_structure($sql, $tablenames = null)
 {
     $this->get_manager();
     // Includes DDL exceptions classes ;-)
     if (is_array($sql)) {
         $sql = implode("\n;\n", $sql);
     }
     try {
         $this->query_start($sql, null, SQL_QUERY_STRUCTURE);
         $result = $this->mysqli->multi_query($sql);
         if ($result === false) {
             $this->query_end(false);
         }
         while ($this->mysqli->more_results()) {
             $result = $this->mysqli->next_result();
             if ($result === false) {
                 $this->query_end(false);
             }
         }
         $this->query_end(true);
     } catch (ddl_change_structure_exception $e) {
         while (@$this->mysqli->more_results()) {
             @$this->mysqli->next_result();
         }
         $this->reset_caches($tablenames);
         throw $e;
     }
     $this->reset_caches($tablenames);
     return true;
 }
開發者ID:rushi963,項目名稱:moodle,代碼行數:37,代碼來源:mysqli_native_moodle_database.php

示例2: executeMulti

 public function executeMulti($sql)
 {
     if (!$this->connection) {
         $this->open();
     }
     $ret = $this->connection->multi_query($sql);
     if (!$ret) {
         $errMsg = "Can't Execute Query:" . $sql;
         $errMsg .= "\n MySQL Message:" . $this->connection->error;
         throw new \RuntimeException($errMsg);
     }
     do {
         if ($this->connection->errno) {
             $errMsg = "Can't Execute Query:" . $sql;
             $errMsg .= "\n MySQL Message:" . $this->connection->error;
             throw new \RuntimeException($errMsg);
         }
         if ($result = $this->connection->store_result()) {
             $result->free_result();
         }
         if (!$this->connection->more_results()) {
             break;
         }
     } while ($this->connection->next_result());
     return $ret;
 }
開發者ID:aainc,項目名稱:Scruit,代碼行數:26,代碼來源:Session.php

示例3: MultiQuery

 /**
  * Preform multiple queries on the Database
  * @param string $sql 
  * @return boolean|mysqli_result
  */
 public function MultiQuery($sql)
 {
     $rs = static::$link->multi_query($sql);
     if ($rs) {
         static::__setLastResult($rs);
     }
     static::__setResults($rs);
     return $rs;
 }
開發者ID:swiftie821,項目名稱:DBConnector,代碼行數:14,代碼來源:connector.php

示例4: persistAuditLogs

 public static function persistAuditLogs()
 {
     if (!is_array($_SESSION['auditLog']['sql']) || count($_SESSION['auditLog']['sql']) <= 0) {
         return;
     }
     $config = $_SESSION['auditLog']['database'];
     $hostname = $config['params']['host'];
     $username = $config['params']['username'];
     $password = $config['params']['password'];
     $dbname = $config['params']['dbname'];
     // in the meantime, just use mysqli because of its multi-query support
     $mysqli = new mysqli($hostname, $username, $password, $dbname);
     /* check connection */
     $retry = 10;
     // 10 seconds to retry
     $ctr = 0;
     do {
         $err = mysqli_connect_errno();
     } while ($err && $ctr++ < $retry);
     if ($err) {
         printf("Connect failed: %s\n", mysqli_connect_error());
         return;
     }
     // generate queries
     $queries = implode(";\n", $_SESSION['auditLog']['sql']);
     /* execute multi query */
     $mysqli->multi_query($queries);
     /* close connection */
     $mysqli->close();
 }
開發者ID:psoas,項目名稱:ch3-dev-preview,代碼行數:30,代碼來源:App.php

示例5: create_tables

 public function create_tables($data)
 {
     // Connect to the database
     $mysqli = new mysqli($data['db_hostname'], $data['db_username'], $data['db_password'], $data['db_database']);
     // Check for errors
     if (mysqli_connect_errno()) {
         return false;
     }
     // Open the default SQL file
     $query = file_get_contents('assets/install.sql');
     $pw = $this->password($data['admin_password']);
     $handled_enc = $this->handle_enc_pms($data);
     $new = str_replace("%ENCRYPT_PRIVATE_MESSAGES%", $data['encrypt_private_messages'], $query);
     $new = str_replace("%ALLOW_GUESTS%", $data['allow_guests'], $new);
     $new = str_replace("%FORCE_VENDOR_PGP%", $data['force_vendor_pgp'], $new);
     $new = str_replace("%ELECTRUM_MPK%", $data['electrum_mpk'], $new);
     $new = str_replace("%PASSWORD%", $pw['hash'], $new);
     $new = str_replace("%PUBLIC_KEY%", $handled_enc['public_key'], $new);
     $new = str_replace("%PRIVATE_KEY%", $handled_enc['private_key'], $new);
     $new = str_replace("%PRIVATE_KEY_SALT%", $handled_enc['private_key_salt'], $new);
     $new = str_replace("%REGISTER_TIME%", time(), $new);
     $new = str_replace("%USER_HASH%", substr(hash('sha512', mcrypt_create_iv(32, MCRYPT_DEV_URANDOM)), 0, 16), $new);
     $new = str_replace("%SALT%", $pw['salt'], $new);
     // Execute a multi query
     $mysqli->multi_query($new);
     if (mysqli_connect_errno()) {
         var_dump($mysqli);
         return false;
     }
     // Close the connection
     $mysqli->close();
     return true;
 }
開發者ID:marketcoinfork,項目名稱:BitWasp-Fork,代碼行數:33,代碼來源:database_class.php

示例6: InitializeData

 function InitializeData()
 {
     $this->TruncateTables();
     $r = $this->Connection->multi_query($this->GetDataSQL());
     while ($this->Connection->more_results()) {
         $this->Connection->next_result();
     }
 }
開發者ID:michalkoczwara,項目名稱:WebGoatPHP,代碼行數:8,代碼來源:mysqli.php

示例7: multiQuery

 /**
  * Performs multiple SQL queries. Results are flushed and not returned. Useful for multiple updates and inserts.
  *
  * @param string $multiSql semicolon separated queries to be sent to the DB
  *
  * @return void
  * @throws \iveeCore\Exceptions\SQLErrorException when the query execution errors out
  */
 public function multiQuery($multiSql)
 {
     $startTime = microtime(true);
     if (!$this->db->multi_query($multiSql)) {
         $exceptionClass = Config::getIveeClassName('SQLErrorException');
         throw new $exceptionClass($this->db->error . "\nQuery: " . $multiSql, $this->db->errno);
     }
     //gather stats about queries
     $this->addQueryTime(microtime(true) - $startTime);
     $this->flushDbResults();
 }
開發者ID:Covert-Inferno,項目名稱:iveeCore,代碼行數:19,代碼來源:SDE.php

示例8: makeInstallation

function makeInstallation($s)
{
    if ($s['createDb']) {
        /* create BDD */
        $mysqli = new mysqli($s['db_adress'], $s['db_user'], $s['db_password']);
        /* check connection */
        if ($mysqli->connect_errno) {
            printf("Connect failed: %s\n", $mysqli->connect_error);
            exit(24);
        }
        $q = "CREATE DATABASE IF NOT EXISTS `" . $s['db_schema'] . "` /*!40100 DEFAULT CHARACTER SET utf8 */;";
        //echo "Création BDD ::".$q;
        //exit;
        if (!$mysqli->query($q)) {
            echo "Création BDD impossible";
            exit;
        }
        $mysqli->close();
    }
    $mysqli = new mysqli($s['db_adress'], $s['db_user'], $s['db_password'], $s['db_schema']);
    /* execute multi query */
    $mysqli->multi_query(file_get_contents('install/install.sql'));
    while ($mysqli->next_result()) {
    }
    // flush multi_queries
    /* init de la table des dates de reference */
    $start_day = mktime(0, 0, 0, 9, 1, 2014);
    //1er septembre 2014
    $stop_day = mktime(0, 0, 0, 9, 1, 2037);
    //justqu'au 1er septembre 2037, on verra en 2037 si j'utilise encore l'app.
    $nb_day = ($stop_day - $start_day) / 86400;
    $query = "INSERT INTO oko_dateref (jour) VALUES ";
    for ($i = 0; $i <= $nb_day; $i++) {
        $day = date('Y-m-d', mktime(0, 0, 0, date("m", $start_day), date("d", $start_day) + $i, date("Y", $start_day)));
        $query .= "('" . $day . "'),";
    }
    $query = substr($query, 0, strlen($query) - 1) . ";";
    //print_r($query);exit;
    $mysqli->query($query);
    $mysqli->close();
    /* Make Config.php */
    $configFile = file_get_contents('config_sample.php');
    $configFile = str_replace("###_BDD_IP_###", $s['db_adress'], $configFile);
    $configFile = str_replace("###_BDD_USER_###", $s['db_user'], $configFile);
    $configFile = str_replace("###_BDD_PASS_###", $s['db_password'], $configFile);
    $configFile = str_replace("###_BDD_SCHEMA_###", $s['db_schema'], $configFile);
    $configFile = str_replace("###_CONTEXT_###", getcwd(), $configFile);
    $configFile = str_replace("###_TOKEN_###", sha1(rand()), $configFile);
    //$configFile = str_replace("###_TOKEN-API_###",sha1(rand()),$configFile);
    file_put_contents('config.php', $configFile);
    /* Make config.json */
    $param = array("chaudiere" => $s['oko_ip'], "tc_ref" => $s['param_tcref'], "poids_pellet" => $s['param_poids_pellet'], "surface_maison" => $s['surface_maison'], "get_data_from_chaudiere" => $s['oko_typeconnect'], "send_to_web" => "0");
    file_put_contents('config.json', json_encode($param));
}
開發者ID:stawen,項目名稱:okovision,代碼行數:54,代碼來源:setup.php

示例9: multi_query

 /**
  * @param string $query
  * @return bool|null
  */
 public function multi_query($query)
 {
     $result = parent::multi_query($query);
     if ($this->errno) {
         $error = $this->error;
         $this->rollback();
         $this->ThrowQueryError($query, $error);
         return null;
     } else {
         return $result;
     }
 }
開發者ID:Riges,項目名稱:KawaiViewModel,代碼行數:16,代碼來源:MySQL.php

示例10: ExecuteMultiQuery

 /**
  * Executes a multi query string; typically concatenated by semicolon
  * @param sring $query
  * @throws DBExceptions\DatabaseException Raises an exception in case of an error
  */
 public function ExecuteMultiQuery($query)
 {
     $result = $this->db->multi_query($query);
     if ($result) {
         while ($this->db->next_result()) {
         }
         //overgo the results!
     }
     if (!$result) {
         throw new DBExceptions\DatabaseException('Error in multi query', 101, $query);
     }
 }
開發者ID:agentmedia,項目名稱:phine-framework,代碼行數:17,代碼來源:Connection.php

示例11: getSQLResultSet

function getSQLResultSet($commando)
{
    $mysqli = new mysqli("localhost", "root", "12345", "conexionandroid");
    $mysqli->query("SET NAMES 'utf8'");
    if ($mysqli->connect_error) {
        printf("Connect failed: %s\n", $mysqli->connect_error);
        exit;
    }
    if ($mysqli->multi_query($commando)) {
        return $mysqli->store_result();
    }
    $mysqli->close();
}
開發者ID:KellyA1D5J,項目名稱:Otros,代碼行數:13,代碼來源:functions.php

示例12: query

 /**
  * @param $query
  * @return bool|mysqli_result
  */
 public function query($query)
 {
     if ($res = $this->link->multi_query($query)) {
         do {
             if ($res = mysqli_store_result($this->link)) {
                 mysqli_free_result($res);
             }
             if (mysqli_more_results($this->link)) {
             }
         } while (mysqli_next_result($this->link));
     }
     return $res;
 }
開發者ID:enderteszla,項目名稱:phpframework-etc,代碼行數:17,代碼來源:DB.php

示例13: xquery

 /**
  * 發送批量查詢語句
  * 記作一次查詢,隻返回最後的查詢結果
  */
 public function xquery($sql, $noerror = false)
 {
     $this->result = $this->conn->multi_query($sql);
     $this->queryCount++;
     if (!$this->result) {
         if ($noerror == true) {
             return false;
         } else {
             throw new Exception("MySQL 批量語句執行錯誤:<br/><b>語句:</b>{$sql}<br/><b>錯誤:</b>" . $this->geterror(), 10000);
         }
     } else {
         return $this->result;
     }
 }
開發者ID:wan-qy,項目名稱:Tieba-Cloud-Sign,代碼行數:18,代碼來源:class.mysqli.php

示例14: init

 public function init()
 {
     $this->load->helper(array('form', 'file', 'url'));
     $this->load->library(array('form_validation'));
     $cartPath = dirname(FCPATH);
     $testConfig = is_writeable($cartPath . '/application/config/');
     $testUploads = is_writeable($cartPath . '/uploads/');
     $testIntl = class_exists('Locale');
     $errors = !$testConfig ? '<div class="alert alert-danger" role="alert">The folder "' . $cartPath . '/application/config" must be writable.</div>' : '';
     $errors .= !$testUploads ? '<div class="alert alert-danger" role="alert">The folder "' . $cartPath . '/uploads" must be writable.</div>' : '';
     $errors .= !$testIntl ? '<div class="alert alert-danger" role="alert">The PHP_INTL Library is required for GoCart and is not installed on your server. <a href="http://php.net/manual/en/book.intl.php">Read More</a></div>' : '';
     $this->form_validation->set_rules('hostname', 'Hostname', 'required');
     $this->form_validation->set_rules('database', 'Database Name', 'required');
     $this->form_validation->set_rules('username', 'Username', 'required');
     $this->form_validation->set_rules('password', 'Password', 'trim|required');
     $this->form_validation->set_rules('prefix', 'Database Prefix', 'trim');
     if ($this->form_validation->run() == FALSE || $errors != '') {
         $this->form_validation->set_error_delimiters('<div class="alert alert-danger">', '</div>');
         $errors .= validation_errors();
         $this->load->view('index', ['errors' => $errors]);
     } else {
         $dbCred = $this->input->post();
         //test the database
         mysqli_report(MYSQLI_REPORT_STRICT);
         try {
             $db = new mysqli($dbCred['hostname'], $dbCred['username'], $dbCred['password'], $dbCred['database']);
         } catch (Exception $e) {
             $errors = '<div class="alert alert-danger" role="alert">There was an error connecting to the database</div>';
             $this->load->view('index', ['errors' => $errors]);
             return;
         }
         //create the database file
         $database = $this->load->view('database', $this->input->post(), true);
         $myfile = fopen($cartPath . '/application/config/database.php', "w");
         fwrite($myfile, $database);
         fclose($myfile);
         $sql = str_replace('gc_', $dbCred['prefix'], file_get_contents(FCPATH . 'database.sql'));
         $db->multi_query($sql);
         // run the dump
         while ($db->more_results() && $db->next_result()) {
         }
         //run through it
         //set some basic information in settings
         $query = "INSERT INTO `{$dbCred['prefix']}settings` (`code`, `setting_key`, `setting`) VALUES\n\t\t\t('gocart', 'theme', 'default'),\n\t\t\t('gocart', 'locale', 'en_US'),\n\t\t\t('gocart', 'currency_iso', 'USD'),\n\t\t\t('gocart', 'new_customer_status', '1'),\n\t\t\t('gocart', 'order_statuses', '{\"Order Placed\":\"Order Placed\",\"Pending\":\"Pending\",\"Processing\":\"Processing\",\"Shipped\":\"Shipped\",\"On Hold\":\"On Hold\",\"Cancelled\":\"Cancelled\",\"Delivered\":\"Delivered\"}'),\n\t\t\t('gocart', 'products_per_page', '24'),\n\t\t\t('gocart', 'default_meta_description', 'Thanks for installing GoCart.'),\n\t\t\t('gocart', 'default_meta_keywords', 'open source, ecommerce'),\n\t\t\t('gocart', 'timezone', 'UTC');";
         $db->query($query);
         $db->close();
         $url = dirname((isset($_SERVER['HTTPS']) ? 'https://' : 'http://') . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']) . '/admin';
         header('Location: ' . dirname($url) . '/admin');
     }
 }
開發者ID:thijmenvenus,項目名稱:GoCart3,代碼行數:50,代碼來源:Installer.php

示例15: addUserData

 function addUserData($userName, $firstName, $lastName, $staffId, $designation, $email_Id, $phoneNumber)
 {
     $sql = "INSERT INTO `nicdata`(`userName`, `firstName`, `lastName`, `staffId`, `designation`, `email_Id`,`phoneNumber`) ";
     $sql .= "VALUES ('" . $userName . "','" . $firstName . "','" . $lastName . "','" . $staffId . "','" . $designation . "','" . $email_Id . "','" . $phoneNumber . "')";
     echo $sql;
     $conn = new mysqli(constant("SERVER_NAME_NIC"), constant("DB_USER_NIC"), constant("DB_PASSWORD_NIC"), constant("DB_NAME_NIC"));
     if ($conn->connect_error) {
         die("Connection failed: " . $conn->connect_error);
     }
     if ($conn->multi_query($sql) === true) {
         $result = "Success";
     }
     $conn->close();
 }
開發者ID:nagyist,項目名稱:Samarthya,代碼行數:14,代碼來源:dal.nicportal.php


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