PHP 8.4.3 Released!

odbc_autocommit

(PHP 4, PHP 5, PHP 7, PHP 8)

odbc_autocommitПереключает поведение автоматической фиксации

Описание

odbc_autocommit(Odbc\Connection $odbc, ?bool $enable = null): int|bool

Функция переключает поведение автоматической фиксации.

По умолчанию для подключения включена автоматическая фиксация. Отключение автоматической фиксации эквивалентно запуску транзакции.

Список параметров

odbc

Объект ODBC-соединения. Подробнее о коннекторе рассказывает описание функции odbc_connect().

enable

Со значением true параметр enable включает автоматическую фиксацию, со значением false — отключает. Функция возвращает статус автофиксации в соединении odbc, если в этот параметр передали значение null.

Возвращаемые значения

Функция возвращает статус автоматической фиксации для подключения, которое передали в параметр odbc, если в параметр enable передали значение null. Функция возвращает ненулевое значение, если автоматическая фиксация включена, 0, если выключена, и false, если возникла ошибка.

Функция возвращает true, если выполнилась успешно, и false, если возникла ошибка, если значение аргумента enable отличается от значения null.

Список изменений

Версия Описание
8.4.0 Параметр odbc теперь ожидает экземпляр соединения Odbc\Connection; раньше ожидался аргумент с типом resource.
8.3.0 Параметр enable теперь принимает значение null.

Смотрите также

Добавить

Примечания пользователей 6 notes

up
1
JRog
21 years ago
If a transaction is started (autocommit disabled) while there is an active result id on the connection, odbc_autocommit will post a warning (Cannot set autocommit). Use odbc_free_result to clear the result id's or start the transaction before you execute the SQL.
up
0
alvaro at demogracia dot com
16 years ago
If you are using persistent connections (odbc_pconnect rather than odbc_connect) the next script that reuses the connection will inherit your changes to autocommit.
up
0
Orgied - info at orgied dot com
19 years ago
Hi (i'm belgian then sorry for my english).

I think you can do more simple to check the errors :

$conn = odbc_connect($odbc,$user,$password)
or die($error);

odbc_autocommit($conn, FALSE);

odbc_exec($conn, $query1);
odbc_exec($conn, $query2);

if (!odbc_error())
odbc_commit($conn);
else
odbc_rollback($conn);

odbc_close($conn);

I'm not sure it's better to use odbc_error() than
odbc_error($conn). It seems to be the same result.
up
0
Joe
20 years ago
It seems that example made by andrea dot galli at acotel dot com works exactly the contrary.

It sets autocommit OFF and NOT ON like it's written inside note!
up
-1
alonsoalonsocr at yahoo dot com
23 years ago
When used in a odbc_fetch loop your selected resultset is lost and loop ends.
up
-4
andrea dot galli at acotel dot com
21 years ago
Example: set autocommit on

<?php

$Link_ID
= odbc_connect("DSN", "user", "pass");

$Return = odbc_autocommit($Link_ID, FALSE);

?>
To Top