当前位置: 首页>>代码示例>>PHP>>正文


PHP pg_transaction_status函数代码示例

本文整理汇总了PHP中pg_transaction_status函数的典型用法代码示例。如果您正苦于以下问题:PHP pg_transaction_status函数的具体用法?PHP pg_transaction_status怎么用?PHP pg_transaction_status使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。


在下文中一共展示了pg_transaction_status函数的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: castLink

 public static function castLink($link, array $a, Stub $stub, $isNested)
 {
     $a['status'] = pg_connection_status($link);
     $a['status'] = new ConstStub(PGSQL_CONNECTION_OK === $a['status'] ? 'PGSQL_CONNECTION_OK' : 'PGSQL_CONNECTION_BAD', $a['status']);
     $a['busy'] = pg_connection_busy($link);
     $a['transaction'] = pg_transaction_status($link);
     if (isset(self::$transactionStatus[$a['transaction']])) {
         $a['transaction'] = new ConstStub(self::$transactionStatus[$a['transaction']], $a['transaction']);
     }
     $a['pid'] = pg_get_pid($link);
     $a['last error'] = pg_last_error($link);
     $a['last notice'] = pg_last_notice($link);
     $a['host'] = pg_host($link);
     $a['port'] = pg_port($link);
     $a['dbname'] = pg_dbname($link);
     $a['options'] = pg_options($link);
     $a['version'] = pg_version($link);
     foreach (self::$paramCodes as $v) {
         if (false !== ($s = pg_parameter_status($link, $v))) {
             $a['param'][$v] = $s;
         }
     }
     $a['param']['client_encoding'] = pg_client_encoding($link);
     $a['param'] = new EnumStub($a['param']);
     return $a;
 }
开发者ID:JesseDarellMoore,项目名称:CS499,代码行数:26,代码来源:PgSqlCaster.php

示例2: inTransaction

 /**
  * testa se a existe transacao ativa na conexao corrente;.
  * @return boolean
  */
 function inTransaction()
 {
     global $conn;
     $isIntransaction = false;
     $lStatus = pg_transaction_status($conn);
     switch ($lStatus) {
         // sem transacao em  (0)
         case PGSQL_TRANSACTION_IDLE:
             $isIntransaction = false;
             break;
             //em Transacao Ativa, comando sendo executado  (1)
         //em Transacao Ativa, comando sendo executado  (1)
         case PGSQL_TRANSACTION_ACTIVE:
             $isIntransaction = true;
             break;
             //transacao em andamento  (2)
         //transacao em andamento  (2)
         case PGSQL_TRANSACTION_INTRANS:
             $isIntransaction = true;
             break;
             //transacao com erro  (3)
         //transacao com erro  (3)
         case PGSQL_TRANSACTION_INERROR:
             $isIntransaction = false;
             break;
             //falha na conexao; (4);
         //falha na conexao; (4);
         case PGSQL_TRANSACTION_UNKNOWN:
             $isIntransaction = false;
             break;
     }
     return $isIntransaction;
 }
开发者ID:arendasistemasintegrados,项目名称:mateusleme,代码行数:37,代码来源:db_utils.php

示例3: inTransaction

 /**
  * Is in transaction?
  * @return bool
  */
 public function inTransaction()
 {
     return !in_array(pg_transaction_status($this->connection), array(PGSQL_TRANSACTION_UNKNOWN, PGSQL_TRANSACTION_IDLE), TRUE);
 }
开发者ID:kravco,项目名称:dibi,代码行数:8,代码来源:postgre.php

示例4: update

 public function update()
 {
     $this->mNewState = array(pg_connection_status($this->mConn), pg_transaction_status($this->mConn));
 }
开发者ID:nischayn22,项目名称:mediawiki-core,代码行数:4,代码来源:DatabasePostgres.php

示例5: inTransaction

 /**
  * Checks whether a transaction is currently open.
  *
  * @return  bool
  */
 public function inTransaction()
 {
     $status = pg_transaction_status($this->getResource());
     return PGSQL_TRANSACTION_INTRANS === $status || PGSQL_TRANSACTION_INERROR === $status;
 }
开发者ID:sad-spirit,项目名称:pg-wrapper,代码行数:10,代码来源:Connection.php

示例6: getTransactionStatus

 /**
  * getTransactionStatus
  *
  * Return the current transaction status.
  * Return a PHP constant.
  * @see http://fr2.php.net/manual/en/function.pg-transaction-status.php
  *
  * @access public
  * @return int
  */
 public function getTransactionStatus()
 {
     return pg_transaction_status($this->handler);
 }
开发者ID:SebLours,项目名称:Foundation,代码行数:14,代码来源:Connection.php

示例7: rollback

rollback($savepoint=NULL){$this->query($savepoint?"ROLLBACK TO SAVEPOINT $savepoint":'ROLLBACK');}function
inTransaction(){return!in_array(pg_transaction_status($this->connection),array(PGSQL_TRANSACTION_UNKNOWN,PGSQL_TRANSACTION_IDLE),TRUE);}function
开发者ID:nosko,项目名称:socialSearch,代码行数:2,代码来源:dibi.min.php

示例8: __destruct

 /**
  * Деструктор. Закрывает открытую транзакцию и записывает в файл(ы) debug информацию.
  *
  */
 public function __destruct()
 {
     --self::$objects;
     if ($this->debugLog) {
         $log = new log("db/" . $this->alias . "/debug/" . $this->debug);
         for ($i = 0; $i < count($this->debugLog); $i++) {
             $log->writeln($this->debugLog[$i]['text']);
         }
     }
     $log = new log("db/" . $this->alias . '/' . date('Y-m-d') . ".log");
     if ($this->log) {
         $log->writeln($this->log);
     }
     if ($this->_transaction) {
         $rollback = false;
         $xstat = pg_transaction_status($this->_transaction);
         $xcodes = array(PGSQL_TRANSACTION_UNKNOWN => 'PGSQL_TRANSACTION_UNKNOWN', PGSQL_TRANSACTION_IDLE => 'PGSQL_TRANSACTION_IDLE', PGSQL_TRANSACTION_INTRANS => 'PGSQL_TRANSACTION_INTRANS', PGSQL_TRANSACTION_INERROR => 'PGSQL_TRANSACTION_INERROR', PGSQL_TRANSACTION_ACTIVE => 'PGSQL_TRANSACTION_ACTIVE');
         switch ($xstat) {
             case PGSQL_TRANSACTION_INTRANS:
             case PGSQL_TRANSACTION_INERROR:
             case PGSQL_TRANSACTION_ACTIVE:
                 $rollback = true;
                 break;
         }
         if ($rollback) {
             $err = "Transaction status is BAD and it rollbacked: {$xcodes[$xstat]}, name=" . $this->alias;
             $this->rollback();
         } else {
             $err = "Transaction counter is BAD on DESTRUCT: status {$xcodes[$xstat]}";
             $this->_transaction = NULL;
         }
         $this->err($err);
     }
     if (!self::$objects) {
         setLastUserAction();
         if (DB::$_stby_log) {
             // можно убрать, отладочное.
             $stby_db = new DB('stat');
             setlocale(LC_ALL, 'en_US.UTF-8');
             foreach (DB::$_stby_log as $key => $val) {
                 list($val['day'], $val['real_mask'], $val['opts']) = explode('=', $key);
                 $sql = "\n                      UPDATE stby_log2\n                         SET master_cnt = master_cnt + ?i, standby_cnt = standby_cnt + ?i,\n                             master_time = master_time + interval ?, standby_time = standby_time + ?, ro_errors_cnt = ro_errors_cnt + ?i\n                       WHERE day = ? AND opts = ? AND real_mask = ?i\n                    ";
                 $res = $stby_db->query($sql, (int) $val['master_cnt'], (int) $val['standby_cnt'], (double) $val['master_time'] . ' seconds', (double) $val['standby_time'] . ' seconds', (int) $val['ro_errors_cnt'], $val['day'], $val['opts'], (int) $val['real_mask']);
                 if (!pg_affected_rows($res)) {
                     $sql = "\n                          INSERT INTO stby_log2 (master_cnt, standby_cnt, master_time, standby_time, ro_errors_cnt, day, opts, real_mask)\n                          VALUES (?i, ?i, ?, ?, ?i, ?, ?, ?i)\n                        ";
                     $stby_db->query($sql, (int) $val['master_cnt'], (int) $val['standby_cnt'], (double) $val['master_time'] . ' seconds', (double) $val['standby_time'] . ' seconds', (int) $val['ro_errors_cnt'], $val['day'], $val['opts'], (int) $val['real_mask']);
                 }
             }
         }
         DB::$_stby_log = array();
     }
 }
开发者ID:Nikitian,项目名称:fl-ru-damp,代码行数:56,代码来源:DB.php

示例9: status

 function status()
 {
     return pg_transaction_status($this->db);
 }
开发者ID:Kloadut,项目名称:noalyss_ynh,代码行数:4,代码来源:class_database.php

示例10: pg_pconnect

// connection function tests
include 'config.inc';
$db = pg_pconnect($conn_str);
var_dump($db);
if (pg_connection_status($db) != PGSQL_CONNECTION_OK) {
    echo "pg_connection_status() error\n";
}
if (!pg_connection_reset($db)) {
    echo "pg_connection_reset() error\n";
}
if (pg_connection_busy($db)) {
    echo "pg_connection_busy() error\n";
}
if (function_exists('pg_transaction_status')) {
    if (pg_transaction_status($db) != PGSQL_TRANSACTION_IDLE) {
        echo "pg_transaction_status() error\n";
    }
}
if (false === pg_host($db)) {
    echo "pg_host() error\n";
}
if (!pg_dbname($db)) {
    echo "pg_dbname() error\n";
}
if (!pg_port($db)) {
    echo "pg_port() error\n";
}
if (pg_tty($db)) {
    echo "pg_tty() error\n";
}
开发者ID:badlamer,项目名称:hhvm,代码行数:30,代码来源:02connection.php

示例11: rollback

 /**
  * Reverts the current transaction
  *
  * @return int  DB_OK on success.  A DB_Error object on failure.
  */
 function rollback()
 {
     if (pg_transaction_status($this->connection) == PGSQL_TRANSACTION_INTRANS) {
         $this->transaction_opcount = 1;
     }
     if ($this->transaction_opcount > 0) {
         $result = @pg_exec($this->connection, 'abort;');
         $this->transaction_opcount = 0;
         if (!$result) {
             return $this->pgsqlRaiseError();
         }
     }
     return DB_OK;
 }
开发者ID:roojs,项目名称:pear,代码行数:19,代码来源:pgsql.php


注:本文中的pg_transaction_status函数示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。