You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  6. <title>db — Database &mdash; Documentation</title>
  7. <link rel="stylesheet" href="_static/sphinxdoc.css" type="text/css" />
  8. <link rel="stylesheet" href="_static/pygments.css" type="text/css" />
  9. <script type="text/javascript">
  10. var DOCUMENTATION_OPTIONS = {
  11. URL_ROOT: '',
  12. VERSION: '',
  13. COLLAPSE_MODINDEX: false,
  14. FILE_SUFFIX: '.html',
  15. HAS_SOURCE: true
  16. };
  17. </script>
  18. <script type="text/javascript" src="_static/jquery.js"></script>
  19. <script type="text/javascript" src="_static/doctools.js"></script>
  20. <link rel="top" title="Documentation" href="index.html" />
  21. <link rel="up" title="Server Side Internals" href="server_side_internals.html" />
  22. <link rel="next" title="page_body — Page Body Serverside Module" href="page_body.html" />
  23. <link rel="prev" title="db_schema — Database Schema Management Module" href="db_schema.html" />
  24. </head>
  25. <body>
  26. <div style="background-color: #FFF; text-align: left; padding: 8px 0px"><img src="_static/banner300910.gif"></div>
  27. <div class="related">
  28. <h3>Navigation</h3>
  29. <ul>
  30. <li class="right" style="margin-right: 10px">
  31. <a href="genindex.html" title="General Index"
  32. accesskey="I">index</a></li>
  33. <li class="right" >
  34. <a href="modindex.html" title="Global Module Index"
  35. accesskey="M">modules</a> |</li>
  36. <li class="right" >
  37. <a href="page_body.html" title="page_body — Page Body Serverside Module"
  38. accesskey="N">next</a> |</li>
  39. <li class="right" >
  40. <a href="db_schema.html" title="db_schema — Database Schema Management Module"
  41. accesskey="P">previous</a> |</li>
  42. <li><a href="index.html">Documentation</a> &raquo;</li>
  43. <li><a href="server_side_api.html" >3. Server Side API</a> &raquo;</li>
  44. <li><a href="server_side_internals.html" accesskey="U">Server Side Internals</a> &raquo;</li>
  45. </ul>
  46. </div>
  47. <div class="sphinxsidebar">
  48. <div class="sphinxsidebarwrapper">
  49. <h3><a href="index.html">Table Of Contents</a></h3>
  50. <ul>
  51. <li><a class="reference external" href=""><tt class="docutils literal"><span class="pre">db</span></tt> &#8212; Database</a><ul>
  52. <li><a class="reference external" href="#database-object-conn">database object &#8212; conn</a></li>
  53. </ul>
  54. </li>
  55. </ul>
  56. <h4>Previous topic</h4>
  57. <p class="topless"><a href="db_schema.html"
  58. title="previous chapter"><tt class="docutils literal docutils literal"><span class="pre">db_schema</span></tt> &#8212; Database Schema Management Module</a></p>
  59. <h4>Next topic</h4>
  60. <p class="topless"><a href="page_body.html"
  61. title="next chapter"><tt class="docutils literal"><span class="pre">page_body</span></tt> &#8212; Page Body Serverside Module</a></p>
  62. <h3>This Page</h3>
  63. <ul class="this-page-menu">
  64. <li><a href="_sources/db.txt"
  65. rel="nofollow">Show Source</a></li>
  66. </ul>
  67. <div id="searchbox" style="display: none">
  68. <h3>Quick search</h3>
  69. <form class="search" action="search.html" method="get">
  70. <input type="text" name="q" size="18" />
  71. <input type="submit" value="Go" />
  72. <input type="hidden" name="check_keywords" value="yes" />
  73. <input type="hidden" name="area" value="default" />
  74. </form>
  75. <p class="searchtip" style="font-size: 90%">
  76. Enter search terms or a module, class or function name.
  77. </p>
  78. </div>
  79. <script type="text/javascript">$('#searchbox').show(0);</script>
  80. </div>
  81. </div>
  82. <div class="document">
  83. <div class="documentwrapper">
  84. <div class="bodywrapper">
  85. <div class="body">
  86. <div class="section" id="module-db">
  87. <h1><tt class="xref docutils literal"><span class="pre">db</span></tt> &#8212; Database<a class="headerlink" href="#module-db" title="Permalink to this headline">¶</a></h1>
  88. <div class="section" id="database-object-conn">
  89. <h2>database object &#8212; conn<a class="headerlink" href="#database-object-conn" title="Permalink to this headline">¶</a></h2>
  90. <dl class="class">
  91. <dt>
  92. <tt class="descname">Database(host='', user='', password='', use_default = 0):</tt></dt>
  93. <dd><p>Open a database connection with the given parmeters, if use_default is True, use the
  94. login details from <cite>defs.py</cite>. This is called by the request handler and is accessible using
  95. the <cite>conn</cite> global variable. the <cite>sql</cite> method is also global to run queries</p>
  96. <dl class="attribute">
  97. <dt id="db.host">
  98. <tt class="descclassname">db.</tt><tt class="descname">host</tt><a class="headerlink" href="#db.host" title="Permalink to this definition">¶</a></dt>
  99. <dd>Database host or &#8216;localhost&#8217;</dd></dl>
  100. <dl class="attribute">
  101. <dt id="db.user">
  102. <tt class="descclassname">db.</tt><tt class="descname">user</tt><a class="headerlink" href="#db.user" title="Permalink to this definition">¶</a></dt>
  103. <dd>Database user</dd></dl>
  104. <dl class="attribute">
  105. <dt id="db.password">
  106. <tt class="descclassname">db.</tt><tt class="descname">password</tt><a class="headerlink" href="#db.password" title="Permalink to this definition">¶</a></dt>
  107. <dd>Database password - cleared after connection is made</dd></dl>
  108. <dl class="attribute">
  109. <dt id="db.is_testing">
  110. <tt class="descclassname">db.</tt><tt class="descname">is_testing</tt><a class="headerlink" href="#db.is_testing" title="Permalink to this definition">¶</a></dt>
  111. <dd>1 if session is in <cite>Testing Mode</cite> else 0</dd></dl>
  112. <dl class="attribute">
  113. <dt id="db.in_transaction">
  114. <tt class="descclassname">db.</tt><tt class="descname">in_transaction</tt><a class="headerlink" href="#db.in_transaction" title="Permalink to this definition">¶</a></dt>
  115. <dd>1 if connection is in a Transaction else 0</dd></dl>
  116. <dl class="attribute">
  117. <dt id="db.testing_tables">
  118. <tt class="descclassname">db.</tt><tt class="descname">testing_tables</tt><a class="headerlink" href="#db.testing_tables" title="Permalink to this definition">¶</a></dt>
  119. <dd>list of tables, tables with <cite>tab</cite> + doctype</dd></dl>
  120. <dl class="method">
  121. <dt id="db.connect">
  122. <tt class="descclassname">db.</tt><tt class="descname">connect</tt><big>(</big><big>)</big><a class="headerlink" href="#db.connect" title="Permalink to this definition">¶</a></dt>
  123. <dd>Connect to a database</dd></dl>
  124. <dl class="method">
  125. <dt id="db.use">
  126. <tt class="descclassname">db.</tt><tt class="descname">use</tt><big>(</big><em>db_name</em><big>)</big><a class="headerlink" href="#db.use" title="Permalink to this definition">¶</a></dt>
  127. <dd><cite>USE</cite> db_name</dd></dl>
  128. <dl class="method">
  129. <dt id="db.set_db">
  130. <tt class="descclassname">db.</tt><tt class="descname">set_db</tt><big>(</big><em>account</em><big>)</big><a class="headerlink" href="#db.set_db" title="Permalink to this definition">¶</a></dt>
  131. <dd>Switch to database of given <cite>account</cite></dd></dl>
  132. <dl class="method">
  133. <dt id="db.check_transaction_status">
  134. <tt class="descclassname">db.</tt><tt class="descname">check_transaction_status</tt><big>(</big><em>query</em><big>)</big><a class="headerlink" href="#db.check_transaction_status" title="Permalink to this definition">¶</a></dt>
  135. <dd>Update <em>in_transaction</em> and check if &#8220;START TRANSACTION&#8221; is not called twice</dd></dl>
  136. <dl class="method">
  137. <dt id="db.fetch_as_dict">
  138. <tt class="descclassname">db.</tt><tt class="descname">fetch_as_dict</tt><big>(</big><big>)</big><a class="headerlink" href="#db.fetch_as_dict" title="Permalink to this definition">¶</a></dt>
  139. <dd>Internal - get results as dictionary</dd></dl>
  140. <dl class="method">
  141. <dt id="db.sql">
  142. <tt class="descclassname">db.</tt><tt class="descname">sql</tt><big>(</big><em>query</em>, <em>values=()</em>, <em>as_dict = 0</em>, <em>as_list = 0</em>, <em>allow_testing = 1</em><big>)</big><a class="headerlink" href="#db.sql" title="Permalink to this definition">¶</a></dt>
  143. <dd><ul class="simple">
  144. <li>Execute a <cite>query</cite>, with given <cite>values</cite></li>
  145. <li>returns as a dictionary if as_dict = 1</li>
  146. <li>returns as a list of lists (with cleaned up dates and decimals) if as_list = 1</li>
  147. </ul>
  148. </dd></dl>
  149. <dl class="method">
  150. <dt id="db.convert_to_lists">
  151. <tt class="descclassname">db.</tt><tt class="descname">convert_to_lists</tt><big>(</big><em>res</em><big>)</big><a class="headerlink" href="#db.convert_to_lists" title="Permalink to this definition">¶</a></dt>
  152. <dd>Convert the given result set to a list of lists (with cleaned up dates and decimals)</dd></dl>
  153. <dl class="method">
  154. <dt id="db.replace_tab_by_test">
  155. <tt class="descclassname">db.</tt><tt class="descname">replace_tab_by_test</tt><big>(</big><em>query</em><big>)</big><a class="headerlink" href="#db.replace_tab_by_test" title="Permalink to this definition">¶</a></dt>
  156. <dd>Relace all <tt class="docutils literal"><span class="pre">tab</span></tt> + doctype to <tt class="docutils literal"><span class="pre">test</span></tt> + doctype</dd></dl>
  157. <dl class="method">
  158. <dt id="db.get_testing_tables">
  159. <tt class="descclassname">db.</tt><tt class="descname">get_testing_tables</tt><big>(</big><big>)</big><a class="headerlink" href="#db.get_testing_tables" title="Permalink to this definition">¶</a></dt>
  160. <dd>Get list of all tables for which <cite>tab</cite> is to be replaced by <cite>test</cite> before a query is executed</dd></dl>
  161. <dl class="method">
  162. <dt id="db.get_value">
  163. <tt class="descclassname">db.</tt><tt class="descname">get_value</tt><big>(</big><em>doctype</em>, <em>docname</em>, <em>fieldname</em><big>)</big><a class="headerlink" href="#db.get_value" title="Permalink to this definition">¶</a></dt>
  164. <dd><p>Get a single value from a record.</p>
  165. <p>For Single records, let docname be = None</p>
  166. </dd></dl>
  167. <dl class="method">
  168. <dt id="db.get_description">
  169. <tt class="descclassname">db.</tt><tt class="descname">get_description</tt><big>(</big><big>)</big><a class="headerlink" href="#db.get_description" title="Permalink to this definition">¶</a></dt>
  170. <dd>Get metadata of the last query</dd></dl>
  171. <dl class="method">
  172. <dt id="db.field_exists">
  173. <tt class="descclassname">db.</tt><tt class="descname">field_exists</tt><big>(</big><em>dt</em>, <em>fn</em><big>)</big><a class="headerlink" href="#db.field_exists" title="Permalink to this definition">¶</a></dt>
  174. <dd>Returns True if <cite>fn</cite> exists in <cite>DocType</cite> <cite>dt</cite></dd></dl>
  175. <dl class="method">
  176. <dt id="db.exists">
  177. <tt class="descclassname">db.</tt><tt class="descname">exists</tt><big>(</big><em>dt</em>, <em>dn</em><big>)</big><a class="headerlink" href="#db.exists" title="Permalink to this definition">¶</a></dt>
  178. <dd>Returns true if the record exists</dd></dl>
  179. <dl class="method">
  180. <dt id="db.close">
  181. <tt class="descclassname">db.</tt><tt class="descname">close</tt><big>(</big><big>)</big><a class="headerlink" href="#db.close" title="Permalink to this definition">¶</a></dt>
  182. <dd>Close my connection</dd></dl>
  183. </dd></dl>
  184. </div>
  185. </div>
  186. </div>
  187. </div>
  188. </div>
  189. <div class="clearer"></div>
  190. </div>
  191. <div class="related">
  192. <h3>Navigation</h3>
  193. <ul>
  194. <li class="right" style="margin-right: 10px">
  195. <a href="genindex.html" title="General Index"
  196. >index</a></li>
  197. <li class="right" >
  198. <a href="modindex.html" title="Global Module Index"
  199. >modules</a> |</li>
  200. <li class="right" >
  201. <a href="page_body.html" title="page_body — Page Body Serverside Module"
  202. >next</a> |</li>
  203. <li class="right" >
  204. <a href="db_schema.html" title="db_schema — Database Schema Management Module"
  205. >previous</a> |</li>
  206. <li><a href="index.html">Documentation</a> &raquo;</li>
  207. <li><a href="server_side_api.html" >3. Server Side API</a> &raquo;</li>
  208. <li><a href="server_side_internals.html" >Server Side Internals</a> &raquo;</li>
  209. </ul>
  210. </div>
  211. <div class="footer">
  212. &copy; Copyright 2010, Rushabh Mehta.
  213. Created using <a href="http://sphinx.pocoo.org/">Sphinx</a> 0.6.3.
  214. </div>
  215. </body>
  216. </html>