<?xml version="1.0" encoding="utf-8"?> <!-- $Revision$ --> <refentry xml:id="function.mysqlnd-ms-get-last-gtid" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink"> <refnamediv> <refname>mysqlnd_ms_get_last_gtid</refname> <refpurpose>Returns the latest global transaction ID</refpurpose> </refnamediv> <refsect1 role="description"> &reftitle.description; <methodsynopsis> <type>string</type> <methodname>mysqlnd_ms_get_last_gtid</methodname> <methodparam><type>mixed</type><parameter>connection</parameter></methodparam> </methodsynopsis> <para> Returns a global transaction identifier which belongs to a write operation no older than the last write performed by the client. It is not guaranteed that the global transaction identifier is identical to that one created for the last write transaction performed by the client. </para> </refsect1> <refsect1 role="parameters"> &reftitle.parameters; <variablelist> <varlistentry> <term><parameter>connection</parameter></term> <listitem> <para> A PECL/mysqlnd_ms connection handle to a MySQL server of the type <link linkend="ref.pdo-mysql">PDO_MYSQL</link>, <link linkend="book.mysqli">mysqli</link>> or <link linkend="book.mysql">ext/mysql</link>. The connection handle is obtained when opening a connection with a host name that matches a mysqlnd_ms configuration file entry using any of the above three MySQL driver extensions. </para> </listitem> </varlistentry> </variablelist> </refsect1> <refsect1 role="returnvalues"> &reftitle.returnvalues; <para> Returns a global transaction ID (GTID) on success. Otherwise, returns &false;. </para> <para> The function <function>mysqlnd_ms_get_last_gtid</function> returns the GTID obtained when executing the SQL statement from the <literal>fetch_last_gtid</literal> entry of the <literal>global_transaction_id_injection</literal> section from the plugins configuration file. </para> <para> The function may be called after the GTID has been incremented. </para> </refsect1> <refsect1> &reftitle.notes; <note> <para> <function>mysqlnd_ms_get_last_gtid</function> requires PHP >= 5.4.0 and PECL mysqlnd_ms >= 1.2.0. Internally, it is using a <literal>mysqlnd</literal> library C functionality not available with PHP 5.3. </para> <para> Please note, all MySQL 5.6 production versions do not provide clients with enough information to use GTIDs for enforcing session consistency. In the worst case, the plugin will choose the master only. </para> </note> </refsect1> <refsect1 role="examples"> &reftitle.examples; <para> <example> <title><function>mysqlnd_ms_get_last_gtid</function> example</title> <programlisting role="php"> <![CDATA[ <?php /* Open mysqlnd_ms connection using mysqli, PDO_MySQL or mysql extension */ $mysqli = new mysqli("myapp", "username", "password", "database"); if (!$mysqli) /* Of course, your error handling is nicer... */ die(sprintf("[%d] %s\n", mysqli_connect_errno(), mysqli_connect_error())); /* auto commit mode, transaction on master, GTID must be incremented */ if (!$mysqli->query("DROP TABLE IF EXISTS test")) die(sprintf("[%d] %s\n", $mysqli->errno, $mysqli->error)); printf("GTID after transaction %s\n", mysqlnd_ms_get_last_gtid($mysqli)); /* auto commit mode, transaction on master, GTID must be incremented */ if (!$mysqli->query("CREATE TABLE test(id INT)")) die(sprintf("[%d] %s\n", $mysqli->errno, $mysqli->error)); printf("GTID after transaction %s\n", mysqlnd_ms_get_last_gtid($mysqli)); ?> ]]> </programlisting> </example> </para> </refsect1> <refsect1 role="seealso"> &reftitle.seealso; <para> <simplelist> <member> <link linkend="mysqlnd-ms.gtid">Global Transaction IDs</link> </member> </simplelist> </para> </refsect1> </refentry> <!-- Keep this comment at the end of the file Local variables: mode: sgml sgml-omittag:t sgml-shorttag:t sgml-minimize-attributes:nil sgml-always-quote-attributes:t sgml-indent-step:1 sgml-indent-data:t indent-tabs-mode:nil sgml-parent-document:nil sgml-default-dtd-file:"~/.phpdoc/manual.ced" sgml-exposed-tags:nil sgml-local-catalogs:nil sgml-local-ecat-files:nil End: vim600: syn=xml fen fdm=syntax fdl=2 si vim: et tw=78 syn=sgml vi: ts=1 sw=1 -->