Sophie

Sophie

distrib > Fedora > 18 > x86_64 > by-pkgid > b3a1f4d91c26f535919e39e25606614a > files > 3072

wt-doc-3.2.3-1.fc18.noarch.rpm

<!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"/>
<title>Wt: Wt::Dbo::dbo_traits&lt; C &gt; Class Template Reference</title>

<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="doxygen.css" rel="stylesheet" type="text/css" />

<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
  $(document).ready(function() { searchBox.OnSelectItem(0); });
</script>

</head>
<body>
<div id="top"><!-- do not remove this div! -->


<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  
  
  <td style="padding-left: 0.5em;">
   <div id="projectname">Wt
   &#160;<span id="projectnumber">3.2.3</span>
   </div>
   
  </td>
  
  
  
 </tr>
 </tbody>
</table>
</div>

<!-- Generated by Doxygen 1.7.5.1 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
        <span class="left">
          <img id="MSearchSelect" src="search/mag_sel.png"
               onmouseover="return searchBox.OnSearchSelectShow()"
               onmouseout="return searchBox.OnSearchSelectHide()"
               alt=""/>
          <input type="text" id="MSearchField" value="Search" accesskey="S"
               onfocus="searchBox.OnSearchFieldFocus(true)" 
               onblur="searchBox.OnSearchFieldFocus(false)" 
               onkeyup="searchBox.OnSearchFieldChange(event)"/>
          </span><span class="right">
            <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
          </span>
        </div>
      </li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="annotated.html"><span>Class&#160;List</span></a></li>
      <li><a href="inherits.html"><span>Class&#160;Hierarchy</span></a></li>
      <li><a href="functions.html"><span>Class&#160;Members</span></a></li>
    </ul>
  </div>
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><a class="el" href="namespaceWt.html">Wt</a>      </li>
      <li class="navelem"><a class="el" href="namespaceWt_1_1Dbo.html">Dbo</a>      </li>
      <li class="navelem"><a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html">dbo_traits</a>      </li>
    </ul>
  </div>
</div>
<div class="header">
  <div class="summary">
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-static-methods">Static Public Member Functions</a>  </div>
  <div class="headertitle">
<div class="title">Wt::Dbo::dbo_traits&lt; C &gt; Class Template Reference<div class="ingroups"><a class="el" href="group__dbo.html">Database Objects (Wt::Dbo)</a></div></div>  </div>
</div>
<div class="contents">
<!-- doxytag: class="Wt::Dbo::dbo_traits" --><!-- doxytag: inherits="Wt::Dbo::dbo_default_traits" -->
<p>Traits for a class mapped with Wt::Dbo.  
 <a href="structWt_1_1Dbo_1_1dbo__traits.html#details">More...</a></p>

<p><code>#include &lt;Wt/Dbo/Dbo&gt;</code></p>
<div class="dynheader">
Inheritance diagram for Wt::Dbo::dbo_traits&lt; C &gt;:</div>
<div class="dyncontent">
<div class="center"><img src="structWt_1_1Dbo_1_1dbo__traits__inherit__graph.png" border="0" usemap="#Wt_1_1Dbo_1_1dbo__traits_3_01C_01_4_inherit__map" alt="Inheritance graph"/></div>
<map name="Wt_1_1Dbo_1_1dbo__traits_3_01C_01_4_inherit__map" id="Wt_1_1Dbo_1_1dbo__traits_3_01C_01_4_inherit__map">
<area shape="rect" href="structWt_1_1Dbo_1_1dbo__default__traits.html" title="Default traits for a class mapped with Wt::Dbo." alt="" coords="5,5,184,32"/></map>
<center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>

<p><a href="classWt_1_1Dbo_1_1dbo__traits-members.html">List of all members.</a></p>
<table class="memberdecls">
<tr><td colspan="2"><h2><a name="pub-types"></a>
Public Types</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">typedef YourIdType&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html#afb62c3f28967b0b14b13360d47cd37dc">IdType</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Type of the primary key.  <a href="#afb62c3f28967b0b14b13360d47cd37dc"></a><br/></td></tr>
<tr><td colspan="2"><h2><a name="pub-static-methods"></a>
Static Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">static <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#a89170e677a75348ef6913d9f4ba496ae">IdType</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html#aae2a13a4ca038f5bad337fbc2d70d37c">invalidId</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the sentinel value for a <code>null</code> id.  <a href="#aae2a13a4ca038f5bad337fbc2d70d37c"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">static const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html#a44c5455df89390fae082aadf7cf1bc13">surrogateIdField</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Configures the surrogate primary key field.  <a href="#a44c5455df89390fae082aadf7cf1bc13"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">static const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html#a701b53b0401836a7c966c619f3c9656d">versionField</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Configures the optimistic concurrency version field.  <a href="#a701b53b0401836a7c966c619f3c9656d"></a><br/></td></tr>
</table>
<hr/><a name="details" id="details"></a><h2>Detailed Description</h2>
<div class="textblock"><h3>template&lt;class C&gt;<br/>
class Wt::Dbo::dbo_traits&lt; C &gt;</h3>

<p>Traits for a class mapped with Wt::Dbo. </p>
<p>The traits class provides some of the mapping properties related to the primary key and optimistic concurrency locking using a version field.</p>
<p>See <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html" title="Default traits for a class mapped with Wt::Dbo.">dbo_default_traits</a> for default values.</p>
<p>The following example changes the surrogate id field name for a class <code>Foo</code> from the default <code>"id"</code> to <code>"foo_id"</code>:</p>
<div class="fragment"><pre class="fragment"> <span class="keyword">namespace </span>Wt {
   <span class="keyword">namespace </span>Dbo {

     <span class="keyword">template</span>&lt;&gt;
     <span class="keyword">struct </span>dbo_traits&lt;Foo&gt;
     {
        <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="structWt_1_1Dbo_1_1dbo__traits.html#a44c5455df89390fae082aadf7cf1bc13" title="Configures the surrogate primary key field.">surrogateIdField</a>() { <span class="keywordflow">return</span> <span class="stringliteral">&quot;foo_id&quot;</span>; }
     };
   }
 }
</pre></div> </div><hr/><h2>Member Typedef Documentation</h2>
<a class="anchor" id="afb62c3f28967b0b14b13360d47cd37dc"></a><!-- doxytag: member="Wt::Dbo::dbo_traits::IdType" ref="afb62c3f28967b0b14b13360d47cd37dc" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class C&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">typedef YourIdType <a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html">Wt::Dbo::dbo_traits</a>&lt; C &gt;::<a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#a89170e677a75348ef6913d9f4ba496ae">IdType</a></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Type of the primary key. </p>
<p>This indicates the type of the primary key, which needs to be <code>long long</code> for a surrogate id, but can be any type supported by <a class="el" href="group__dbo.html#ga864a2e134149e7f614f45967777992c7" title="Maps a database object field.">Wt::Dbo::field()</a> (including composite types) for a natural primary key.</p>
<p>The following operations need to be supported for an id value:</p>
<ul>
<li><em>default constructor</em></li>
<li><em>copy constructor</em></li>
<li>serialization to a string (for formatting an error message in exceptions) : <code>std::ostream &lt;&lt; id</code></li>
<li>comparison operator (for use as a key in a std::map): <code>id == id</code></li>
<li>less than operator (for use as a key in a std::map): <code>id &lt; id</code></li>
</ul>
<p>Only the default <code>long long</code> is supported for an auto-incrementing surrogate primary key. You need to change the default key type typically in conjuction with specifying a natural id, see <a class="el" href="group__dbo.html#ga42c50bd3bfc38ad8c810b30b279b0ba6" title="Maps a natural primary key (id) field.">Wt::Dbo::id()</a>.</p>
<p>The following example illustrates how to prepare a type to be usable as a composite id type:</p>
<div class="fragment"><pre class="fragment"> <span class="keyword">struct </span>Coordinate {
   <span class="keywordtype">int</span> x, y;

   Coordinate()
     : x(-1), y(-1) { }

   <span class="keywordtype">bool</span> operator== (<span class="keyword">const</span> Coordinate&amp; other)<span class="keyword"> const </span>{
     <span class="keywordflow">return</span> x == other.x &amp;&amp; y == other.y;
   }

   <span class="keywordtype">bool</span> operator&lt; (<span class="keyword">const</span> Coordinate&amp; other)<span class="keyword"> const </span>{
     <span class="keywordflow">if</span> (x &lt; other.x)
       <span class="keywordflow">return</span> <span class="keyword">true</span>;
     <span class="keywordflow">else</span> <span class="keywordflow">if</span> (x == other.x)
       <span class="keywordflow">return</span> y &lt; other.y;
     <span class="keywordflow">else</span>
       <span class="keywordflow">return</span> <span class="keyword">false</span>;
   }
 };
 
 std::ostream&amp; operator&lt;&lt; (std::ostream&amp; o, <span class="keyword">const</span> Coordinate&amp; c)
 {
   <span class="keywordflow">return</span> o &lt;&lt; <span class="stringliteral">&quot;(&quot;</span> &lt;&lt; c.x &lt;&lt; <span class="stringliteral">&quot;, &quot;</span> &lt;&lt; c.y &lt;&lt; <span class="stringliteral">&quot;)&quot;</span>;
 }
 
 <span class="keyword">namespace </span>Wt {
   <span class="keyword">namespace </span>Dbo {
 
     <span class="keyword">template</span> &lt;<span class="keyword">class</span> Action&gt;
     <span class="keywordtype">void</span> <a class="code" href="group__dbo.html#ga864a2e134149e7f614f45967777992c7" title="Maps a database object field.">field</a>(Action&amp; action, Coordinate&amp; coordinate, <span class="keyword">const</span> std::string&amp; name, <span class="keywordtype">int</span> size = -1)
     {
       <a class="code" href="group__dbo.html#ga864a2e134149e7f614f45967777992c7" title="Maps a database object field.">field</a>(action, coordinate.x, name + <span class="stringliteral">&quot;_x&quot;</span>);
       <a class="code" href="group__dbo.html#ga864a2e134149e7f614f45967777992c7" title="Maps a database object field.">field</a>(action, coordinate.y, name + <span class="stringliteral">&quot;_y&quot;</span>);
     }
   }
 }
</pre></div> 
<p>Reimplemented from <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#a89170e677a75348ef6913d9f4ba496ae">Wt::Dbo::dbo_default_traits</a>.</p>

</div>
</div>
<hr/><h2>Member Function Documentation</h2>
<a class="anchor" id="aae2a13a4ca038f5bad337fbc2d70d37c"></a><!-- doxytag: member="Wt::Dbo::dbo_traits::invalidId" ref="aae2a13a4ca038f5bad337fbc2d70d37c" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class C&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#a89170e677a75348ef6913d9f4ba496ae">IdType</a> <a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html">Wt::Dbo::dbo_traits</a>&lt; C &gt;::invalidId </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Returns the sentinel value for a <code>null</code> id. </p>
<p>When used as a foreign key, this value is used to represent a <code>null</code> value. </p>

<p>Reimplemented from <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#a6bb01d0dc6a5bbd25481fa16b642b996">Wt::Dbo::dbo_default_traits</a>.</p>

</div>
</div>
<a class="anchor" id="a44c5455df89390fae082aadf7cf1bc13"></a><!-- doxytag: member="Wt::Dbo::dbo_traits::surrogateIdField" ref="a44c5455df89390fae082aadf7cf1bc13" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class C&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static const char* <a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html">Wt::Dbo::dbo_traits</a>&lt; C &gt;::surrogateIdField </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Configures the surrogate primary key field. </p>
<p>Returns the field name which is the surrogate primary key, corresponding to the object's id.</p>
<p>You can disable this auto-incrementing surrogate id by returning <code>0</code> instead. In that case you will need to define a natural id for your class using <a class="el" href="group__dbo.html#ga42c50bd3bfc38ad8c810b30b279b0ba6" title="Maps a natural primary key (id) field.">Wt::Dbo::id()</a>. </p>

<p>Reimplemented from <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#a0c092c6b045f77d4fc04b5360b762b7f">Wt::Dbo::dbo_default_traits</a>.</p>

</div>
</div>
<a class="anchor" id="a701b53b0401836a7c966c619f3c9656d"></a><!-- doxytag: member="Wt::Dbo::dbo_traits::versionField" ref="a701b53b0401836a7c966c619f3c9656d" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class C&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static const char* <a class="el" href="structWt_1_1Dbo_1_1dbo__traits.html">Wt::Dbo::dbo_traits</a>&lt; C &gt;::versionField </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Configures the optimistic concurrency version field. </p>
<p>Optimistic concurrency locking is used to detect concurrent updates by an object from multiple sessions. On each update, the version of a record is at the same time checked (to see if it matches the version of the record that was read), and incremented. A <a class="el" href="classWt_1_1Dbo_1_1StaleObjectException.html" title="Exception thrown when Wt::Dbo detects a concurrent modification">StaleObjectException</a> is thrown if a record was modified by another session since it was read.</p>
<p>This method must return the database field name used for this version field.</p>
<p>You can disable optimistic locking using a version field all together for your class by returning <code>0</code> instead. </p>

<p>Reimplemented from <a class="el" href="structWt_1_1Dbo_1_1dbo__default__traits.html#af4da1fde75771c5f2e707827e2a885c4">Wt::Dbo::dbo_default_traits</a>.</p>

</div>
</div>
</div>
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Enumerator</a></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>

<hr size="1"><address style="text-align: right; margin: 3px"><small>
Generated on Thu Nov 1 2012 for <a href="http://www.webtoolkit.eu/wt">the
C++ Web Toolkit (Wt)</a> by&nbsp;<a
href="http://www.doxygen.org/index.html"><img src="doxygen.png"
alt="doxygen" border="0" style="vertical-align: middle; display:
inline-block; height: 2em"></a> 1.7.5.1</small></address>
</body>
</html>