oci_commit

(PHP 5, PHP 7, PECL OCI8 >= 1.1.0)

oci_commit�ύδִ�е�������

˵��

oci_commit ( resource $connection ) : bool

oci_commit() �� Oracle ���� connection ���������е�����������δִ�е�����ύ����

Example #1 oci_commit() ����

<?php
    
// Login to Oracle server
    
$conn oci_connect('scott''tiger');

    
// Parse SQL
    
$stmt oci_parse($conn"
                              INSERT INTO
                                         employees (name, surname)
                                   VALUES
                                         ('Maxim', 'Maletsky')
                             "
);

    
/* Execute statement
       OCI_DEFAULT tells oci_execute()
       not to commit statement immediately */
    
oci_execute($stmtOCI_DEFAULT);

    
/*
    ....
    Parsing and executing other statements here ...
    ....
    */

    // Commit transaction
    
$committed oci_commit($conn);

    
// Test whether commit was successful. If error occurred, return error message
    
if (!$committed) {
        
$error oci_error($conn);
        echo 
'Commit failed. Oracle reports: ' $error['message'];
    }

?>

�ɹ�ʱ���� TRUE�� ������ʧ��ʱ���� FALSE��

Note:

���ر����ӻ�ű�����ʱ�����ĸ��ȣ�������Զ��ؾ���Ҫ��ȷ�ص��� oci_commit() ���ύ���񣬻� oci_rollback() ����ֹ����

Note:

�� PHP 5.0.0 ֮ǰ�İ汾����ʹ�� ocicommit() ������������ú�������Ȼ���ã�Ϊ���¼�����Ϊ oci_commit() �ı������������ѱ����������Ƽ�ʹ�á�

�μ� oci_rollback() �� oci_execute()��

����

connection

An Oracle connection identifier, returned by oci_connect(), oci_pconnect(), or oci_new_connect().

����ֵ

�ɹ�ʱ���� TRUE�� ������ʧ��ʱ���� FALSE��

����

Example #2 oci_commit() example

<?php

// Insert into several tables, rolling back the changes if an error occurs

$conn oci_connect('hr''welcome''localhost/XE');

$stid oci_parse($conn"INSERT INTO mysalary (id, name) VALUES (1, 'Chris')");

// The OCI_NO_AUTO_COMMIT flag tells Oracle not to commit the INSERT immediately
// Use OCI_DEFAULT as the flag for PHP <= 5.3.1.  The two flags are equivalent
$r oci_execute($stidOCI_NO_AUTO_COMMIT);
if (!
$r) {    
    
$e oci_error($stid);
    
trigger_error(htmlentities($e['message']), E_USER_ERROR);
}

$stid oci_parse($conn'INSERT INTO myschedule (startday) VALUES (12)');
$r oci_execute($stidOCI_NO_AUTO_COMMIT);
if (!
$r) {    
    
$e oci_error($stid);
    
oci_rollback($conn);  // rollback changes to both tables
    
trigger_error(htmlentities($e['message']), E_USER_ERROR);
}

// Commit the changes to both tables
$r oci_commit($conn);
if (!
r) {
    
$e oci_error($conn);
    
trigger_error(htmlentities($e['message']), E_USER_ERROR);
}

?>

ע��

Note:

Transactions are automatically rolled back when you close the connection, or when the script ends, whichever is soonest. You need to explicitly call oci_commit() to commit the transaction.

Any call to oci_execute() that uses OCI_COMMIT_ON_SUCCESS mode explicitly or by default will commit any previous uncommitted transaction.

Any Oracle DDL statement such as CREATE or DROP will automatically commit any uncommitted transaction.

Note:

In PHP versions before 5.0.0 you must use ocicommit() instead. �ڵ�ǰ�汾�У��ɵĺ����������Ա�ʹ�ã����Ѿ���������������ʹ�á�

�μ�