123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435 |
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
- <meta http-equiv="X-UA-Compatible" content="IE=9"/>
- <meta name="generator" content="Doxygen 1.8.14"/>
- <meta name="viewport" content="width=device-width, initial-scale=1"/>
- <title>EasyQtSql: Transaction Class Reference</title>
- <link href="tabs.css" rel="stylesheet" type="text/css"/>
- <script type="text/javascript" src="jquery.js"></script>
- <script type="text/javascript" src="dynsections.js"></script>
- <link href="navtree.css" rel="stylesheet" type="text/css"/>
- <script type="text/javascript" src="resize.js"></script>
- <script type="text/javascript" src="navtreedata.js"></script>
- <script type="text/javascript" src="navtree.js"></script>
- <script type="text/javascript">
- /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
- $(document).ready(initResizable);
- /* @license-end */</script>
- <link href="search/search.css" rel="stylesheet" type="text/css"/>
- <script type="text/javascript" src="search/searchdata.js"></script>
- <script type="text/javascript" src="search/search.js"></script>
- <link href="doxygen.css" rel="stylesheet" type="text/css" />
- </head>
- <body>
- <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
- <div id="titlearea">
- <table cellspacing="0" cellpadding="0">
- <tbody>
- <tr style="height: 56px;">
- <td id="projectalign" style="padding-left: 0.5em;">
- <div id="projectname">EasyQtSql
- </div>
- <div id="projectbrief">Easy SQL data access helper for QtSql</div>
- </td>
- </tr>
- </tbody>
- </table>
- </div>
- <!-- end header part -->
- <!-- Generated by Doxygen 1.8.14 -->
- <script type="text/javascript">
- /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
- var searchBox = new SearchBox("searchBox", "search",false,'Search');
- /* @license-end */
- </script>
- <script type="text/javascript" src="menudata.js"></script>
- <script type="text/javascript" src="menu.js"></script>
- <script type="text/javascript">
- /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
- $(function() {
- initMenu('',true,false,'search.php','Search');
- $(document).ready(function() { init_search(); });
- });
- /* @license-end */</script>
- <div id="main-nav"></div>
- </div><!-- top -->
- <div id="side-nav" class="ui-resizable side-nav-resizable">
- <div id="nav-tree">
- <div id="nav-tree-contents">
- <div id="nav-sync" class="sync"></div>
- </div>
- </div>
- <div id="splitbar" style="-moz-user-select:none;"
- class="ui-resizable-handle">
- </div>
- </div>
- <script type="text/javascript">
- /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
- $(document).ready(function(){initNavTree('class_transaction.htm','');});
- /* @license-end */
- </script>
- <div id="doc-content">
- <!-- window showing the filter options -->
- <div id="MSearchSelectWindow"
- onmouseover="return searchBox.OnSearchSelectShow()"
- onmouseout="return searchBox.OnSearchSelectHide()"
- onkeydown="return searchBox.OnSearchSelectKey(event)">
- </div>
- <!-- iframe showing the search results (closed by default) -->
- <div id="MSearchResultsWindow">
- <iframe src="javascript:void(0)" frameborder="0"
- name="MSearchResults" id="MSearchResults">
- </iframe>
- </div>
- <div class="header">
- <div class="summary">
- <a href="#pub-methods">Public Member Functions</a> |
- <a href="class_transaction-members.htm">List of all members</a> </div>
- <div class="headertitle">
- <div class="title">Transaction Class Reference</div> </div>
- </div><!--header-->
- <div class="contents">
- <p>QSqlDatabase transaction wrapper.
- <a href="class_transaction.htm#details">More...</a></p>
- <p><code>#include <<a class="el" href="_easy_qt_sql___transaction_8h_source.htm">EasyQtSql_Transaction.h</a>></code></p>
- <div class="dynheader">
- Inheritance diagram for Transaction:</div>
- <div class="dyncontent">
- <div class="center">
- <img src="class_transaction.png" usemap="#Transaction_map" alt=""/>
- <map id="Transaction_map" name="Transaction_map">
- <area href="class_database.htm" title="QSqlDatabase wrapper. " alt="Database" shape="rect" coords="0,0,78,24"/>
- </map>
- </div></div>
- <table class="memberdecls">
- <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
- Public Member Functions</h2></td></tr>
- <tr class="memitem:a9fed08d5643b66471a6e9fc75f351117"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a9fed08d5643b66471a6e9fc75f351117">Transaction</a> (const QSqlDatabase &db=QSqlDatabase())</td></tr>
- <tr class="separator:a9fed08d5643b66471a6e9fc75f351117"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a25916a5c0268d3b24a1fe17acf49fd95"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a25916a5c0268d3b24a1fe17acf49fd95">Transaction</a> (<a class="el" href="class_transaction.htm">Transaction</a> &&other)</td></tr>
- <tr class="separator:a25916a5c0268d3b24a1fe17acf49fd95"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a384204be2d6c76f7f6d20d612f487e71"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_transaction.htm">Transaction</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a384204be2d6c76f7f6d20d612f487e71">operator=</a> (<a class="el" href="class_transaction.htm">Transaction</a> &&other)</td></tr>
- <tr class="separator:a384204be2d6c76f7f6d20d612f487e71"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a362b0d2524d0c799165190517192dca9"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a362b0d2524d0c799165190517192dca9">~Transaction</a> ()</td></tr>
- <tr class="separator:a362b0d2524d0c799165190517192dca9"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a7388031cba0416d48e03e3f7acd5ca6a"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a7388031cba0416d48e03e3f7acd5ca6a">commit</a> ()</td></tr>
- <tr class="memdesc:a7388031cba0416d48e03e3f7acd5ca6a"><td class="mdescLeft"> </td><td class="mdescRight">Commits transaction. <a href="#a7388031cba0416d48e03e3f7acd5ca6a">More...</a><br /></td></tr>
- <tr class="separator:a7388031cba0416d48e03e3f7acd5ca6a"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a01e20e050a9ee2ba3eecf1b5ed57e2eb"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a01e20e050a9ee2ba3eecf1b5ed57e2eb">rollback</a> ()</td></tr>
- <tr class="memdesc:a01e20e050a9ee2ba3eecf1b5ed57e2eb"><td class="mdescLeft"> </td><td class="mdescRight">Rolls back transaction. <a href="#a01e20e050a9ee2ba3eecf1b5ed57e2eb">More...</a><br /></td></tr>
- <tr class="separator:a01e20e050a9ee2ba3eecf1b5ed57e2eb"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a53d4633727d54be34b7af5d68e7ef0ac"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a53d4633727d54be34b7af5d68e7ef0ac">started</a> () const</td></tr>
- <tr class="memdesc:a53d4633727d54be34b7af5d68e7ef0ac"><td class="mdescLeft"> </td><td class="mdescRight">Returns true if the transaction has been started successfully. Otherwise it returns false. <a href="#a53d4633727d54be34b7af5d68e7ef0ac">More...</a><br /></td></tr>
- <tr class="separator:a53d4633727d54be34b7af5d68e7ef0ac"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a87b55e002c7d1b8b2d912c6714a88576"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_transaction.htm#a87b55e002c7d1b8b2d912c6714a88576">commited</a> () const</td></tr>
- <tr class="memdesc:a87b55e002c7d1b8b2d912c6714a88576"><td class="mdescLeft"> </td><td class="mdescRight">Returns true if the transaction has been commited successfully. Otherwise it returns false. <a href="#a87b55e002c7d1b8b2d912c6714a88576">More...</a><br /></td></tr>
- <tr class="separator:a87b55e002c7d1b8b2d912c6714a88576"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="inherit_header pub_methods_class_database"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_database')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_database.htm">Database</a></td></tr>
- <tr class="memitem:a252b2bb8aeb0c0a2509b0eddf0be3c4e inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a252b2bb8aeb0c0a2509b0eddf0be3c4e">Database</a> (const QSqlDatabase &db=QSqlDatabase())</td></tr>
- <tr class="separator:a252b2bb8aeb0c0a2509b0eddf0be3c4e inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:afe82d7c8e0e895c0b4f9fa08b4e3eb8e inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#afe82d7c8e0e895c0b4f9fa08b4e3eb8e">Database</a> (<a class="el" href="class_database.htm">Database</a> &&other)</td></tr>
- <tr class="separator:afe82d7c8e0e895c0b4f9fa08b4e3eb8e inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a2a81e06933bf2ef5be2e59030a7e1e1c inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_database.htm">Database</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a2a81e06933bf2ef5be2e59030a7e1e1c">operator=</a> (<a class="el" href="class_database.htm">Database</a> &&other)</td></tr>
- <tr class="separator:a2a81e06933bf2ef5be2e59030a7e1e1c inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a7bc0ce48d3711002d4e0490c826f7b5e inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top">QSqlError </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a7bc0ce48d3711002d4e0490c826f7b5e">lastError</a> () const</td></tr>
- <tr class="memdesc:a7bc0ce48d3711002d4e0490c826f7b5e inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Returns information about the last error that occurred on the underlying database. <a href="class_database.htm#a7bc0ce48d3711002d4e0490c826f7b5e">More...</a><br /></td></tr>
- <tr class="separator:a7bc0ce48d3711002d4e0490c826f7b5e inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:aae9f7e53275334c91655eeb7a2bde030 inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_non_query_result.htm">NonQueryResult</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#aae9f7e53275334c91655eeb7a2bde030">execNonQuery</a> (const QString &sql) const</td></tr>
- <tr class="memdesc:aae9f7e53275334c91655eeb7a2bde030 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes non-query SQL statement (DELETE, INSERT, UPDATE, CREATE, ALTER, etc.) <a href="class_database.htm#aae9f7e53275334c91655eeb7a2bde030">More...</a><br /></td></tr>
- <tr class="separator:aae9f7e53275334c91655eeb7a2bde030 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a05c1ac255cdba9781f8bf306801bca70 inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_query_result.htm">QueryResult</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a05c1ac255cdba9781f8bf306801bca70">execQuery</a> (const QString &sql) const</td></tr>
- <tr class="memdesc:a05c1ac255cdba9781f8bf306801bca70 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes SELECT query. <a href="class_database.htm#a05c1ac255cdba9781f8bf306801bca70">More...</a><br /></td></tr>
- <tr class="separator:a05c1ac255cdba9781f8bf306801bca70 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a8388689590c1f3adeabd2972b221bcb2 inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_insert_query.htm">InsertQuery</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a8388689590c1f3adeabd2972b221bcb2">insertInto</a> (const QString &table) const</td></tr>
- <tr class="memdesc:a8388689590c1f3adeabd2972b221bcb2 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Creates INSERT query wrapper. <a href="class_database.htm#a8388689590c1f3adeabd2972b221bcb2">More...</a><br /></td></tr>
- <tr class="separator:a8388689590c1f3adeabd2972b221bcb2 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a44fca4a9c9241481a87d59f529e98b9e inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_delete_query.htm">DeleteQuery</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a44fca4a9c9241481a87d59f529e98b9e">deleteFrom</a> (const QString &table) const</td></tr>
- <tr class="memdesc:a44fca4a9c9241481a87d59f529e98b9e inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Creates DELETE query wrapper. <a href="class_database.htm#a44fca4a9c9241481a87d59f529e98b9e">More...</a><br /></td></tr>
- <tr class="separator:a44fca4a9c9241481a87d59f529e98b9e inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a2d8dad3df4134306749582216bd437e0 inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_update_query.htm">UpdateQuery</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a2d8dad3df4134306749582216bd437e0">update</a> (const QString &table) const</td></tr>
- <tr class="memdesc:a2d8dad3df4134306749582216bd437e0 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Creates UPDATE query wrapper. <a href="class_database.htm#a2d8dad3df4134306749582216bd437e0">More...</a><br /></td></tr>
- <tr class="separator:a2d8dad3df4134306749582216bd437e0 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a03e2c9113452bb52bb7018ef2366bce1 inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_prepared_query.htm">PreparedQuery</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a03e2c9113452bb52bb7018ef2366bce1">prepare</a> (const QString &sql, bool forwardOnly=true) const</td></tr>
- <tr class="memdesc:a03e2c9113452bb52bb7018ef2366bce1 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Prepares SQL statement. <a href="class_database.htm#a03e2c9113452bb52bb7018ef2366bce1">More...</a><br /></td></tr>
- <tr class="separator:a03e2c9113452bb52bb7018ef2366bce1 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a0076431e130f7815ca7a3ae8ec7284ef inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top">QSqlDatabase & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a0076431e130f7815ca7a3ae8ec7284ef">qSqlDatabase</a> ()</td></tr>
- <tr class="memdesc:a0076431e130f7815ca7a3ae8ec7284ef inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Returns a reference to the wrapped QSqlDatabase object. <a href="class_database.htm#a0076431e130f7815ca7a3ae8ec7284ef">More...</a><br /></td></tr>
- <tr class="separator:a0076431e130f7815ca7a3ae8ec7284ef inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a7a13f4fc603fb829f123894d9abd6ea7 inherit pub_methods_class_database"><td class="memTemplParams" colspan="2">template<typename Func > </td></tr>
- <tr class="memitem:a7a13f4fc603fb829f123894d9abd6ea7 inherit pub_methods_class_database"><td class="memTemplItemLeft" align="right" valign="top">int </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_database.htm#a7a13f4fc603fb829f123894d9abd6ea7">each</a> (const QString &query, Func &&f) const</td></tr>
- <tr class="memdesc:a7a13f4fc603fb829f123894d9abd6ea7 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes <em>query</em> and applies function <em>f</em> to each result row. <a href="class_database.htm#a7a13f4fc603fb829f123894d9abd6ea7">More...</a><br /></td></tr>
- <tr class="separator:a7a13f4fc603fb829f123894d9abd6ea7 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:ad2283c7025501aafc33530d19beb02b4 inherit pub_methods_class_database"><td class="memTemplParams" colspan="2">template<typename Func > </td></tr>
- <tr class="memitem:ad2283c7025501aafc33530d19beb02b4 inherit pub_methods_class_database"><td class="memTemplItemLeft" align="right" valign="top">int </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_database.htm#ad2283c7025501aafc33530d19beb02b4">first</a> (const QString &query, Func &&f) const</td></tr>
- <tr class="memdesc:ad2283c7025501aafc33530d19beb02b4 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes <em>query</em> and applies function <em>f</em> to the first result row. <a href="class_database.htm#ad2283c7025501aafc33530d19beb02b4">More...</a><br /></td></tr>
- <tr class="separator:ad2283c7025501aafc33530d19beb02b4 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a3b1fb50c3263775351fc981fda798207 inherit pub_methods_class_database"><td class="memTemplParams" colspan="2">template<typename Func > </td></tr>
- <tr class="memitem:a3b1fb50c3263775351fc981fda798207 inherit pub_methods_class_database"><td class="memTemplItemLeft" align="right" valign="top">int </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_database.htm#a3b1fb50c3263775351fc981fda798207">range</a> (const QString &query, int start, int count, Func &&f) const</td></tr>
- <tr class="memdesc:a3b1fb50c3263775351fc981fda798207 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes <em>query</em> and applies function <em>f</em> to <em>count</em> result rows starting from index <em>start</em>. <a href="class_database.htm#a3b1fb50c3263775351fc981fda798207">More...</a><br /></td></tr>
- <tr class="separator:a3b1fb50c3263775351fc981fda798207 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a91583d42e701fb399563facc3c3c58c0 inherit pub_methods_class_database"><td class="memTemplParams" colspan="2">template<typename Func > </td></tr>
- <tr class="memitem:a91583d42e701fb399563facc3c3c58c0 inherit pub_methods_class_database"><td class="memTemplItemLeft" align="right" valign="top">int </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_database.htm#a91583d42e701fb399563facc3c3c58c0">top</a> (const QString &query, int topCount, Func &&f) const</td></tr>
- <tr class="memdesc:a91583d42e701fb399563facc3c3c58c0 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes <em>query</em> and applies function <em>f</em> to <em>topCount</em> result rows. <a href="class_database.htm#a91583d42e701fb399563facc3c3c58c0">More...</a><br /></td></tr>
- <tr class="separator:a91583d42e701fb399563facc3c3c58c0 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a909783661db7d15e0b0adca5a96db4de inherit pub_methods_class_database"><td class="memTemplParams" colspan="2">template<typename T > </td></tr>
- <tr class="memitem:a909783661db7d15e0b0adca5a96db4de inherit pub_methods_class_database"><td class="memTemplItemLeft" align="right" valign="top">T </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_database.htm#a909783661db7d15e0b0adca5a96db4de">scalar</a> (const QString &query) const</td></tr>
- <tr class="memdesc:a909783661db7d15e0b0adca5a96db4de inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes <em>query</em> and returns scalar value converted to T. <a href="class_database.htm#a909783661db7d15e0b0adca5a96db4de">More...</a><br /></td></tr>
- <tr class="separator:a909783661db7d15e0b0adca5a96db4de inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a39dbcd9a97f4e3c38c8c5ba48e445216 inherit pub_methods_class_database"><td class="memItemLeft" align="right" valign="top">QVariant </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a39dbcd9a97f4e3c38c8c5ba48e445216">scalar</a> (const QString &query) const</td></tr>
- <tr class="memdesc:a39dbcd9a97f4e3c38c8c5ba48e445216 inherit pub_methods_class_database"><td class="mdescLeft"> </td><td class="mdescRight">Executes <em>query</em> and returns scalar value. <a href="class_database.htm#a39dbcd9a97f4e3c38c8c5ba48e445216">More...</a><br /></td></tr>
- <tr class="separator:a39dbcd9a97f4e3c38c8c5ba48e445216 inherit pub_methods_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- </table><table class="memberdecls">
- <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="inherited"></a>
- Additional Inherited Members</h2></td></tr>
- <tr class="inherit_header pro_attribs_class_database"><td colspan="2" onclick="javascript:toggleInherit('pro_attribs_class_database')"><img src="closed.png" alt="-"/> Protected Attributes inherited from <a class="el" href="class_database.htm">Database</a></td></tr>
- <tr class="memitem:a7357cbeca05937556f66e2fe2288bdb5 inherit pro_attribs_class_database"><td class="memItemLeft" align="right" valign="top">QSqlDatabase </td><td class="memItemRight" valign="bottom"><a class="el" href="class_database.htm#a7357cbeca05937556f66e2fe2288bdb5">m_db</a></td></tr>
- <tr class="separator:a7357cbeca05937556f66e2fe2288bdb5 inherit pro_attribs_class_database"><td class="memSeparator" colspan="2"> </td></tr>
- </table>
- <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
- <div class="textblock"><p>QSqlDatabase transaction wrapper. </p>
- <p>Features:</p><ul>
- <li>Automatic rollback of non-expclicitely commited transactions</li>
- <li>Helper methods: <a class="el" href="class_database.htm#aae9f7e53275334c91655eeb7a2bde030" title="Executes non-query SQL statement (DELETE, INSERT, UPDATE, CREATE, ALTER, etc.) ">Transaction::execNonQuery</a>, <a class="el" href="class_database.htm#a05c1ac255cdba9781f8bf306801bca70" title="Executes SELECT query. ">Transaction::execQuery</a>, <a class="el" href="class_database.htm#a8388689590c1f3adeabd2972b221bcb2" title="Creates INSERT query wrapper. ">Transaction::insertInto</a>, <a class="el" href="class_database.htm#a44fca4a9c9241481a87d59f529e98b9e" title="Creates DELETE query wrapper. ">Transaction::deleteFrom</a>, <a class="el" href="class_database.htm#a2d8dad3df4134306749582216bd437e0" title="Creates UPDATE query wrapper. ">Transaction::update</a>, <a class="el" href="class_database.htm#a03e2c9113452bb52bb7018ef2366bce1" title="Prepares SQL statement. ">Transaction::prepare</a>.</li>
- </ul>
- <div class="fragment"><div class="line"><span class="keywordtype">void</span> test()</div><div class="line">{</div><div class="line"> QSqlDatabase db = QSqlDatabase::addDatabase(<span class="stringliteral">"QSQLITE"</span>);</div><div class="line"> db.setDatabaseName(<span class="stringliteral">":memory:"</span>);</div><div class="line"> db.open();</div><div class="line"></div><div class="line"> <span class="keywordflow">try</span></div><div class="line"> {</div><div class="line"> <a class="code" href="class_transaction.htm">Transaction</a> t(db);</div><div class="line"></div><div class="line"> t.<a class="code" href="class_database.htm#aae9f7e53275334c91655eeb7a2bde030">execNonQuery</a>(<span class="stringliteral">"CREATE TABLE table (a int, b int, c int, d text)"</span>);</div><div class="line"></div><div class="line"> t.<a class="code" href="class_database.htm#a8388689590c1f3adeabd2972b221bcb2">insertInto</a>(<span class="stringliteral">"table (a, b, c, d)"</span>)</div><div class="line"> .<a class="code" href="class_insert_query.htm#ae207fa97fdf9571fbcded31bbad9b9ed">values</a>(1, 2, 3, <span class="stringliteral">"row1"</span>)</div><div class="line"> .<a class="code" href="class_insert_query.htm#ae207fa97fdf9571fbcded31bbad9b9ed">values</a>(4, 5, 6, <span class="stringliteral">"row2"</span>)</div><div class="line"> .<a class="code" href="class_insert_query.htm#ae207fa97fdf9571fbcded31bbad9b9ed">values</a>(7, 8, 9, <span class="stringliteral">"row3"</span>)</div><div class="line"> .<a class="code" href="class_insert_query.htm#a385c674dfad02ee62cfc0d3e124cd33b">exec</a>();</div><div class="line"></div><div class="line"> <a class="code" href="class_prepared_query.htm">PreparedQuery</a> query = t.<a class="code" href="class_database.htm#a03e2c9113452bb52bb7018ef2366bce1">prepare</a>(<span class="stringliteral">"SELECT a, b, c, d FROM table"</span>);</div><div class="line"></div><div class="line"> <a class="code" href="class_query_result.htm">QueryResult</a> res = query.<a class="code" href="class_prepared_query.htm#a1013aea1638d6d04868ce39130bc1b67">exec</a>();</div><div class="line"> <span class="keywordflow">while</span> (res.<a class="code" href="class_query_result.htm#a1c756382c20c126979b28715d529c054">next</a>())</div><div class="line"> {</div><div class="line"> QVariantMap map = res.<a class="code" href="class_query_result.htm#a023bd84f7010368d616d7dbb1b399a06">toMap</a>();</div><div class="line"> qDebug() << map;</div><div class="line"> }</div><div class="line"></div><div class="line"> t.<a class="code" href="class_database.htm#a2d8dad3df4134306749582216bd437e0">update</a>(<span class="stringliteral">"table"</span>)</div><div class="line"> .<a class="code" href="class_update_query.htm#a7c1b4eaa45048ec8a3f6f7d4223f5ace">set</a>(<span class="stringliteral">"a"</span>, 111)</div><div class="line"> .<a class="code" href="class_update_query.htm#a7c1b4eaa45048ec8a3f6f7d4223f5ace">set</a>(<span class="stringliteral">"b"</span>, 222)</div><div class="line"> .<a class="code" href="class_update_query.htm#abb4c7b7502599a78699e3a1f4cb4cbda">where</a>(<span class="stringliteral">"c = ? OR c = ?"</span>, 3, 6);</div><div class="line"></div><div class="line"> res = query.<a class="code" href="class_prepared_query.htm#a1013aea1638d6d04868ce39130bc1b67">exec</a>();</div><div class="line"> <span class="keywordflow">while</span> (res.<a class="code" href="class_query_result.htm#a1c756382c20c126979b28715d529c054">next</a>())</div><div class="line"> {</div><div class="line"> QVariantMap map = res.<a class="code" href="class_query_result.htm#a023bd84f7010368d616d7dbb1b399a06">toMap</a>();</div><div class="line"> qDebug() << map;</div><div class="line"> }</div><div class="line"></div><div class="line"> t.<a class="code" href="class_transaction.htm#a7388031cba0416d48e03e3f7acd5ca6a">commit</a>(); <span class="comment">//the transaction will be rolled back on exit from the scope (when calling the destructor) if you do not explicitly commit</span></div><div class="line"></div><div class="line"> <span class="keywordflow">catch</span> (<span class="keyword">const</span> <a class="code" href="class_d_b_exception.htm">DBException</a> &e)</div><div class="line"> {</div><div class="line"> <span class="comment">//you can handle all the errors at one point</span></div><div class="line"> <span class="comment">//the transaction will be automatically rolled back on exception</span></div><div class="line"></div><div class="line"> qDebug() << e.<a class="code" href="class_d_b_exception.htm#adf142ded3fb236826a5a6ba4a606e584">lastError</a> << e.<a class="code" href="class_d_b_exception.htm#a3ec8b4b593abee155554472ae0b58f12">lastQuery</a>;</div><div class="line"> }</div><div class="line">}</div></div><!-- fragment --> </div><h2 class="groupheader">Constructor & Destructor Documentation</h2>
- <a id="a9fed08d5643b66471a6e9fc75f351117"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a9fed08d5643b66471a6e9fc75f351117">◆ </a></span>Transaction() <span class="overload">[1/2]</span></h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">Transaction::Transaction </td>
- <td>(</td>
- <td class="paramtype">const QSqlDatabase & </td>
- <td class="paramname"><em>db</em> = <code>QSqlDatabase()</code></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">explicit</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- </div>
- </div>
- <a id="a25916a5c0268d3b24a1fe17acf49fd95"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a25916a5c0268d3b24a1fe17acf49fd95">◆ </a></span>Transaction() <span class="overload">[2/2]</span></h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">Transaction::Transaction </td>
- <td>(</td>
- <td class="paramtype"><a class="el" href="class_transaction.htm">Transaction</a> && </td>
- <td class="paramname"><em>other</em></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- </div>
- </div>
- <a id="a362b0d2524d0c799165190517192dca9"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a362b0d2524d0c799165190517192dca9">◆ </a></span>~Transaction()</h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">Transaction::~Transaction </td>
- <td>(</td>
- <td class="paramname"></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- </div>
- </div>
- <h2 class="groupheader">Member Function Documentation</h2>
- <a id="a7388031cba0416d48e03e3f7acd5ca6a"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a7388031cba0416d48e03e3f7acd5ca6a">◆ </a></span>commit()</h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">bool Transaction::commit </td>
- <td>(</td>
- <td class="paramname"></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Commits transaction. </p>
- <p>The transaction will be rolled back on calling the destructor if not explicitly commited</p>
- <dl class="exception"><dt>Exceptions</dt><dd>
- <table class="exception">
- <tr><td class="paramname"><a class="el" href="class_d_b_exception.htm" title="Exception class for SQL errors handling. ">DBException</a></td><td></td></tr>
- </table>
- </dd>
- </dl>
- </div>
- </div>
- <a id="a87b55e002c7d1b8b2d912c6714a88576"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a87b55e002c7d1b8b2d912c6714a88576">◆ </a></span>commited()</h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">bool Transaction::commited </td>
- <td>(</td>
- <td class="paramname"></td><td>)</td>
- <td> const</td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Returns true if the transaction has been commited successfully. Otherwise it returns false. </p>
- </div>
- </div>
- <a id="a384204be2d6c76f7f6d20d612f487e71"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a384204be2d6c76f7f6d20d612f487e71">◆ </a></span>operator=()</h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname"><a class="el" href="class_transaction.htm">Transaction</a>& Transaction::operator= </td>
- <td>(</td>
- <td class="paramtype"><a class="el" href="class_transaction.htm">Transaction</a> && </td>
- <td class="paramname"><em>other</em></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- </div>
- </div>
- <a id="a01e20e050a9ee2ba3eecf1b5ed57e2eb"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a01e20e050a9ee2ba3eecf1b5ed57e2eb">◆ </a></span>rollback()</h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">bool Transaction::rollback </td>
- <td>(</td>
- <td class="paramname"></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Rolls back transaction. </p>
- </div>
- </div>
- <a id="a53d4633727d54be34b7af5d68e7ef0ac"></a>
- <h2 class="memtitle"><span class="permalink"><a href="#a53d4633727d54be34b7af5d68e7ef0ac">◆ </a></span>started()</h2>
- <div class="memitem">
- <div class="memproto">
- <table class="mlabels">
- <tr>
- <td class="mlabels-left">
- <table class="memname">
- <tr>
- <td class="memname">bool Transaction::started </td>
- <td>(</td>
- <td class="paramname"></td><td>)</td>
- <td> const</td>
- </tr>
- </table>
- </td>
- <td class="mlabels-right">
- <span class="mlabels"><span class="mlabel">inline</span></span> </td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Returns true if the transaction has been started successfully. Otherwise it returns false. </p>
- </div>
- </div>
- <hr/>The documentation for this class was generated from the following file:<ul>
- <li>EasyQtSql/<a class="el" href="_easy_qt_sql___transaction_8h_source.htm">EasyQtSql_Transaction.h</a></li>
- </ul>
- </div><!-- contents -->
- </div><!-- doc-content -->
- <!-- start footer part -->
- <div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
- <ul>
- <li class="navelem"><a class="el" href="class_transaction.htm">Transaction</a></li>
- <li class="footer">Generated by
- <a href="http://www.doxygen.org/index.html">
- <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.14 </li>
- </ul>
- </div>
- </body>
- </html>
|