MobileBlur

web2py.gluon.dal-pysrc.html at [50a1ba732d]
Login

web2py.gluon.dal-pysrc.html at [50a1ba732d]

File applications/examples/static/epydoc/web2py.gluon.dal-pysrc.html artifact db12cff127 part of check-in 50a1ba732d


<?xml version="1.0" encoding="ascii"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
          "DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
  <title>web2py.gluon.dal</title>
  <link rel="stylesheet" href="epydoc.css" type="text/css" />
  <script type="text/javascript" src="epydoc.js"></script>
</head>

<body bgcolor="white" text="black" link="blue" vlink="#204080"
      alink="#204080">
<!-- ==================== NAVIGATION BAR ==================== -->
<table class="navbar" border="0" width="100%" cellpadding="0"
       bgcolor="#a0c0ff" cellspacing="0">
  <tr valign="middle">
  <!-- Home link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="web2py.gluon-module.html">Home</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Tree link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="module-tree.html">Trees</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Index link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="identifier-index.html">Indices</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Help link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="help.html">Help</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Project homepage -->
      <th class="navbar" align="right" width="100%">
        <table border="0" cellpadding="0" cellspacing="0">
          <tr><th class="navbar" align="center"
            ><a class="navbar" target="_top" href="http://www.web2py.com">web2py Web Framework</a></th>
          </tr></table></th>
  </tr>
</table>
<table width="100%" cellpadding="0" cellspacing="0">
  <tr valign="top">
    <td width="100%">
      <span class="breadcrumbs">
        Package&nbsp;web2py ::
        <a href="web2py.gluon-module.html">Package&nbsp;gluon</a> ::
        Module&nbsp;dal
      </span>
    </td>
    <td>
      <table cellpadding="0" cellspacing="0">
        <!-- hide/show private -->
        <tr><td align="right"><span class="options">[<a href="javascript:void(0);" class="privatelink"
    onclick="toggle_private();">hide&nbsp;private</a>]</span></td></tr>
        <tr><td align="right"><span class="options"
            >[<a href="frames.html" target="_top">frames</a
            >]&nbsp;|&nbsp;<a href="web2py.gluon.dal-pysrc.html"
            target="_top">no&nbsp;frames</a>]</span></td></tr>
      </table>
    </td>
  </tr>
</table>
<h1 class="epydoc">Source Code for <a href="web2py.gluon.dal-module.html">Module web2py.gluon.dal</a></h1>
<pre class="py-src">
<a name="L1"></a><tt class="py-lineno">   1</tt>  <tt class="py-line"><tt class="py-comment">#!/bin/env python</tt> </tt>
<a name="L2"></a><tt class="py-lineno">   2</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># -*- coding: utf-8 -*-</tt> </tt>
<a name="L3"></a><tt class="py-lineno">   3</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L4"></a><tt class="py-lineno">   4</tt>  <tt class="py-line"><tt class="py-docstring">"""</tt> </tt>
<a name="L5"></a><tt class="py-lineno">   5</tt>  <tt class="py-line"><tt class="py-docstring">This file is part of the web2py Web Framework</tt> </tt>
<a name="L6"></a><tt class="py-lineno">   6</tt>  <tt class="py-line"><tt class="py-docstring">Copyrighted by Massimo Di Pierro &lt;mdipierro@cs.depaul.edu&gt;</tt> </tt>
<a name="L7"></a><tt class="py-lineno">   7</tt>  <tt class="py-line"><tt class="py-docstring">License: LGPLv3 (http://www.gnu.org/licenses/lgpl.html)</tt> </tt>
<a name="L8"></a><tt class="py-lineno">   8</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L9"></a><tt class="py-lineno">   9</tt>  <tt class="py-line"><tt class="py-docstring">Thanks to</tt> </tt>
<a name="L10"></a><tt class="py-lineno">  10</tt>  <tt class="py-line"><tt class="py-docstring">    * Niall Sweeny &lt;niall.sweeny@fonjax.com&gt; for MS SQL support</tt> </tt>
<a name="L11"></a><tt class="py-lineno">  11</tt>  <tt class="py-line"><tt class="py-docstring">    * Marcel Leuthi &lt;mluethi@mlsystems.ch&gt; for Oracle support</tt> </tt>
<a name="L12"></a><tt class="py-lineno">  12</tt>  <tt class="py-line"><tt class="py-docstring">    * Denes</tt> </tt>
<a name="L13"></a><tt class="py-lineno">  13</tt>  <tt class="py-line"><tt class="py-docstring">    * Chris Clark</tt> </tt>
<a name="L14"></a><tt class="py-lineno">  14</tt>  <tt class="py-line"><tt class="py-docstring">    * clach05</tt> </tt>
<a name="L15"></a><tt class="py-lineno">  15</tt>  <tt class="py-line"><tt class="py-docstring">    * Denes Lengyel</tt> </tt>
<a name="L16"></a><tt class="py-lineno">  16</tt>  <tt class="py-line"><tt class="py-docstring">    * and many others who have contributed to current and previous versions</tt> </tt>
<a name="L17"></a><tt class="py-lineno">  17</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L18"></a><tt class="py-lineno">  18</tt>  <tt class="py-line"><tt class="py-docstring">This file contains the DAL support for many relational databases,</tt> </tt>
<a name="L19"></a><tt class="py-lineno">  19</tt>  <tt class="py-line"><tt class="py-docstring">including:</tt> </tt>
<a name="L20"></a><tt class="py-lineno">  20</tt>  <tt class="py-line"><tt class="py-docstring">- SQLite</tt> </tt>
<a name="L21"></a><tt class="py-lineno">  21</tt>  <tt class="py-line"><tt class="py-docstring">- MySQL</tt> </tt>
<a name="L22"></a><tt class="py-lineno">  22</tt>  <tt class="py-line"><tt class="py-docstring">- Postgres</tt> </tt>
<a name="L23"></a><tt class="py-lineno">  23</tt>  <tt class="py-line"><tt class="py-docstring">- Oracle</tt> </tt>
<a name="L24"></a><tt class="py-lineno">  24</tt>  <tt class="py-line"><tt class="py-docstring">- MS SQL</tt> </tt>
<a name="L25"></a><tt class="py-lineno">  25</tt>  <tt class="py-line"><tt class="py-docstring">- DB2</tt> </tt>
<a name="L26"></a><tt class="py-lineno">  26</tt>  <tt class="py-line"><tt class="py-docstring">- Interbase</tt> </tt>
<a name="L27"></a><tt class="py-lineno">  27</tt>  <tt class="py-line"><tt class="py-docstring">- Ingres</tt> </tt>
<a name="L28"></a><tt class="py-lineno">  28</tt>  <tt class="py-line"><tt class="py-docstring">- SapDB (experimental)</tt> </tt>
<a name="L29"></a><tt class="py-lineno">  29</tt>  <tt class="py-line"><tt class="py-docstring">- Cubrid (experimental)</tt> </tt>
<a name="L30"></a><tt class="py-lineno">  30</tt>  <tt class="py-line"><tt class="py-docstring">- CouchDB (experimental)</tt> </tt>
<a name="L31"></a><tt class="py-lineno">  31</tt>  <tt class="py-line"><tt class="py-docstring">- MongoDB (in progress)</tt> </tt>
<a name="L32"></a><tt class="py-lineno">  32</tt>  <tt class="py-line"><tt class="py-docstring">- Google:nosql</tt> </tt>
<a name="L33"></a><tt class="py-lineno">  33</tt>  <tt class="py-line"><tt class="py-docstring">- Google:sql</tt> </tt>
<a name="L34"></a><tt class="py-lineno">  34</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L35"></a><tt class="py-lineno">  35</tt>  <tt class="py-line"><tt class="py-docstring">Example of usage:</tt> </tt>
<a name="L36"></a><tt class="py-lineno">  36</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L37"></a><tt class="py-lineno">  37</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; # from dal import DAL, Field</tt> </tt>
<a name="L38"></a><tt class="py-lineno">  38</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L39"></a><tt class="py-lineno">  39</tt>  <tt class="py-line"><tt class="py-docstring">### create DAL connection (and create DB if not exists)</tt> </tt>
<a name="L40"></a><tt class="py-lineno">  40</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; db=DAL(('mysql://a:b@locahost/x','sqlite://storage.sqlite'),folder=None)</tt> </tt>
<a name="L41"></a><tt class="py-lineno">  41</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L42"></a><tt class="py-lineno">  42</tt>  <tt class="py-line"><tt class="py-docstring">### define a table 'person' (create/aster as necessary)</tt> </tt>
<a name="L43"></a><tt class="py-lineno">  43</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; person = db.define_table('person',Field('name','string'))</tt> </tt>
<a name="L44"></a><tt class="py-lineno">  44</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L45"></a><tt class="py-lineno">  45</tt>  <tt class="py-line"><tt class="py-docstring">### insert a record</tt> </tt>
<a name="L46"></a><tt class="py-lineno">  46</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; id = person.insert(name='James')</tt> </tt>
<a name="L47"></a><tt class="py-lineno">  47</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L48"></a><tt class="py-lineno">  48</tt>  <tt class="py-line"><tt class="py-docstring">### retrieve it by id</tt> </tt>
<a name="L49"></a><tt class="py-lineno">  49</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; james = person(id)</tt> </tt>
<a name="L50"></a><tt class="py-lineno">  50</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L51"></a><tt class="py-lineno">  51</tt>  <tt class="py-line"><tt class="py-docstring">### retrieve it by name</tt> </tt>
<a name="L52"></a><tt class="py-lineno">  52</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; james = person(name='James')</tt> </tt>
<a name="L53"></a><tt class="py-lineno">  53</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L54"></a><tt class="py-lineno">  54</tt>  <tt class="py-line"><tt class="py-docstring">### retrieve it by arbitrary query</tt> </tt>
<a name="L55"></a><tt class="py-lineno">  55</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; query = (person.name=='James')&amp;(person.name.startswith('J'))</tt> </tt>
<a name="L56"></a><tt class="py-lineno">  56</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; james = db(query).select(person.ALL)[0]</tt> </tt>
<a name="L57"></a><tt class="py-lineno">  57</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L58"></a><tt class="py-lineno">  58</tt>  <tt class="py-line"><tt class="py-docstring">### update one record</tt> </tt>
<a name="L59"></a><tt class="py-lineno">  59</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; james.update_record(name='Jim')</tt> </tt>
<a name="L60"></a><tt class="py-lineno">  60</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L61"></a><tt class="py-lineno">  61</tt>  <tt class="py-line"><tt class="py-docstring">### update multiple records by query</tt> </tt>
<a name="L62"></a><tt class="py-lineno">  62</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; db(person.name.like('J%')).update(name='James')</tt> </tt>
<a name="L63"></a><tt class="py-lineno">  63</tt>  <tt class="py-line"><tt class="py-docstring">1</tt> </tt>
<a name="L64"></a><tt class="py-lineno">  64</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L65"></a><tt class="py-lineno">  65</tt>  <tt class="py-line"><tt class="py-docstring">### delete records by query</tt> </tt>
<a name="L66"></a><tt class="py-lineno">  66</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; db(person.name.lower()=='jim').delete()</tt> </tt>
<a name="L67"></a><tt class="py-lineno">  67</tt>  <tt class="py-line"><tt class="py-docstring">0</tt> </tt>
<a name="L68"></a><tt class="py-lineno">  68</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L69"></a><tt class="py-lineno">  69</tt>  <tt class="py-line"><tt class="py-docstring">### retrieve multiple records (rows)</tt> </tt>
<a name="L70"></a><tt class="py-lineno">  70</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; people = db(person).select(orderby=person.name,groupby=person.name,limitby=(0,100))</tt> </tt>
<a name="L71"></a><tt class="py-lineno">  71</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L72"></a><tt class="py-lineno">  72</tt>  <tt class="py-line"><tt class="py-docstring">### further filter them</tt> </tt>
<a name="L73"></a><tt class="py-lineno">  73</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; james = people.find(lambda row: row.name=='James').first()</tt> </tt>
<a name="L74"></a><tt class="py-lineno">  74</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; print james.id, james.name</tt> </tt>
<a name="L75"></a><tt class="py-lineno">  75</tt>  <tt class="py-line"><tt class="py-docstring">1 James</tt> </tt>
<a name="L76"></a><tt class="py-lineno">  76</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L77"></a><tt class="py-lineno">  77</tt>  <tt class="py-line"><tt class="py-docstring">### check aggrgates</tt> </tt>
<a name="L78"></a><tt class="py-lineno">  78</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; counter = person.id.count()</tt> </tt>
<a name="L79"></a><tt class="py-lineno">  79</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; print db(person).select(counter).first()(counter)</tt> </tt>
<a name="L80"></a><tt class="py-lineno">  80</tt>  <tt class="py-line"><tt class="py-docstring">1</tt> </tt>
<a name="L81"></a><tt class="py-lineno">  81</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L82"></a><tt class="py-lineno">  82</tt>  <tt class="py-line"><tt class="py-docstring">### delete one record</tt> </tt>
<a name="L83"></a><tt class="py-lineno">  83</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; james.delete_record()</tt> </tt>
<a name="L84"></a><tt class="py-lineno">  84</tt>  <tt class="py-line"><tt class="py-docstring">1</tt> </tt>
<a name="L85"></a><tt class="py-lineno">  85</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L86"></a><tt class="py-lineno">  86</tt>  <tt class="py-line"><tt class="py-docstring">### delete (drop) entire database table</tt> </tt>
<a name="L87"></a><tt class="py-lineno">  87</tt>  <tt class="py-line"><tt class="py-docstring">&gt;&gt;&gt; person.drop()</tt> </tt>
<a name="L88"></a><tt class="py-lineno">  88</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L89"></a><tt class="py-lineno">  89</tt>  <tt class="py-line"><tt class="py-docstring">Supported field types:</tt> </tt>
<a name="L90"></a><tt class="py-lineno">  90</tt>  <tt class="py-line"><tt class="py-docstring">id string text boolean integer double decimal password upload blob time date datetime,</tt> </tt>
<a name="L91"></a><tt class="py-lineno">  91</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L92"></a><tt class="py-lineno">  92</tt>  <tt class="py-line"><tt class="py-docstring">Supported DAL URI strings:</tt> </tt>
<a name="L93"></a><tt class="py-lineno">  93</tt>  <tt class="py-line"><tt class="py-docstring">'sqlite://test.db'</tt> </tt>
<a name="L94"></a><tt class="py-lineno">  94</tt>  <tt class="py-line"><tt class="py-docstring">'sqlite:memory'</tt> </tt>
<a name="L95"></a><tt class="py-lineno">  95</tt>  <tt class="py-line"><tt class="py-docstring">'jdbc:sqlite://test.db'</tt> </tt>
<a name="L96"></a><tt class="py-lineno">  96</tt>  <tt class="py-line"><tt class="py-docstring">'mysql://root:none@localhost/test'</tt> </tt>
<a name="L97"></a><tt class="py-lineno">  97</tt>  <tt class="py-line"><tt class="py-docstring">'postgres://mdipierro:none@localhost/test'</tt> </tt>
<a name="L98"></a><tt class="py-lineno">  98</tt>  <tt class="py-line"><tt class="py-docstring">'jdbc:postgres://mdipierro:none@localhost/test'</tt> </tt>
<a name="L99"></a><tt class="py-lineno">  99</tt>  <tt class="py-line"><tt class="py-docstring">'mssql://web2py:none@A64X2/web2py_test'</tt> </tt>
<a name="L100"></a><tt class="py-lineno"> 100</tt>  <tt class="py-line"><tt class="py-docstring">'mssql2://web2py:none@A64X2/web2py_test' # alternate mappings</tt> </tt>
<a name="L101"></a><tt class="py-lineno"> 101</tt>  <tt class="py-line"><tt class="py-docstring">'oracle://username:password@database'</tt> </tt>
<a name="L102"></a><tt class="py-lineno"> 102</tt>  <tt class="py-line"><tt class="py-docstring">'firebird://user:password@server:3050/database'</tt> </tt>
<a name="L103"></a><tt class="py-lineno"> 103</tt>  <tt class="py-line"><tt class="py-docstring">'db2://DSN=dsn;UID=user;PWD=pass'</tt> </tt>
<a name="L104"></a><tt class="py-lineno"> 104</tt>  <tt class="py-line"><tt class="py-docstring">'firebird://username:password@hostname/database'</tt> </tt>
<a name="L105"></a><tt class="py-lineno"> 105</tt>  <tt class="py-line"><tt class="py-docstring">'firebird_embedded://username:password@c://path'</tt> </tt>
<a name="L106"></a><tt class="py-lineno"> 106</tt>  <tt class="py-line"><tt class="py-docstring">'informix://user:password@server:3050/database'</tt> </tt>
<a name="L107"></a><tt class="py-lineno"> 107</tt>  <tt class="py-line"><tt class="py-docstring">'informixu://user:password@server:3050/database' # unicode informix</tt> </tt>
<a name="L108"></a><tt class="py-lineno"> 108</tt>  <tt class="py-line"><tt class="py-docstring">'google:datastore' # for google app engine datastore</tt> </tt>
<a name="L109"></a><tt class="py-lineno"> 109</tt>  <tt class="py-line"><tt class="py-docstring">'google:sql' # for google app engine with sql (mysql compatible)</tt> </tt>
<a name="L110"></a><tt class="py-lineno"> 110</tt>  <tt class="py-line"><tt class="py-docstring">'teradata://DSN=dsn;UID=user;PWD=pass' # experimental </tt> </tt>
<a name="L111"></a><tt class="py-lineno"> 111</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L112"></a><tt class="py-lineno"> 112</tt>  <tt class="py-line"><tt class="py-docstring">For more info:</tt> </tt>
<a name="L113"></a><tt class="py-lineno"> 113</tt>  <tt class="py-line"><tt class="py-docstring">help(DAL)</tt> </tt>
<a name="L114"></a><tt class="py-lineno"> 114</tt>  <tt class="py-line"><tt class="py-docstring">help(Field)</tt> </tt>
<a name="L115"></a><tt class="py-lineno"> 115</tt>  <tt class="py-line"><tt class="py-docstring">"""</tt> </tt>
<a name="L116"></a><tt class="py-lineno"> 116</tt>  <tt class="py-line"> </tt>
<a name="L117"></a><tt class="py-lineno"> 117</tt>  <tt class="py-line"><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L118"></a><tt class="py-lineno"> 118</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># this file orly exposes DAL and Field</tt> </tt>
<a name="L119"></a><tt class="py-lineno"> 119</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L120"></a><tt class="py-lineno"> 120</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L121"></a><tt class="py-lineno"> 121</tt>  <tt class="py-line"><tt class="py-name">__all__</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'DAL'</tt><tt class="py-op">,</tt> <tt class="py-string">'Field'</tt><tt class="py-op">]</tt> </tt>
<a name="L122"></a><tt class="py-lineno"> 122</tt>  <tt class="py-line"><tt id="link-0" class="py-name" targets="Variable web2py.gluon.dal.MAXCHARLENGTH=web2py.gluon.dal-module.html#MAXCHARLENGTH"><a title="web2py.gluon.dal.MAXCHARLENGTH" class="py-name" href="#" onclick="return doclink('link-0', 'MAXCHARLENGTH', 'link-0');">MAXCHARLENGTH</a></tt> <tt class="py-op">=</tt> <tt class="py-number">512</tt> </tt>
<a name="L123"></a><tt class="py-lineno"> 123</tt>  <tt class="py-line"><tt id="link-1" class="py-name" targets="Variable web2py.gluon.dal.INFINITY=web2py.gluon.dal-module.html#INFINITY"><a title="web2py.gluon.dal.INFINITY" class="py-name" href="#" onclick="return doclink('link-1', 'INFINITY', 'link-1');">INFINITY</a></tt> <tt class="py-op">=</tt> <tt class="py-number">2</tt><tt class="py-op">**</tt><tt class="py-number">15</tt> <tt class="py-comment"># not quite but reasonable default max char length</tt> </tt>
<a name="L124"></a><tt class="py-lineno"> 124</tt>  <tt class="py-line"> </tt>
<a name="L125"></a><tt class="py-lineno"> 125</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">re</tt> </tt>
<a name="L126"></a><tt class="py-lineno"> 126</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">sys</tt> </tt>
<a name="L127"></a><tt class="py-lineno"> 127</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">locale</tt> </tt>
<a name="L128"></a><tt class="py-lineno"> 128</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">os</tt> </tt>
<a name="L129"></a><tt class="py-lineno"> 129</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt id="link-2" class="py-name" targets="Variable web2py.gluon.dal.BaseAdapter.types=web2py.gluon.dal.BaseAdapter-class.html#types,Variable web2py.gluon.dal.CouchDBAdapter.types=web2py.gluon.dal.CouchDBAdapter-class.html#types,Variable web2py.gluon.dal.DB2Adapter.types=web2py.gluon.dal.DB2Adapter-class.html#types,Variable web2py.gluon.dal.FireBirdAdapter.types=web2py.gluon.dal.FireBirdAdapter-class.html#types,Variable web2py.gluon.dal.GoogleDatastoreAdapter.types=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#types,Variable web2py.gluon.dal.InformixAdapter.types=web2py.gluon.dal.InformixAdapter-class.html#types,Variable web2py.gluon.dal.IngresAdapter.types=web2py.gluon.dal.IngresAdapter-class.html#types,Variable web2py.gluon.dal.IngresUnicodeAdapter.types=web2py.gluon.dal.IngresUnicodeAdapter-class.html#types,Variable web2py.gluon.dal.MSSQL2Adapter.types=web2py.gluon.dal.MSSQL2Adapter-class.html#types,Variable web2py.gluon.dal.MSSQLAdapter.types=web2py.gluon.dal.MSSQLAdapter-class.html#types,Variable web2py.gluon.dal.MongoDBAdapter.types=web2py.gluon.dal.MongoDBAdapter-class.html#types,Variable web2py.gluon.dal.MySQLAdapter.types=web2py.gluon.dal.MySQLAdapter-class.html#types,Variable web2py.gluon.dal.OracleAdapter.types=web2py.gluon.dal.OracleAdapter-class.html#types,Variable web2py.gluon.dal.PostgreSQLAdapter.types=web2py.gluon.dal.PostgreSQLAdapter-class.html#types,Variable web2py.gluon.dal.SAPDBAdapter.types=web2py.gluon.dal.SAPDBAdapter-class.html#types,Variable web2py.gluon.dal.TeradataAdapter.types=web2py.gluon.dal.TeradataAdapter-class.html#types"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-2', 'types', 'link-2');">types</a></tt> </tt>
<a name="L130"></a><tt class="py-lineno"> 130</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">cPickle</tt> </tt>
<a name="L131"></a><tt class="py-lineno"> 131</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt id="link-3" class="py-name" targets="Class datetime.datetime=datetime.datetime-class.html"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-3', 'datetime', 'link-3');">datetime</a></tt> </tt>
<a name="L132"></a><tt class="py-lineno"> 132</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">threading</tt> </tt>
<a name="L133"></a><tt class="py-lineno"> 133</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt id="link-4" class="py-name" targets="Class datetime.time=datetime.time-class.html"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-4', 'time', 'link-4');">time</a></tt> </tt>
<a name="L134"></a><tt class="py-lineno"> 134</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">cStringIO</tt> </tt>
<a name="L135"></a><tt class="py-lineno"> 135</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt id="link-5" class="py-name" targets="Function web2py.gluon.serializers.csv()=web2py.gluon.serializers-module.html#csv,Method web2py.gluon.tools.Service.csv()=web2py.gluon.tools.Service-class.html#csv"><a title="web2py.gluon.serializers.csv
web2py.gluon.tools.Service.csv" class="py-name" href="#" onclick="return doclink('link-5', 'csv', 'link-5');">csv</a></tt> </tt>
<a name="L136"></a><tt class="py-lineno"> 136</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">copy</tt> </tt>
<a name="L137"></a><tt class="py-lineno"> 137</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt id="link-6" class="py-name" targets="Variable web2py.gluon.rocket.Connection.socket=web2py.gluon.rocket.Connection-class.html#socket"><a title="web2py.gluon.rocket.Connection.socket" class="py-name" href="#" onclick="return doclink('link-6', 'socket', 'link-6');">socket</a></tt> </tt>
<a name="L138"></a><tt class="py-lineno"> 138</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">logging</tt> </tt>
<a name="L139"></a><tt class="py-lineno"> 139</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">copy_reg</tt> </tt>
<a name="L140"></a><tt class="py-lineno"> 140</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">base64</tt> </tt>
<a name="L141"></a><tt class="py-lineno"> 141</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">shutil</tt> </tt>
<a name="L142"></a><tt class="py-lineno"> 142</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">marshal</tt> </tt>
<a name="L143"></a><tt class="py-lineno"> 143</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">decimal</tt> </tt>
<a name="L144"></a><tt class="py-lineno"> 144</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">struct</tt> </tt>
<a name="L145"></a><tt class="py-lineno"> 145</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">urllib</tt> </tt>
<a name="L146"></a><tt class="py-lineno"> 146</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">hashlib</tt> </tt>
<a name="L147"></a><tt class="py-lineno"> 147</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">uuid</tt> </tt>
<a name="L148"></a><tt class="py-lineno"> 148</tt>  <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">glob</tt> </tt>
<a name="L149"></a><tt class="py-lineno"> 149</tt>  <tt class="py-line"> </tt>
<a name="L150"></a><tt class="py-lineno"> 150</tt>  <tt class="py-line"><tt id="link-7" class="py-name" targets="Variable web2py.gluon.dal.CALLABLETYPES=web2py.gluon.dal-module.html#CALLABLETYPES"><a title="web2py.gluon.dal.CALLABLETYPES" class="py-name" href="#" onclick="return doclink('link-7', 'CALLABLETYPES', 'link-7');">CALLABLETYPES</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt id="link-8" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-8', 'types', 'link-2');">types</a></tt><tt class="py-op">.</tt><tt class="py-name">LambdaType</tt><tt class="py-op">,</tt> <tt id="link-9" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-9', 'types', 'link-2');">types</a></tt><tt class="py-op">.</tt><tt class="py-name">FunctionType</tt><tt class="py-op">,</tt> <tt id="link-10" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-10', 'types', 'link-2');">types</a></tt><tt class="py-op">.</tt><tt class="py-name">BuiltinFunctionType</tt><tt class="py-op">,</tt> </tt>
<a name="L151"></a><tt class="py-lineno"> 151</tt>  <tt class="py-line">                 <tt id="link-11" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-11', 'types', 'link-2');">types</a></tt><tt class="py-op">.</tt><tt class="py-name">MethodType</tt><tt class="py-op">,</tt> <tt id="link-12" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-12', 'types', 'link-2');">types</a></tt><tt class="py-op">.</tt><tt class="py-name">BuiltinMethodType</tt><tt class="py-op">)</tt> </tt>
<a name="L152"></a><tt class="py-lineno"> 152</tt>  <tt class="py-line"> </tt>
<a name="L153"></a><tt class="py-lineno"> 153</tt>  <tt class="py-line"> </tt>
<a name="L154"></a><tt class="py-lineno"> 154</tt>  <tt class="py-line"><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L155"></a><tt class="py-lineno"> 155</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># following checks allows running of dal without web2py as a standalone module</tt> </tt>
<a name="L156"></a><tt class="py-lineno"> 156</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L157"></a><tt class="py-lineno"> 157</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L158"></a><tt class="py-lineno"> 158</tt>  <tt class="py-line">    <tt class="py-keyword">from</tt> <tt id="link-13" class="py-name" targets="Module web2py.gluon.utils=web2py.gluon.utils-module.html"><a title="web2py.gluon.utils" class="py-name" href="#" onclick="return doclink('link-13', 'utils', 'link-13');">utils</a></tt> <tt class="py-keyword">import</tt> <tt id="link-14" class="py-name" targets="Function web2py.gluon.utils.web2py_uuid()=web2py.gluon.utils-module.html#web2py_uuid"><a title="web2py.gluon.utils.web2py_uuid" class="py-name" href="#" onclick="return doclink('link-14', 'web2py_uuid', 'link-14');">web2py_uuid</a></tt> </tt>
<a name="L159"></a><tt class="py-lineno"> 159</tt>  <tt class="py-line"><tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L160"></a><tt class="py-lineno"> 160</tt>  <tt class="py-line">    <tt class="py-keyword">import</tt> <tt class="py-name">uuid</tt> </tt>
<a name="web2py_uuid"></a><div id="web2py_uuid-def"><a name="L161"></a><tt class="py-lineno"> 161</tt> <a class="py-toggle" href="#" id="web2py_uuid-toggle" onclick="return toggle('web2py_uuid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#web2py_uuid">web2py_uuid</a><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">uuid</tt><tt class="py-op">.</tt><tt class="py-name">uuid4</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L162"></a><tt class="py-lineno"> 162</tt>  <tt class="py-line"> </tt>
<a name="L163"></a><tt class="py-lineno"> 163</tt>  <tt class="py-line"><tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L164"></a><tt class="py-lineno"> 164</tt>  <tt class="py-line">    <tt class="py-keyword">import</tt> <tt id="link-15" class="py-name" targets="Module web2py.gluon.portalocker=web2py.gluon.portalocker-module.html"><a title="web2py.gluon.portalocker" class="py-name" href="#" onclick="return doclink('link-15', 'portalocker', 'link-15');">portalocker</a></tt> </tt>
<a name="L165"></a><tt class="py-lineno"> 165</tt>  <tt class="py-line">    <tt id="link-16" class="py-name" targets="Variable web2py.gluon.dal.have_portalocker=web2py.gluon.dal-module.html#have_portalocker"><a title="web2py.gluon.dal.have_portalocker" class="py-name" href="#" onclick="return doclink('link-16', 'have_portalocker', 'link-16');">have_portalocker</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L166"></a><tt class="py-lineno"> 166</tt>  <tt class="py-line"><tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L167"></a><tt class="py-lineno"> 167</tt>  <tt class="py-line">    <tt id="link-17" class="py-name"><a title="web2py.gluon.dal.have_portalocker" class="py-name" href="#" onclick="return doclink('link-17', 'have_portalocker', 'link-16');">have_portalocker</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L168"></a><tt class="py-lineno"> 168</tt>  <tt class="py-line"> </tt>
<a name="L169"></a><tt class="py-lineno"> 169</tt>  <tt class="py-line"><tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L170"></a><tt class="py-lineno"> 170</tt>  <tt class="py-line">    <tt class="py-keyword">import</tt> <tt id="link-18" class="py-name" targets="Module web2py.gluon.serializers=web2py.gluon.serializers-module.html"><a title="web2py.gluon.serializers" class="py-name" href="#" onclick="return doclink('link-18', 'serializers', 'link-18');">serializers</a></tt> </tt>
<a name="L171"></a><tt class="py-lineno"> 171</tt>  <tt class="py-line">    <tt id="link-19" class="py-name" targets="Variable web2py.gluon.dal.have_serializers=web2py.gluon.dal-module.html#have_serializers"><a title="web2py.gluon.dal.have_serializers" class="py-name" href="#" onclick="return doclink('link-19', 'have_serializers', 'link-19');">have_serializers</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L172"></a><tt class="py-lineno"> 172</tt>  <tt class="py-line"><tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L173"></a><tt class="py-lineno"> 173</tt>  <tt class="py-line">    <tt id="link-20" class="py-name"><a title="web2py.gluon.dal.have_serializers" class="py-name" href="#" onclick="return doclink('link-20', 'have_serializers', 'link-19');">have_serializers</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L174"></a><tt class="py-lineno"> 174</tt>  <tt class="py-line"> </tt>
<a name="L175"></a><tt class="py-lineno"> 175</tt>  <tt class="py-line"><tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L176"></a><tt class="py-lineno"> 176</tt>  <tt class="py-line">    <tt class="py-keyword">import</tt> <tt id="link-21" class="py-name" targets="Function web2py.gluon.tools.validators()=web2py.gluon.tools-module.html#validators,Module web2py.gluon.validators=web2py.gluon.validators-module.html"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-21', 'validators', 'link-21');">validators</a></tt> </tt>
<a name="L177"></a><tt class="py-lineno"> 177</tt>  <tt class="py-line">    <tt id="link-22" class="py-name" targets="Variable web2py.gluon.dal.have_validators=web2py.gluon.dal-module.html#have_validators"><a title="web2py.gluon.dal.have_validators" class="py-name" href="#" onclick="return doclink('link-22', 'have_validators', 'link-22');">have_validators</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L178"></a><tt class="py-lineno"> 178</tt>  <tt class="py-line"><tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L179"></a><tt class="py-lineno"> 179</tt>  <tt class="py-line">    <tt id="link-23" class="py-name"><a title="web2py.gluon.dal.have_validators" class="py-name" href="#" onclick="return doclink('link-23', 'have_validators', 'link-22');">have_validators</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L180"></a><tt class="py-lineno"> 180</tt>  <tt class="py-line"> </tt>
<a name="L181"></a><tt class="py-lineno"> 181</tt>  <tt class="py-line"><tt id="link-24" class="py-name" targets="Variable web2py.gluon.cache.logger=web2py.gluon.cache-module.html#logger,Variable web2py.gluon.compileapp.logger=web2py.gluon.compileapp-module.html#logger,Variable web2py.gluon.dal.logger=web2py.gluon.dal-module.html#logger,Variable web2py.gluon.debug.logger=web2py.gluon.debug-module.html#logger,Variable web2py.gluon.main.logger=web2py.gluon.main-module.html#logger,Variable web2py.gluon.newcron.logger=web2py.gluon.newcron-module.html#logger,Variable web2py.gluon.portalocker.logger=web2py.gluon.portalocker-module.html#logger,Variable web2py.gluon.restricted.logger=web2py.gluon.restricted-module.html#logger,Variable web2py.gluon.rewrite.logger=web2py.gluon.rewrite-module.html#logger,Variable web2py.gluon.shell.logger=web2py.gluon.shell-module.html#logger,Variable web2py.gluon.tools.logger=web2py.gluon.tools-module.html#logger,Variable web2py.gluon.utils.logger=web2py.gluon.utils-module.html#logger,Variable web2py.gluon.widget.logger=web2py.gluon.widget-module.html#logger"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-24', 'logger', 'link-24');">logger</a></tt> <tt class="py-op">=</tt> <tt class="py-name">logging</tt><tt class="py-op">.</tt><tt class="py-name">getLogger</tt><tt class="py-op">(</tt><tt class="py-string">"web2py.dal"</tt><tt class="py-op">)</tt> </tt>
<a name="L182"></a><tt class="py-lineno"> 182</tt>  <tt class="py-line"><tt id="link-25" class="py-name" targets="Function web2py.gluon.dal.DEFAULT()=web2py.gluon.dal-module.html#DEFAULT,Function web2py.gluon.tools.DEFAULT()=web2py.gluon.tools-module.html#DEFAULT"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-25', 'DEFAULT', 'link-25');">DEFAULT</a></tt> <tt class="py-op">=</tt> <tt class="py-keyword">lambda</tt><tt class="py-op">:</tt><tt class="py-number">0</tt> </tt>
<a name="L183"></a><tt class="py-lineno"> 183</tt>  <tt class="py-line"> </tt>
<a name="L184"></a><tt class="py-lineno"> 184</tt>  <tt class="py-line"><tt id="link-26" class="py-name" targets="Variable web2py.gluon.dal.sql_locker=web2py.gluon.dal-module.html#sql_locker"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-26', 'sql_locker', 'link-26');">sql_locker</a></tt> <tt class="py-op">=</tt> <tt class="py-name">threading</tt><tt class="py-op">.</tt><tt class="py-name">RLock</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L185"></a><tt class="py-lineno"> 185</tt>  <tt class="py-line"><tt id="link-27" class="py-name" targets="Variable web2py.gluon.dal.thread=web2py.gluon.dal-module.html#thread,Variable web2py.gluon.rewrite.thread=web2py.gluon.rewrite-module.html#thread"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-27', 'thread', 'link-27');">thread</a></tt> <tt class="py-op">=</tt> <tt class="py-name">threading</tt><tt class="py-op">.</tt><tt class="py-name">local</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L186"></a><tt class="py-lineno"> 186</tt>  <tt class="py-line"> </tt>
<a name="L187"></a><tt class="py-lineno"> 187</tt>  <tt class="py-line"><tt class="py-comment"># internal representation of tables with field</tt> </tt>
<a name="L188"></a><tt class="py-lineno"> 188</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">#  &lt;table&gt;.&lt;field&gt;, tables and fields may only be [a-zA-Z0-0_]</tt> </tt>
<a name="L189"></a><tt class="py-lineno"> 189</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L190"></a><tt class="py-lineno"> 190</tt>  <tt class="py-line"><tt id="link-28" class="py-name" targets="Variable web2py.gluon.dal.regex_dbname=web2py.gluon.dal-module.html#regex_dbname"><a title="web2py.gluon.dal.regex_dbname" class="py-name" href="#" onclick="return doclink('link-28', 'regex_dbname', 'link-28');">regex_dbname</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(\w+)(\:\w+)*'</tt><tt class="py-op">)</tt> </tt>
<a name="L191"></a><tt class="py-lineno"> 191</tt>  <tt class="py-line"><tt id="link-29" class="py-name" targets="Variable web2py.gluon.dal.table_field=web2py.gluon.dal-module.html#table_field,Variable web2py.gluon.sqlhtml.table_field=web2py.gluon.sqlhtml-module.html#table_field"><a title="web2py.gluon.dal.table_field
web2py.gluon.sqlhtml.table_field" class="py-name" href="#" onclick="return doclink('link-29', 'table_field', 'link-29');">table_field</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^[\w_]+\.[\w_]+$'</tt><tt class="py-op">)</tt> </tt>
<a name="L192"></a><tt class="py-lineno"> 192</tt>  <tt class="py-line"><tt id="link-30" class="py-name" targets="Variable web2py.gluon.dal.regex_content=web2py.gluon.dal-module.html#regex_content"><a title="web2py.gluon.dal.regex_content" class="py-name" href="#" onclick="return doclink('link-30', 'regex_content', 'link-30');">regex_content</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'(?P&lt;table&gt;[\w\-]+)\.(?P&lt;field&gt;[\w\-]+)\.(?P&lt;uuidkey&gt;[\w\-]+)\.(?P&lt;name&gt;\w+)\.\w+$'</tt><tt class="py-op">)</tt> </tt>
<a name="L193"></a><tt class="py-lineno"> 193</tt>  <tt class="py-line"><tt id="link-31" class="py-name" targets="Variable web2py.gluon.dal.regex_cleanup_fn=web2py.gluon.dal-module.html#regex_cleanup_fn"><a title="web2py.gluon.dal.regex_cleanup_fn" class="py-name" href="#" onclick="return doclink('link-31', 'regex_cleanup_fn', 'link-31');">regex_cleanup_fn</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'[\'"\s;]+'</tt><tt class="py-op">)</tt> </tt>
<a name="L194"></a><tt class="py-lineno"> 194</tt>  <tt class="py-line"><tt id="link-32" class="py-name" targets="Variable web2py.gluon.dal.string_unpack=web2py.gluon.dal-module.html#string_unpack"><a title="web2py.gluon.dal.string_unpack" class="py-name" href="#" onclick="return doclink('link-32', 'string_unpack', 'link-32');">string_unpack</a></tt><tt class="py-op">=</tt><tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'(?&lt;!\|)\|(?!\|)'</tt><tt class="py-op">)</tt> </tt>
<a name="L195"></a><tt class="py-lineno"> 195</tt>  <tt class="py-line"><tt id="link-33" class="py-name" targets="Variable web2py.gluon.dal.regex_python_keywords=web2py.gluon.dal-module.html#regex_python_keywords"><a title="web2py.gluon.dal.regex_python_keywords" class="py-name" href="#" onclick="return doclink('link-33', 'regex_python_keywords', 'link-33');">regex_python_keywords</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(and|del|from|not|while|as|elif|global|or|with|assert|else|if|pass|yield|break|except|import|print|class|exec|in|raise|continue|finally|is|return|def|for|lambda|try)$'</tt><tt class="py-op">)</tt> </tt>
<a name="L196"></a><tt class="py-lineno"> 196</tt>  <tt class="py-line"> </tt>
<a name="L197"></a><tt class="py-lineno"> 197</tt>  <tt class="py-line"> </tt>
<a name="L198"></a><tt class="py-lineno"> 198</tt>  <tt class="py-line"> </tt>
<a name="L199"></a><tt class="py-lineno"> 199</tt>  <tt class="py-line"><tt class="py-comment"># list of drivers will be built on the fly</tt> </tt>
<a name="L200"></a><tt class="py-lineno"> 200</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># and lists only what is available</tt> </tt>
<a name="L201"></a><tt class="py-lineno"> 201</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt id="link-34" class="py-name" targets="Variable web2py.gluon.dal.drivers=web2py.gluon.dal-module.html#drivers,Variable web2py.gluon.sql.drivers=web2py.gluon.sql-module.html#drivers"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-34', 'drivers', 'link-34');">drivers</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L202"></a><tt class="py-lineno"> 202</tt>  <tt class="py-line"> </tt>
<a name="L203"></a><tt class="py-lineno"> 203</tt>  <tt class="py-line"><tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L204"></a><tt class="py-lineno"> 204</tt>  <tt class="py-line">    <tt class="py-keyword">from</tt> <tt class="py-name">new</tt> <tt class="py-keyword">import</tt> <tt class="py-name">classobj</tt> </tt>
<a name="L205"></a><tt class="py-lineno"> 205</tt>  <tt class="py-line">    <tt class="py-keyword">from</tt> <tt class="py-name">google</tt><tt class="py-op">.</tt><tt class="py-name">appengine</tt><tt class="py-op">.</tt><tt class="py-name">ext</tt> <tt class="py-keyword">import</tt> <tt class="py-name">db</tt> <tt class="py-keyword">as</tt> <tt class="py-name">gae</tt> </tt>
<a name="L206"></a><tt class="py-lineno"> 206</tt>  <tt class="py-line">    <tt class="py-keyword">from</tt> <tt class="py-name">google</tt><tt class="py-op">.</tt><tt class="py-name">appengine</tt><tt class="py-op">.</tt><tt class="py-name">api</tt> <tt class="py-keyword">import</tt> <tt class="py-name">namespace_manager</tt><tt class="py-op">,</tt> <tt class="py-name">rdbms</tt> </tt>
<a name="L207"></a><tt class="py-lineno"> 207</tt>  <tt class="py-line">    <tt class="py-keyword">from</tt> <tt class="py-name">google</tt><tt class="py-op">.</tt><tt class="py-name">appengine</tt><tt class="py-op">.</tt><tt class="py-name">api</tt><tt class="py-op">.</tt><tt class="py-name">datastore_types</tt> <tt class="py-keyword">import</tt> <tt class="py-name">Key</tt>  <tt class="py-comment">### needed for belongs on ID</tt> </tt>
<a name="L208"></a><tt class="py-lineno"> 208</tt>  <tt class="py-line">    <tt class="py-keyword">from</tt> <tt class="py-name">google</tt><tt class="py-op">.</tt><tt class="py-name">appengine</tt><tt class="py-op">.</tt><tt class="py-name">ext</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">polymodel</tt> <tt class="py-keyword">import</tt> <tt class="py-name">PolyModel</tt> </tt>
<a name="L209"></a><tt class="py-lineno"> 209</tt>  <tt class="py-line">    <tt id="link-35" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-35', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-36" class="py-name" targets="Method web2py.gluon.html.DIV.append()=web2py.gluon.html.DIV-class.html#append,Method web2py.gluon.template.BlockNode.append()=web2py.gluon.template.BlockNode-class.html#append,Method web2py.gluon.template.Content.append()=web2py.gluon.template.Content-class.html#append"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-36', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'google'</tt><tt class="py-op">)</tt> </tt>
<a name="L210"></a><tt class="py-lineno"> 210</tt>  <tt class="py-line"><tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L211"></a><tt class="py-lineno"> 211</tt>  <tt class="py-line">    <tt class="py-keyword">pass</tt> </tt>
<a name="L212"></a><tt class="py-lineno"> 212</tt>  <tt class="py-line"> </tt>
<a name="L213"></a><tt class="py-lineno"> 213</tt>  <tt class="py-line"><tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-string">'google'</tt> <tt class="py-keyword">in</tt> <tt id="link-37" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-37', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">:</tt> </tt>
<a name="L214"></a><tt class="py-lineno"> 214</tt>  <tt class="py-line"> </tt>
<a name="L215"></a><tt class="py-lineno"> 215</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L216"></a><tt class="py-lineno"> 216</tt>  <tt class="py-line">        <tt class="py-keyword">from</tt> <tt class="py-name">pysqlite2</tt> <tt class="py-keyword">import</tt> <tt id="link-38" class="py-name" targets="Module sqlite3.dbapi2=sqlite3.dbapi2-module.html"><a title="sqlite3.dbapi2" class="py-name" href="#" onclick="return doclink('link-38', 'dbapi2', 'link-38');">dbapi2</a></tt> <tt class="py-keyword">as</tt> <tt class="py-name">sqlite3</tt> </tt>
<a name="L217"></a><tt class="py-lineno"> 217</tt>  <tt class="py-line">        <tt id="link-39" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-39', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-40" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-40', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'pysqlite2'</tt><tt class="py-op">)</tt> </tt>
<a name="L218"></a><tt class="py-lineno"> 218</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L219"></a><tt class="py-lineno"> 219</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L220"></a><tt class="py-lineno"> 220</tt>  <tt class="py-line">            <tt class="py-keyword">from</tt> <tt class="py-name">sqlite3</tt> <tt class="py-keyword">import</tt> <tt id="link-41" class="py-name"><a title="sqlite3.dbapi2" class="py-name" href="#" onclick="return doclink('link-41', 'dbapi2', 'link-38');">dbapi2</a></tt> <tt class="py-keyword">as</tt> <tt class="py-name">sqlite3</tt> </tt>
<a name="L221"></a><tt class="py-lineno"> 221</tt>  <tt class="py-line">            <tt id="link-42" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-42', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-43" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-43', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'SQLite3'</tt><tt class="py-op">)</tt> </tt>
<a name="L222"></a><tt class="py-lineno"> 222</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L223"></a><tt class="py-lineno"> 223</tt>  <tt class="py-line">            <tt id="link-44" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-44', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-45" class="py-name" targets="Module web2py.gluon.debug=web2py.gluon.debug-module.html"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-45', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no sqlite3 or pysqlite2.dbapi2 driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L224"></a><tt class="py-lineno"> 224</tt>  <tt class="py-line"> </tt>
<a name="L225"></a><tt class="py-lineno"> 225</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L226"></a><tt class="py-lineno"> 226</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">contrib</tt><tt class="py-op">.</tt><tt id="link-46" class="py-name" targets="Package web2py.gluon.contrib.pymysql=web2py.gluon.contrib.pymysql-module.html"><a title="web2py.gluon.contrib.pymysql" class="py-name" href="#" onclick="return doclink('link-46', 'pymysql', 'link-46');">pymysql</a></tt> <tt class="py-keyword">as</tt> <tt id="link-47" class="py-name"><a title="web2py.gluon.contrib.pymysql" class="py-name" href="#" onclick="return doclink('link-47', 'pymysql', 'link-46');">pymysql</a></tt> </tt>
<a name="L227"></a><tt class="py-lineno"> 227</tt>  <tt class="py-line">        <tt id="link-48" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-48', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-49" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-49', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'pymysql'</tt><tt class="py-op">)</tt> </tt>
<a name="L228"></a><tt class="py-lineno"> 228</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L229"></a><tt class="py-lineno"> 229</tt>  <tt class="py-line">        <tt id="link-50" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-50', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-51" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-51', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no pymysql driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L230"></a><tt class="py-lineno"> 230</tt>  <tt class="py-line"> </tt>
<a name="L231"></a><tt class="py-lineno"> 231</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L232"></a><tt class="py-lineno"> 232</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt id="link-52" class="py-name" targets="Package psycopg2=psycopg2-module.html"><a title="psycopg2" class="py-name" href="#" onclick="return doclink('link-52', 'psycopg2', 'link-52');">psycopg2</a></tt> </tt>
<a name="L233"></a><tt class="py-lineno"> 233</tt>  <tt class="py-line">        <tt id="link-53" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-53', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-54" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-54', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'PostgreSQL'</tt><tt class="py-op">)</tt> </tt>
<a name="L234"></a><tt class="py-lineno"> 234</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L235"></a><tt class="py-lineno"> 235</tt>  <tt class="py-line">        <tt id="link-55" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-55', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-56" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-56', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no psycopg2 driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L236"></a><tt class="py-lineno"> 236</tt>  <tt class="py-line"> </tt>
<a name="L237"></a><tt class="py-lineno"> 237</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L238"></a><tt class="py-lineno"> 238</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">cx_Oracle</tt> </tt>
<a name="L239"></a><tt class="py-lineno"> 239</tt>  <tt class="py-line">        <tt id="link-57" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-57', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-58" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-58', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'Oracle'</tt><tt class="py-op">)</tt> </tt>
<a name="L240"></a><tt class="py-lineno"> 240</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L241"></a><tt class="py-lineno"> 241</tt>  <tt class="py-line">        <tt id="link-59" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-59', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-60" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-60', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no cx_Oracle driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L242"></a><tt class="py-lineno"> 242</tt>  <tt class="py-line"> </tt>
<a name="L243"></a><tt class="py-lineno"> 243</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L244"></a><tt class="py-lineno"> 244</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">pyodbc</tt> </tt>
<a name="L245"></a><tt class="py-lineno"> 245</tt>  <tt class="py-line">        <tt id="link-61" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-61', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-62" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-62', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'MSSQL/DB2'</tt><tt class="py-op">)</tt> </tt>
<a name="L246"></a><tt class="py-lineno"> 246</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L247"></a><tt class="py-lineno"> 247</tt>  <tt class="py-line">        <tt id="link-63" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-63', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-64" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-64', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no MSSQL/DB2 driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L248"></a><tt class="py-lineno"> 248</tt>  <tt class="py-line"> </tt>
<a name="L249"></a><tt class="py-lineno"> 249</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L250"></a><tt class="py-lineno"> 250</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">kinterbasdb</tt> </tt>
<a name="L251"></a><tt class="py-lineno"> 251</tt>  <tt class="py-line">        <tt id="link-65" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-65', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-66" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-66', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'Interbase'</tt><tt class="py-op">)</tt> </tt>
<a name="L252"></a><tt class="py-lineno"> 252</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L253"></a><tt class="py-lineno"> 253</tt>  <tt class="py-line">        <tt id="link-67" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-67', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-68" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-68', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no kinterbasdb driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L254"></a><tt class="py-lineno"> 254</tt>  <tt class="py-line"> </tt>
<a name="L255"></a><tt class="py-lineno"> 255</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L256"></a><tt class="py-lineno"> 256</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">firebirdsql</tt> </tt>
<a name="L257"></a><tt class="py-lineno"> 257</tt>  <tt class="py-line">        <tt id="link-69" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-69', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-70" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-70', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'Firebird'</tt><tt class="py-op">)</tt> </tt>
<a name="L258"></a><tt class="py-lineno"> 258</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L259"></a><tt class="py-lineno"> 259</tt>  <tt class="py-line">        <tt id="link-71" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-71', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-72" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-72', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no Firebird driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L260"></a><tt class="py-lineno"> 260</tt>  <tt class="py-line"> </tt>
<a name="L261"></a><tt class="py-lineno"> 261</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L262"></a><tt class="py-lineno"> 262</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">informixdb</tt> </tt>
<a name="L263"></a><tt class="py-lineno"> 263</tt>  <tt class="py-line">        <tt id="link-73" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-73', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-74" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-74', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'Informix'</tt><tt class="py-op">)</tt> </tt>
<a name="L264"></a><tt class="py-lineno"> 264</tt>  <tt class="py-line">        <tt id="link-75" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-75', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt class="py-name">warning</tt><tt class="py-op">(</tt><tt class="py-string">'Informix support is experimental'</tt><tt class="py-op">)</tt> </tt>
<a name="L265"></a><tt class="py-lineno"> 265</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L266"></a><tt class="py-lineno"> 266</tt>  <tt class="py-line">        <tt id="link-76" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-76', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-77" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-77', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no informixdb driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L267"></a><tt class="py-lineno"> 267</tt>  <tt class="py-line">         </tt>
<a name="L268"></a><tt class="py-lineno"> 268</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L269"></a><tt class="py-lineno"> 269</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">sapdb</tt> </tt>
<a name="L270"></a><tt class="py-lineno"> 270</tt>  <tt class="py-line">        <tt id="link-78" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-78', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-79" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-79', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'SAPDB'</tt><tt class="py-op">)</tt> </tt>
<a name="L271"></a><tt class="py-lineno"> 271</tt>  <tt class="py-line">        <tt id="link-80" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-80', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt class="py-name">warning</tt><tt class="py-op">(</tt><tt class="py-string">'SAPDB support is experimental'</tt><tt class="py-op">)</tt> </tt>
<a name="L272"></a><tt class="py-lineno"> 272</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L273"></a><tt class="py-lineno"> 273</tt>  <tt class="py-line">        <tt id="link-81" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-81', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-82" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-82', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no sapdb driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L274"></a><tt class="py-lineno"> 274</tt>  <tt class="py-line"> </tt>
<a name="L275"></a><tt class="py-lineno"> 275</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L276"></a><tt class="py-lineno"> 276</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">cubriddb</tt> </tt>
<a name="L277"></a><tt class="py-lineno"> 277</tt>  <tt class="py-line">        <tt id="link-83" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-83', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-84" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-84', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'Cubrid'</tt><tt class="py-op">)</tt> </tt>
<a name="L278"></a><tt class="py-lineno"> 278</tt>  <tt class="py-line">        <tt id="link-85" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-85', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt class="py-name">warning</tt><tt class="py-op">(</tt><tt class="py-string">'Cubrid support is experimental'</tt><tt class="py-op">)</tt> </tt>
<a name="L279"></a><tt class="py-lineno"> 279</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L280"></a><tt class="py-lineno"> 280</tt>  <tt class="py-line">        <tt id="link-86" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-86', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-87" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-87', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no cubriddb driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L281"></a><tt class="py-lineno"> 281</tt>  <tt class="py-line"> </tt>
<a name="L282"></a><tt class="py-lineno"> 282</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L283"></a><tt class="py-lineno"> 283</tt>  <tt class="py-line">        <tt class="py-keyword">from</tt> <tt class="py-name">com</tt><tt class="py-op">.</tt><tt class="py-name">ziclix</tt><tt class="py-op">.</tt><tt class="py-name">python</tt><tt class="py-op">.</tt><tt id="link-88" class="py-name" targets="Module web2py.gluon.sql=web2py.gluon.sql-module.html"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-88', 'sql', 'link-88');">sql</a></tt> <tt class="py-keyword">import</tt> <tt class="py-name">zxJDBC</tt> </tt>
<a name="L284"></a><tt class="py-lineno"> 284</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">java</tt><tt class="py-op">.</tt><tt id="link-89" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-89', 'sql', 'link-88');">sql</a></tt> </tt>
<a name="L285"></a><tt class="py-lineno"> 285</tt>  <tt class="py-line">        <tt class="py-comment"># Try sqlite jdbc driver from http://www.zentus.com/sqlitejdbc/</tt> </tt>
<a name="L286"></a><tt class="py-lineno"> 286</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">from</tt> <tt class="py-name">org</tt><tt class="py-op">.</tt><tt class="py-name">sqlite</tt> <tt class="py-keyword">import</tt> <tt class="py-name">JDBC</tt> <tt class="py-comment"># required by java.sql; ensure we have it</tt> </tt>
<a name="L287"></a><tt class="py-lineno"> 287</tt>  <tt class="py-line">        <tt id="link-90" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-90', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-91" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-91', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'zxJDBC'</tt><tt class="py-op">)</tt> </tt>
<a name="L288"></a><tt class="py-lineno"> 288</tt>  <tt class="py-line">        <tt id="link-92" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-92', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt class="py-name">warning</tt><tt class="py-op">(</tt><tt class="py-string">'zxJDBC support is experimental'</tt><tt class="py-op">)</tt> </tt>
<a name="L289"></a><tt class="py-lineno"> 289</tt>  <tt class="py-line">        <tt id="link-93" class="py-name" targets="Variable web2py.gluon.dal.is_jdbc=web2py.gluon.dal-module.html#is_jdbc"><a title="web2py.gluon.dal.is_jdbc" class="py-name" href="#" onclick="return doclink('link-93', 'is_jdbc', 'link-93');">is_jdbc</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L290"></a><tt class="py-lineno"> 290</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L291"></a><tt class="py-lineno"> 291</tt>  <tt class="py-line">        <tt id="link-94" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-94', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-95" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-95', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no zxJDBC driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L292"></a><tt class="py-lineno"> 292</tt>  <tt class="py-line">        <tt id="link-96" class="py-name"><a title="web2py.gluon.dal.is_jdbc" class="py-name" href="#" onclick="return doclink('link-96', 'is_jdbc', 'link-93');">is_jdbc</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L293"></a><tt class="py-lineno"> 293</tt>  <tt class="py-line"> </tt>
<a name="L294"></a><tt class="py-lineno"> 294</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L295"></a><tt class="py-lineno"> 295</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">ingresdbi</tt> </tt>
<a name="L296"></a><tt class="py-lineno"> 296</tt>  <tt class="py-line">        <tt id="link-97" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-97', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-98" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-98', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'Ingres'</tt><tt class="py-op">)</tt> </tt>
<a name="L297"></a><tt class="py-lineno"> 297</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L298"></a><tt class="py-lineno"> 298</tt>  <tt class="py-line">        <tt id="link-99" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-99', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-100" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-100', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no Ingres driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L299"></a><tt class="py-lineno"> 299</tt>  <tt class="py-line">    <tt class="py-comment"># NOTE could try JDBC.......</tt> </tt>
<a name="L300"></a><tt class="py-lineno"> 300</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L301"></a><tt class="py-lineno"> 301</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L302"></a><tt class="py-lineno"> 302</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">couchdb</tt> </tt>
<a name="L303"></a><tt class="py-lineno"> 303</tt>  <tt class="py-line">        <tt id="link-101" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-101', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-102" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-102', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'CouchDB'</tt><tt class="py-op">)</tt> </tt>
<a name="L304"></a><tt class="py-lineno"> 304</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">ImportError</tt><tt class="py-op">:</tt> </tt>
<a name="L305"></a><tt class="py-lineno"> 305</tt>  <tt class="py-line">        <tt id="link-103" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-103', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-104" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-104', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no couchdb driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L306"></a><tt class="py-lineno"> 306</tt>  <tt class="py-line"> </tt>
<a name="L307"></a><tt class="py-lineno"> 307</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L308"></a><tt class="py-lineno"> 308</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt class="py-name">pymongo</tt> </tt>
<a name="L309"></a><tt class="py-lineno"> 309</tt>  <tt class="py-line">        <tt id="link-105" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-105', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">.</tt><tt id="link-106" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-106', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'mongoDB'</tt><tt class="py-op">)</tt> </tt>
<a name="L310"></a><tt class="py-lineno"> 310</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L311"></a><tt class="py-lineno"> 311</tt>  <tt class="py-line">        <tt id="link-107" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-107', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-108" class="py-name"><a title="web2py.gluon.debug" class="py-name" href="#" onclick="return doclink('link-108', 'debug', 'link-45');">debug</a></tt><tt class="py-op">(</tt><tt class="py-string">'no mongoDB driver'</tt><tt class="py-op">)</tt> </tt>
<a name="L312"></a><tt class="py-lineno"> 312</tt>  <tt class="py-line"> </tt>
<a name="L313"></a><tt class="py-lineno"> 313</tt>  <tt class="py-line"> </tt>
<a name="L314"></a><tt class="py-lineno"> 314</tt>  <tt class="py-line"><tt class="py-keyword">if</tt> <tt class="py-string">'google'</tt> <tt class="py-keyword">in</tt> <tt id="link-109" class="py-name"><a title="web2py.gluon.dal.drivers
web2py.gluon.sql.drivers" class="py-name" href="#" onclick="return doclink('link-109', 'drivers', 'link-34');">drivers</a></tt><tt class="py-op">:</tt> </tt>
<a name="L315"></a><tt class="py-lineno"> 315</tt>  <tt class="py-line"> </tt>
<a name="L316"></a><tt class="py-lineno"> 316</tt>  <tt class="py-line">    <tt id="link-110" class="py-name"><a title="web2py.gluon.dal.is_jdbc" class="py-name" href="#" onclick="return doclink('link-110', 'is_jdbc', 'link-93');">is_jdbc</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L317"></a><tt class="py-lineno"> 317</tt>  <tt class="py-line"> </tt>
<a name="GAEDecimalProperty"></a><div id="GAEDecimalProperty-def"><a name="L318"></a><tt class="py-lineno"> 318</tt> <a class="py-toggle" href="#" id="GAEDecimalProperty-toggle" onclick="return toggle('GAEDecimalProperty');">-</a><tt class="py-line">    <tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEDecimalProperty-class.html">GAEDecimalProperty</a><tt class="py-op">(</tt><tt class="py-base-class">gae</tt><tt class="py-op">.</tt><tt class="py-base-class">Property</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEDecimalProperty-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GAEDecimalProperty-expanded"><a name="L319"></a><tt class="py-lineno"> 319</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L320"></a><tt class="py-lineno"> 320</tt>  <tt class="py-line"><tt class="py-docstring">        GAE decimal implementation</tt> </tt>
<a name="L321"></a><tt class="py-lineno"> 321</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L322"></a><tt class="py-lineno"> 322</tt>  <tt class="py-line">        <tt id="link-111" class="py-name" targets="Variable web2py.gluon.dal.GAEDecimalProperty.data_type=web2py.gluon.dal.GAEDecimalProperty-class.html#data_type"><a title="web2py.gluon.dal.GAEDecimalProperty.data_type" class="py-name" href="#" onclick="return doclink('link-111', 'data_type', 'link-111');">data_type</a></tt> <tt class="py-op">=</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt> </tt>
<a name="L323"></a><tt class="py-lineno"> 323</tt>  <tt class="py-line"> </tt>
<a name="GAEDecimalProperty.__init__"></a><div id="GAEDecimalProperty.__init__-def"><a name="L324"></a><tt class="py-lineno"> 324</tt> <a class="py-toggle" href="#" id="GAEDecimalProperty.__init__-toggle" onclick="return toggle('GAEDecimalProperty.__init__');">-</a><tt class="py-line">        <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEDecimalProperty-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">precision</tt><tt class="py-op">,</tt> <tt class="py-param">scale</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">kwargs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEDecimalProperty.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++++++++++"></div><div id="GAEDecimalProperty.__init__-expanded"><a name="L325"></a><tt class="py-lineno"> 325</tt>  <tt class="py-line">            <tt class="py-name">super</tt><tt class="py-op">(</tt><tt id="link-112" class="py-name" targets="Class web2py.gluon.dal.GAEDecimalProperty=web2py.gluon.dal.GAEDecimalProperty-class.html"><a title="web2py.gluon.dal.GAEDecimalProperty" class="py-name" href="#" onclick="return doclink('link-112', 'GAEDecimalProperty', 'link-112');">GAEDecimalProperty</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-113" class="py-name" targets="Method web2py.gluon.cache.Cache.__init__()=web2py.gluon.cache.Cache-class.html#__init__,Method web2py.gluon.cache.CacheAbstract.__init__()=web2py.gluon.cache.CacheAbstract-class.html#__init__,Method web2py.gluon.cache.CacheInRam.__init__()=web2py.gluon.cache.CacheInRam-class.html#__init__,Method web2py.gluon.cache.CacheOnDisk.__init__()=web2py.gluon.cache.CacheOnDisk-class.html#__init__,Method web2py.gluon.compileapp.LoadFactory.__init__()=web2py.gluon.compileapp.LoadFactory-class.html#__init__,Method web2py.gluon.custom_import._DateTrackerImporter.__init__()=web2py.gluon.custom_import._DateTrackerImporter-class.html#__init__,Method web2py.gluon.custom_import._Web2pyImporter.__init__()=web2py.gluon.custom_import._Web2pyImporter-class.html#__init__,Method web2py.gluon.dal.BaseAdapter.__init__()=web2py.gluon.dal.BaseAdapter-class.html#__init__,Method web2py.gluon.dal.CouchDBAdapter.__init__()=web2py.gluon.dal.CouchDBAdapter-class.html#__init__,Method web2py.gluon.dal.CubridAdapter.__init__()=web2py.gluon.dal.CubridAdapter-class.html#__init__,Method web2py.gluon.dal.DAL.__init__()=web2py.gluon.dal.DAL-class.html#__init__,Method web2py.gluon.dal.DB2Adapter.__init__()=web2py.gluon.dal.DB2Adapter-class.html#__init__,Method web2py.gluon.dal.DatabaseStoredFile.__init__()=web2py.gluon.dal.DatabaseStoredFile-class.html#__init__,Method web2py.gluon.dal.Expression.__init__()=web2py.gluon.dal.Expression-class.html#__init__,Method web2py.gluon.dal.Field.__init__()=web2py.gluon.dal.Field-class.html#__init__,Method web2py.gluon.dal.FireBirdAdapter.__init__()=web2py.gluon.dal.FireBirdAdapter-class.html#__init__,Method web2py.gluon.dal.FireBirdEmbeddedAdapter.__init__()=web2py.gluon.dal.FireBirdEmbeddedAdapter-class.html#__init__,Method web2py.gluon.dal.GAEDecimalProperty.__init__()=web2py.gluon.dal.GAEDecimalProperty-class.html#__init__,Method web2py.gluon.dal.GAEF.__init__()=web2py.gluon.dal.GAEF-class.html#__init__,Method web2py.gluon.dal.GoogleDatastoreAdapter.__init__()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#__init__,Method web2py.gluon.dal.GoogleSQLAdapter.__init__()=web2py.gluon.dal.GoogleSQLAdapter-class.html#__init__,Method web2py.gluon.dal.InformixAdapter.__init__()=web2py.gluon.dal.InformixAdapter-class.html#__init__,Method web2py.gluon.dal.IngresAdapter.__init__()=web2py.gluon.dal.IngresAdapter-class.html#__init__,Method web2py.gluon.dal.JDBCPostgreSQLAdapter.__init__()=web2py.gluon.dal.JDBCPostgreSQLAdapter-class.html#__init__,Method web2py.gluon.dal.JDBCSQLiteAdapter.__init__()=web2py.gluon.dal.JDBCSQLiteAdapter-class.html#__init__,Method web2py.gluon.dal.MSSQLAdapter.__init__()=web2py.gluon.dal.MSSQLAdapter-class.html#__init__,Method web2py.gluon.dal.MongoDBAdapter.__init__()=web2py.gluon.dal.MongoDBAdapter-class.html#__init__,Method web2py.gluon.dal.MySQLAdapter.__init__()=web2py.gluon.dal.MySQLAdapter-class.html#__init__,Method web2py.gluon.dal.OracleAdapter.__init__()=web2py.gluon.dal.OracleAdapter-class.html#__init__,Method web2py.gluon.dal.PostgreSQLAdapter.__init__()=web2py.gluon.dal.PostgreSQLAdapter-class.html#__init__,Method web2py.gluon.dal.Query.__init__()=web2py.gluon.dal.Query-class.html#__init__,Method web2py.gluon.dal.Rows.__init__()=web2py.gluon.dal.Rows-class.html#__init__,Method web2py.gluon.dal.SAPDBAdapter.__init__()=web2py.gluon.dal.SAPDBAdapter-class.html#__init__,Method web2py.gluon.dal.SQLALL.__init__()=web2py.gluon.dal.SQLALL-class.html#__init__,Method web2py.gluon.dal.SQLCustomType.__init__()=web2py.gluon.dal.SQLCustomType-class.html#__init__,Method web2py.gluon.dal.SQLiteAdapter.__init__()=web2py.gluon.dal.SQLiteAdapter-class.html#__init__,Method web2py.gluon.dal.Set.__init__()=web2py.gluon.dal.Set-class.html#__init__,Method web2py.gluon.dal.Table.__init__()=web2py.gluon.dal.Table-class.html#__init__,Method web2py.gluon.dal.TeradataAdapter.__init__()=web2py.gluon.dal.TeradataAdapter-class.html#__init__,Method web2py.gluon.debug.Pipe.__init__()=web2py.gluon.debug.Pipe-class.html#__init__,Method web2py.gluon.globals.Request.__init__()=web2py.gluon.globals.Request-class.html#__init__,Method web2py.gluon.globals.Response.__init__()=web2py.gluon.globals.Response-class.html#__init__,Method web2py.gluon.highlight.Highlighter.__init__()=web2py.gluon.highlight.Highlighter-class.html#__init__,Method web2py.gluon.html.BEAUTIFY.__init__()=web2py.gluon.html.BEAUTIFY-class.html#__init__,Method web2py.gluon.html.DIV.__init__()=web2py.gluon.html.DIV-class.html#__init__,Method web2py.gluon.html.FORM.__init__()=web2py.gluon.html.FORM-class.html#__init__,Method web2py.gluon.html.MARKMIN.__init__()=web2py.gluon.html.MARKMIN-class.html#__init__,Method web2py.gluon.html.MENU.__init__()=web2py.gluon.html.MENU-class.html#__init__,Method web2py.gluon.html.XML.__init__()=web2py.gluon.html.XML-class.html#__init__,Method web2py.gluon.html.web2pyHTMLParser.__init__()=web2py.gluon.html.web2pyHTMLParser-class.html#__init__,Method web2py.gluon.http.HTTP.__init__()=web2py.gluon.http.HTTP-class.html#__init__,Method web2py.gluon.languages.lazyT.__init__()=web2py.gluon.languages.lazyT-class.html#__init__,Method web2py.gluon.languages.translator.__init__()=web2py.gluon.languages.translator-class.html#__init__,Method web2py.gluon.main.HttpServer.__init__()=web2py.gluon.main.HttpServer-class.html#__init__,Method web2py.gluon.newcron.Token.__init__()=web2py.gluon.newcron.Token-class.html#__init__,Method web2py.gluon.newcron.cronlauncher.__init__()=web2py.gluon.newcron.cronlauncher-class.html#__init__,Method web2py.gluon.newcron.extcron.__init__()=web2py.gluon.newcron.extcron-class.html#__init__,Method web2py.gluon.newcron.hardcron.__init__()=web2py.gluon.newcron.hardcron-class.html#__init__,Method web2py.gluon.newcron.softcron.__init__()=web2py.gluon.newcron.softcron-class.html#__init__,Method web2py.gluon.restricted.RestrictedError.__init__()=web2py.gluon.restricted.RestrictedError-class.html#__init__,Method web2py.gluon.restricted.TicketStorage.__init__()=web2py.gluon.restricted.TicketStorage-class.html#__init__,Method web2py.gluon.rewrite.MapUrlIn.__init__()=web2py.gluon.rewrite.MapUrlIn-class.html#__init__,Method web2py.gluon.rewrite.MapUrlOut.__init__()=web2py.gluon.rewrite.MapUrlOut-class.html#__init__,Method web2py.gluon.rocket.ChunkedReader.__init__()=web2py.gluon.rocket.ChunkedReader-class.html#__init__,Method web2py.gluon.rocket.Connection.__init__()=web2py.gluon.rocket.Connection-class.html#__init__,Method web2py.gluon.rocket.FileWrapper.__init__()=web2py.gluon.rocket.FileWrapper-class.html#__init__,Method web2py.gluon.rocket.Headers.__init__()=web2py.gluon.rocket.Headers-class.html#__init__,Method web2py.gluon.rocket.Listener.__init__()=web2py.gluon.rocket.Listener-class.html#__init__,Method web2py.gluon.rocket.Monitor.__init__()=web2py.gluon.rocket.Monitor-class.html#__init__,Method web2py.gluon.rocket.Rocket.__init__()=web2py.gluon.rocket.Rocket-class.html#__init__,Method web2py.gluon.rocket.ThreadPool.__init__()=web2py.gluon.rocket.ThreadPool-class.html#__init__,Method web2py.gluon.rocket.WSGIWorker.__init__()=web2py.gluon.rocket.WSGIWorker-class.html#__init__,Method web2py.gluon.rocket.Worker.__init__()=web2py.gluon.rocket.Worker-class.html#__init__,Method web2py.gluon.sanitizer.XssCleaner.__init__()=web2py.gluon.sanitizer.XssCleaner-class.html#__init__,Method web2py.gluon.sqlhtml.AutocompleteWidget.__init__()=web2py.gluon.sqlhtml.AutocompleteWidget-class.html#__init__,Method web2py.gluon.sqlhtml.SQLFORM.__init__()=web2py.gluon.sqlhtml.SQLFORM-class.html#__init__,Method web2py.gluon.sqlhtml.SQLTABLE.__init__()=web2py.gluon.sqlhtml.SQLTABLE-class.html#__init__,Method web2py.gluon.storage.Messages.__init__()=web2py.gluon.storage.Messages-class.html#__init__,Method web2py.gluon.template.BlockNode.__init__()=web2py.gluon.template.BlockNode-class.html#__init__,Method web2py.gluon.template.Content.__init__()=web2py.gluon.template.Content-class.html#__init__,Method web2py.gluon.template.Node.__init__()=web2py.gluon.template.Node-class.html#__init__,Method web2py.gluon.template.SuperNode.__init__()=web2py.gluon.template.SuperNode-class.html#__init__,Method web2py.gluon.template.TemplateParser.__init__()=web2py.gluon.template.TemplateParser-class.html#__init__,Method web2py.gluon.tools.Auth.__init__()=web2py.gluon.tools.Auth-class.html#__init__,Method web2py.gluon.tools.Crud.__init__()=web2py.gluon.tools.Crud-class.html#__init__,Method web2py.gluon.tools.Mail.Attachment.__init__()=web2py.gluon.tools.Mail.Attachment-class.html#__init__,Method web2py.gluon.tools.Mail.__init__()=web2py.gluon.tools.Mail-class.html#__init__,Method web2py.gluon.tools.PluginManager.__init__()=web2py.gluon.tools.PluginManager-class.html#__init__,Method web2py.gluon.tools.Recaptcha.__init__()=web2py.gluon.tools.Recaptcha-class.html#__init__,Method web2py.gluon.tools.Service.JsonRpcException.__init__()=web2py.gluon.tools.Service.JsonRpcException-class.html#__init__,Method web2py.gluon.tools.Service.__init__()=web2py.gluon.tools.Service-class.html#__init__,Method web2py.gluon.validators.CLEANUP.__init__()=web2py.gluon.validators.CLEANUP-class.html#__init__,Method web2py.gluon.validators.CRYPT.__init__()=web2py.gluon.validators.CRYPT-class.html#__init__,Method web2py.gluon.validators.IS_ALPHANUMERIC.__init__()=web2py.gluon.validators.IS_ALPHANUMERIC-class.html#__init__,Method web2py.gluon.validators.IS_DATE.__init__()=web2py.gluon.validators.IS_DATE-class.html#__init__,Method web2py.gluon.validators.IS_DATETIME.__init__()=web2py.gluon.validators.IS_DATETIME-class.html#__init__,Method web2py.gluon.validators.IS_DATETIME_IN_RANGE.__init__()=web2py.gluon.validators.IS_DATETIME_IN_RANGE-class.html#__init__,Method web2py.gluon.validators.IS_DATE_IN_RANGE.__init__()=web2py.gluon.validators.IS_DATE_IN_RANGE-class.html#__init__,Method web2py.gluon.validators.IS_DECIMAL_IN_RANGE.__init__()=web2py.gluon.validators.IS_DECIMAL_IN_RANGE-class.html#__init__,Method web2py.gluon.validators.IS_EMAIL.__init__()=web2py.gluon.validators.IS_EMAIL-class.html#__init__,Method web2py.gluon.validators.IS_EMPTY_OR.__init__()=web2py.gluon.validators.IS_EMPTY_OR-class.html#__init__,Method web2py.gluon.validators.IS_EQUAL_TO.__init__()=web2py.gluon.validators.IS_EQUAL_TO-class.html#__init__,Method web2py.gluon.validators.IS_EXPR.__init__()=web2py.gluon.validators.IS_EXPR-class.html#__init__,Method web2py.gluon.validators.IS_FLOAT_IN_RANGE.__init__()=web2py.gluon.validators.IS_FLOAT_IN_RANGE-class.html#__init__,Method web2py.gluon.validators.IS_GENERIC_URL.__init__()=web2py.gluon.validators.IS_GENERIC_URL-class.html#__init__,Method web2py.gluon.validators.IS_HTTP_URL.__init__()=web2py.gluon.validators.IS_HTTP_URL-class.html#__init__,Method web2py.gluon.validators.IS_IMAGE.__init__()=web2py.gluon.validators.IS_IMAGE-class.html#__init__,Method web2py.gluon.validators.IS_INT_IN_RANGE.__init__()=web2py.gluon.validators.IS_INT_IN_RANGE-class.html#__init__,Method web2py.gluon.validators.IS_IN_DB.__init__()=web2py.gluon.validators.IS_IN_DB-class.html#__init__,Method web2py.gluon.validators.IS_IN_SET.__init__()=web2py.gluon.validators.IS_IN_SET-class.html#__init__,Method web2py.gluon.validators.IS_IN_SUBSET.__init__()=web2py.gluon.validators.IS_IN_SUBSET-class.html#__init__,Method web2py.gluon.validators.IS_IPV4.__init__()=web2py.gluon.validators.IS_IPV4-class.html#__init__,Method web2py.gluon.validators.IS_LENGTH.__init__()=web2py.gluon.validators.IS_LENGTH-class.html#__init__,Method web2py.gluon.validators.IS_LIST_OF.__init__()=web2py.gluon.validators.IS_LIST_OF-class.html#__init__,Method web2py.gluon.validators.IS_MATCH.__init__()=web2py.gluon.validators.IS_MATCH-class.html#__init__,Method web2py.gluon.validators.IS_NOT_EMPTY.__init__()=web2py.gluon.validators.IS_NOT_EMPTY-class.html#__init__,Method web2py.gluon.validators.IS_NOT_IN_DB.__init__()=web2py.gluon.validators.IS_NOT_IN_DB-class.html#__init__,Method web2py.gluon.validators.IS_SLUG.__init__()=web2py.gluon.validators.IS_SLUG-class.html#__init__,Method web2py.gluon.validators.IS_STRONG.__init__()=web2py.gluon.validators.IS_STRONG-class.html#__init__,Method web2py.gluon.validators.IS_TIME.__init__()=web2py.gluon.validators.IS_TIME-class.html#__init__,Method web2py.gluon.validators.IS_UPLOAD_FILENAME.__init__()=web2py.gluon.validators.IS_UPLOAD_FILENAME-class.html#__init__,Method web2py.gluon.validators.IS_URL.__init__()=web2py.gluon.validators.IS_URL-class.html#__init__,Method web2py.gluon.widget.IO.__init__()=web2py.gluon.widget.IO-class.html#__init__,Method web2py.gluon.widget.web2pyDialog.__init__()=web2py.gluon.widget.web2pyDialog-class.html#__init__,Method web2py.gluon.winservice.Service.__init__()=web2py.gluon.winservice.Service-class.html#__init__"><a title="web2py.gluon.cache.Cache.__init__
web2py.gluon.cache.CacheAbstract.__init__
web2py.gluon.cache.CacheInRam.__init__
web2py.gluon.cache.CacheOnDisk.__init__
web2py.gluon.compileapp.LoadFactory.__init__
web2py.gluon.custom_import._DateTrackerImporter.__init__
web2py.gluon.custom_import._Web2pyImporter.__init__
web2py.gluon.dal.BaseAdapter.__init__
web2py.gluon.dal.CouchDBAdapter.__init__
web2py.gluon.dal.CubridAdapter.__init__
web2py.gluon.dal.DAL.__init__
web2py.gluon.dal.DB2Adapter.__init__
web2py.gluon.dal.DatabaseStoredFile.__init__
web2py.gluon.dal.Expression.__init__
web2py.gluon.dal.Field.__init__
web2py.gluon.dal.FireBirdAdapter.__init__
web2py.gluon.dal.FireBirdEmbeddedAdapter.__init__
web2py.gluon.dal.GAEDecimalProperty.__init__
web2py.gluon.dal.GAEF.__init__
web2py.gluon.dal.GoogleDatastoreAdapter.__init__
web2py.gluon.dal.GoogleSQLAdapter.__init__
web2py.gluon.dal.InformixAdapter.__init__
web2py.gluon.dal.IngresAdapter.__init__
web2py.gluon.dal.JDBCPostgreSQLAdapter.__init__
web2py.gluon.dal.JDBCSQLiteAdapter.__init__
web2py.gluon.dal.MSSQLAdapter.__init__
web2py.gluon.dal.MongoDBAdapter.__init__
web2py.gluon.dal.MySQLAdapter.__init__
web2py.gluon.dal.OracleAdapter.__init__
web2py.gluon.dal.PostgreSQLAdapter.__init__
web2py.gluon.dal.Query.__init__
web2py.gluon.dal.Rows.__init__
web2py.gluon.dal.SAPDBAdapter.__init__
web2py.gluon.dal.SQLALL.__init__
web2py.gluon.dal.SQLCustomType.__init__
web2py.gluon.dal.SQLiteAdapter.__init__
web2py.gluon.dal.Set.__init__
web2py.gluon.dal.Table.__init__
web2py.gluon.dal.TeradataAdapter.__init__
web2py.gluon.debug.Pipe.__init__
web2py.gluon.globals.Request.__init__
web2py.gluon.globals.Response.__init__
web2py.gluon.highlight.Highlighter.__init__
web2py.gluon.html.BEAUTIFY.__init__
web2py.gluon.html.DIV.__init__
web2py.gluon.html.FORM.__init__
web2py.gluon.html.MARKMIN.__init__
web2py.gluon.html.MENU.__init__
web2py.gluon.html.XML.__init__
web2py.gluon.html.web2pyHTMLParser.__init__
web2py.gluon.http.HTTP.__init__
web2py.gluon.languages.lazyT.__init__
web2py.gluon.languages.translator.__init__
web2py.gluon.main.HttpServer.__init__
web2py.gluon.newcron.Token.__init__
web2py.gluon.newcron.cronlauncher.__init__
web2py.gluon.newcron.extcron.__init__
web2py.gluon.newcron.hardcron.__init__
web2py.gluon.newcron.softcron.__init__
web2py.gluon.restricted.RestrictedError.__init__
web2py.gluon.restricted.TicketStorage.__init__
web2py.gluon.rewrite.MapUrlIn.__init__
web2py.gluon.rewrite.MapUrlOut.__init__
web2py.gluon.rocket.ChunkedReader.__init__
web2py.gluon.rocket.Connection.__init__
web2py.gluon.rocket.FileWrapper.__init__
web2py.gluon.rocket.Headers.__init__
web2py.gluon.rocket.Listener.__init__
web2py.gluon.rocket.Monitor.__init__
web2py.gluon.rocket.Rocket.__init__
web2py.gluon.rocket.ThreadPool.__init__
web2py.gluon.rocket.WSGIWorker.__init__
web2py.gluon.rocket.Worker.__init__
web2py.gluon.sanitizer.XssCleaner.__init__
web2py.gluon.sqlhtml.AutocompleteWidget.__init__
web2py.gluon.sqlhtml.SQLFORM.__init__
web2py.gluon.sqlhtml.SQLTABLE.__init__
web2py.gluon.storage.Messages.__init__
web2py.gluon.template.BlockNode.__init__
web2py.gluon.template.Content.__init__
web2py.gluon.template.Node.__init__
web2py.gluon.template.SuperNode.__init__
web2py.gluon.template.TemplateParser.__init__
web2py.gluon.tools.Auth.__init__
web2py.gluon.tools.Crud.__init__
web2py.gluon.tools.Mail.Attachment.__init__
web2py.gluon.tools.Mail.__init__
web2py.gluon.tools.PluginManager.__init__
web2py.gluon.tools.Recaptcha.__init__
web2py.gluon.tools.Service.JsonRpcException.__init__
web2py.gluon.tools.Service.__init__
web2py.gluon.validators.CLEANUP.__init__
web2py.gluon.validators.CRYPT.__init__
web2py.gluon.validators.IS_ALPHANUMERIC.__init__
web2py.gluon.validators.IS_DATE.__init__
web2py.gluon.validators.IS_DATETIME.__init__
web2py.gluon.validators.IS_DATETIME_IN_RANGE.__init__
web2py.gluon.validators.IS_DATE_IN_RANGE.__init__
web2py.gluon.validators.IS_DECIMAL_IN_RANGE.__init__
web2py.gluon.validators.IS_EMAIL.__init__
web2py.gluon.validators.IS_EMPTY_OR.__init__
web2py.gluon.validators.IS_EQUAL_TO.__init__
web2py.gluon.validators.IS_EXPR.__init__
web2py.gluon.validators.IS_FLOAT_IN_RANGE.__init__
web2py.gluon.validators.IS_GENERIC_URL.__init__
web2py.gluon.validators.IS_HTTP_URL.__init__
web2py.gluon.validators.IS_IMAGE.__init__
web2py.gluon.validators.IS_INT_IN_RANGE.__init__
web2py.gluon.validators.IS_IN_DB.__init__
web2py.gluon.validators.IS_IN_SET.__init__
web2py.gluon.validators.IS_IN_SUBSET.__init__
web2py.gluon.validators.IS_IPV4.__init__
web2py.gluon.validators.IS_LENGTH.__init__
web2py.gluon.validators.IS_LIST_OF.__init__
web2py.gluon.validators.IS_MATCH.__init__
web2py.gluon.validators.IS_NOT_EMPTY.__init__
web2py.gluon.validators.IS_NOT_IN_DB.__init__
web2py.gluon.validators.IS_SLUG.__init__
web2py.gluon.validators.IS_STRONG.__init__
web2py.gluon.validators.IS_TIME.__init__
web2py.gluon.validators.IS_UPLOAD_FILENAME.__init__
web2py.gluon.validators.IS_URL.__init__
web2py.gluon.widget.IO.__init__
web2py.gluon.widget.web2pyDialog.__init__
web2py.gluon.winservice.Service.__init__" class="py-name" href="#" onclick="return doclink('link-113', '__init__', 'link-113');">__init__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-name">kwargs</tt><tt class="py-op">)</tt> </tt>
<a name="L326"></a><tt class="py-lineno"> 326</tt>  <tt class="py-line">            <tt class="py-name">d</tt> <tt class="py-op">=</tt> <tt class="py-string">'1.'</tt> </tt>
<a name="L327"></a><tt class="py-lineno"> 327</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt id="link-114" class="py-name" targets="Variable sqlite3.dbapi2.x=sqlite3.dbapi2-module.html#x"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-114', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-name">scale</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L328"></a><tt class="py-lineno"> 328</tt>  <tt class="py-line">                <tt class="py-name">d</tt> <tt class="py-op">+=</tt> <tt class="py-string">'0'</tt> </tt>
<a name="L329"></a><tt class="py-lineno"> 329</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">round</tt> <tt class="py-op">=</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">(</tt><tt class="py-name">d</tt><tt class="py-op">)</tt> </tt>
</div><a name="L330"></a><tt class="py-lineno"> 330</tt>  <tt class="py-line"> </tt>
<a name="GAEDecimalProperty.get_value_for_datastore"></a><div id="GAEDecimalProperty.get_value_for_datastore-def"><a name="L331"></a><tt class="py-lineno"> 331</tt> <a class="py-toggle" href="#" id="GAEDecimalProperty.get_value_for_datastore-toggle" onclick="return toggle('GAEDecimalProperty.get_value_for_datastore');">-</a><tt class="py-line">        <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEDecimalProperty-class.html#get_value_for_datastore">get_value_for_datastore</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">model_instance</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEDecimalProperty.get_value_for_datastore-collapsed" style="display:none;" pad="++++" indent="++++++++++++++++"></div><div id="GAEDecimalProperty.get_value_for_datastore-expanded"><a name="L332"></a><tt class="py-lineno"> 332</tt>  <tt class="py-line">            <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">super</tt><tt class="py-op">(</tt><tt id="link-115" class="py-name"><a title="web2py.gluon.dal.GAEDecimalProperty" class="py-name" href="#" onclick="return doclink('link-115', 'GAEDecimalProperty', 'link-112');">GAEDecimalProperty</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-116" class="py-name" targets="Method web2py.gluon.dal.GAEDecimalProperty.get_value_for_datastore()=web2py.gluon.dal.GAEDecimalProperty-class.html#get_value_for_datastore"><a title="web2py.gluon.dal.GAEDecimalProperty.get_value_for_datastore" class="py-name" href="#" onclick="return doclink('link-116', 'get_value_for_datastore', 'link-116');">get_value_for_datastore</a></tt><tt class="py-op">(</tt><tt class="py-name">model_instance</tt><tt class="py-op">)</tt> </tt>
<a name="L333"></a><tt class="py-lineno"> 333</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">value</tt><tt class="py-op">:</tt> </tt>
<a name="L334"></a><tt class="py-lineno"> 334</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L335"></a><tt class="py-lineno"> 335</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L336"></a><tt class="py-lineno"> 336</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L337"></a><tt class="py-lineno"> 337</tt>  <tt class="py-line"> </tt>
<a name="GAEDecimalProperty.make_value_from_datastore"></a><div id="GAEDecimalProperty.make_value_from_datastore-def"><a name="L338"></a><tt class="py-lineno"> 338</tt> <a class="py-toggle" href="#" id="GAEDecimalProperty.make_value_from_datastore-toggle" onclick="return toggle('GAEDecimalProperty.make_value_from_datastore');">-</a><tt class="py-line">        <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEDecimalProperty-class.html#make_value_from_datastore">make_value_from_datastore</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEDecimalProperty.make_value_from_datastore-collapsed" style="display:none;" pad="++++" indent="++++++++++++++++"></div><div id="GAEDecimalProperty.make_value_from_datastore-expanded"><a name="L339"></a><tt class="py-lineno"> 339</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">value</tt><tt class="py-op">:</tt> </tt>
<a name="L340"></a><tt class="py-lineno"> 340</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">quantize</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">round</tt><tt class="py-op">)</tt> </tt>
<a name="L341"></a><tt class="py-lineno"> 341</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L342"></a><tt class="py-lineno"> 342</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L343"></a><tt class="py-lineno"> 343</tt>  <tt class="py-line"> </tt>
<a name="GAEDecimalProperty.validate"></a><div id="GAEDecimalProperty.validate-def"><a name="L344"></a><tt class="py-lineno"> 344</tt> <a class="py-toggle" href="#" id="GAEDecimalProperty.validate-toggle" onclick="return toggle('GAEDecimalProperty.validate');">-</a><tt class="py-line">        <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEDecimalProperty-class.html#validate">validate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEDecimalProperty.validate-collapsed" style="display:none;" pad="++++" indent="++++++++++++++++"></div><div id="GAEDecimalProperty.validate-expanded"><a name="L345"></a><tt class="py-lineno"> 345</tt>  <tt class="py-line">            <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">super</tt><tt class="py-op">(</tt><tt id="link-117" class="py-name"><a title="web2py.gluon.dal.GAEDecimalProperty" class="py-name" href="#" onclick="return doclink('link-117', 'GAEDecimalProperty', 'link-112');">GAEDecimalProperty</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-118" class="py-name" targets="Method web2py.gluon.dal.Field.validate()=web2py.gluon.dal.Field-class.html#validate,Method web2py.gluon.dal.GAEDecimalProperty.validate()=web2py.gluon.dal.GAEDecimalProperty-class.html#validate,Method web2py.gluon.html.FORM.validate()=web2py.gluon.html.FORM-class.html#validate"><a title="web2py.gluon.dal.Field.validate
web2py.gluon.dal.GAEDecimalProperty.validate
web2py.gluon.html.FORM.validate" class="py-name" href="#" onclick="return doclink('link-118', 'validate', 'link-118');">validate</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L346"></a><tt class="py-lineno"> 346</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">value</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L347"></a><tt class="py-lineno"> 347</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">value</tt> </tt>
<a name="L348"></a><tt class="py-lineno"> 348</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">basestring</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L349"></a><tt class="py-lineno"> 349</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L350"></a><tt class="py-lineno"> 350</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">BadValueError</tt><tt class="py-op">(</tt><tt class="py-string">"Property %s must be a Decimal or string."</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-119" class="py-name" targets="Variable web2py.gluon.import_all.name=web2py.gluon.import_all-module.html#name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-119', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L351"></a><tt class="py-lineno"> 351</tt>  <tt class="py-line"> </tt>
<a name="L352"></a><tt class="py-lineno"> 352</tt>  <tt class="py-line"><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L353"></a><tt class="py-lineno"> 353</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># class that handles connection pooling (all adapters derived form this one)</tt> </tt>
<a name="L354"></a><tt class="py-lineno"> 354</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L355"></a><tt class="py-lineno"> 355</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="ConnectionPool"></a><div id="ConnectionPool-def"><a name="L356"></a><tt class="py-lineno"> 356</tt> <a class="py-toggle" href="#" id="ConnectionPool-toggle" onclick="return toggle('ConnectionPool');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.ConnectionPool-class.html">ConnectionPool</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="ConnectionPool-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="ConnectionPool-expanded"><a name="L357"></a><tt class="py-lineno"> 357</tt>  <tt class="py-line"> </tt>
<a name="L358"></a><tt class="py-lineno"> 358</tt>  <tt class="py-line">    <tt id="link-120" class="py-name" targets="Variable web2py.gluon.dal.ConnectionPool.pools=web2py.gluon.dal.ConnectionPool-class.html#pools"><a title="web2py.gluon.dal.ConnectionPool.pools" class="py-name" href="#" onclick="return doclink('link-120', 'pools', 'link-120');">pools</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L359"></a><tt class="py-lineno"> 359</tt>  <tt class="py-line"> </tt>
<a name="L360"></a><tt class="py-lineno"> 360</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="ConnectionPool.set_folder"></a><div id="ConnectionPool.set_folder-def"><a name="L361"></a><tt class="py-lineno"> 361</tt> <a class="py-toggle" href="#" id="ConnectionPool.set_folder-toggle" onclick="return toggle('ConnectionPool.set_folder');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.ConnectionPool-class.html#set_folder">set_folder</a><tt class="py-op">(</tt><tt class="py-param">folder</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="ConnectionPool.set_folder-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="ConnectionPool.set_folder-expanded"><a name="L362"></a><tt class="py-lineno"> 362</tt>  <tt class="py-line">        <tt id="link-121" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-121', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
</div><a name="L363"></a><tt class="py-lineno"> 363</tt>  <tt class="py-line"> </tt>
<a name="L364"></a><tt class="py-lineno"> 364</tt>  <tt class="py-line">    <tt class="py-comment"># ## this allows gluon to commit/rollback all dbs in this thread</tt> </tt>
<a name="L365"></a><tt class="py-lineno"> 365</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L366"></a><tt class="py-lineno"> 366</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="ConnectionPool.close_all_instances"></a><div id="ConnectionPool.close_all_instances-def"><a name="L367"></a><tt class="py-lineno"> 367</tt> <a class="py-toggle" href="#" id="ConnectionPool.close_all_instances-toggle" onclick="return toggle('ConnectionPool.close_all_instances');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.ConnectionPool-class.html#close_all_instances">close_all_instances</a><tt class="py-op">(</tt><tt class="py-param">action</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="ConnectionPool.close_all_instances-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="ConnectionPool.close_all_instances-expanded"><a name="L368"></a><tt class="py-lineno"> 368</tt>  <tt class="py-line">        <tt class="py-docstring">""" to close cleanly databases in a multithreaded environment """</tt> </tt>
<a name="L369"></a><tt class="py-lineno"> 369</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt id="link-122" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-122', 'thread', 'link-27');">thread</a></tt><tt class="py-op">,</tt><tt class="py-string">'instances'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L370"></a><tt class="py-lineno"> 370</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> </tt>
<a name="L371"></a><tt class="py-lineno"> 371</tt>  <tt class="py-line">        <tt class="py-keyword">while</tt> <tt id="link-123" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-123', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt id="link-124" class="py-name" targets="Variable web2py.gluon.tools.PluginManager.instances=web2py.gluon.tools.PluginManager-class.html#instances"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-124', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L372"></a><tt class="py-lineno"> 372</tt>  <tt class="py-line">            <tt class="py-name">instance</tt> <tt class="py-op">=</tt> <tt id="link-125" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-125', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt id="link-126" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-126', 'instances', 'link-124');">instances</a></tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L373"></a><tt class="py-lineno"> 373</tt>  <tt class="py-line">            <tt class="py-name">getattr</tt><tt class="py-op">(</tt><tt class="py-name">instance</tt><tt class="py-op">,</tt><tt class="py-name">action</tt><tt class="py-op">)</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L374"></a><tt class="py-lineno"> 374</tt>  <tt class="py-line">            <tt class="py-comment"># ## if you want pools, recycle this connection</tt> </tt>
<a name="L375"></a><tt class="py-lineno"> 375</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">really</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L376"></a><tt class="py-lineno"> 376</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">instance</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt><tt class="py-op">:</tt> </tt>
<a name="L377"></a><tt class="py-lineno"> 377</tt>  <tt class="py-line">                <tt id="link-127" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-127', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-128" class="py-name" targets="Method web2py.gluon.newcron.Token.acquire()=web2py.gluon.newcron.Token-class.html#acquire"><a title="web2py.gluon.newcron.Token.acquire" class="py-name" href="#" onclick="return doclink('link-128', 'acquire', 'link-128');">acquire</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L378"></a><tt class="py-lineno"> 378</tt>  <tt class="py-line">                <tt class="py-name">pool</tt> <tt class="py-op">=</tt> <tt id="link-129" class="py-name" targets="Class web2py.gluon.dal.ConnectionPool=web2py.gluon.dal.ConnectionPool-class.html"><a title="web2py.gluon.dal.ConnectionPool" class="py-name" href="#" onclick="return doclink('link-129', 'ConnectionPool', 'link-129');">ConnectionPool</a></tt><tt class="py-op">.</tt><tt id="link-130" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pools" class="py-name" href="#" onclick="return doclink('link-130', 'pools', 'link-120');">pools</a></tt><tt class="py-op">[</tt><tt class="py-name">instance</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">]</tt> </tt>
<a name="L379"></a><tt class="py-lineno"> 379</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt id="link-131" class="py-name" targets="Method web2py.gluon.dal.Expression.len()=web2py.gluon.dal.Expression-class.html#len"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-131', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">pool</tt><tt class="py-op">)</tt> <tt class="py-op">&lt;</tt> <tt class="py-name">instance</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt><tt class="py-op">:</tt> </tt>
<a name="L380"></a><tt class="py-lineno"> 380</tt>  <tt class="py-line">                    <tt class="py-name">pool</tt><tt class="py-op">.</tt><tt id="link-132" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-132', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">instance</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">)</tt> </tt>
<a name="L381"></a><tt class="py-lineno"> 381</tt>  <tt class="py-line">                    <tt class="py-name">really</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L382"></a><tt class="py-lineno"> 382</tt>  <tt class="py-line">                <tt id="link-133" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-133', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-134" class="py-name" targets="Method web2py.gluon.newcron.Token.release()=web2py.gluon.newcron.Token-class.html#release"><a title="web2py.gluon.newcron.Token.release" class="py-name" href="#" onclick="return doclink('link-134', 'release', 'link-134');">release</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L383"></a><tt class="py-lineno"> 383</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">really</tt><tt class="py-op">:</tt> </tt>
<a name="L384"></a><tt class="py-lineno"> 384</tt>  <tt class="py-line">                <tt class="py-name">getattr</tt><tt class="py-op">(</tt><tt class="py-name">instance</tt><tt class="py-op">,</tt><tt class="py-string">'close'</tt><tt class="py-op">)</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L385"></a><tt class="py-lineno"> 385</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> </tt>
</div><a name="L386"></a><tt class="py-lineno"> 386</tt>  <tt class="py-line"> </tt>
<a name="ConnectionPool.find_or_make_work_folder"></a><div id="ConnectionPool.find_or_make_work_folder-def"><a name="L387"></a><tt class="py-lineno"> 387</tt> <a class="py-toggle" href="#" id="ConnectionPool.find_or_make_work_folder-toggle" onclick="return toggle('ConnectionPool.find_or_make_work_folder');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.ConnectionPool-class.html#find_or_make_work_folder">find_or_make_work_folder</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="ConnectionPool.find_or_make_work_folder-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="ConnectionPool.find_or_make_work_folder-expanded"><a name="L388"></a><tt class="py-lineno"> 388</tt>  <tt class="py-line">        <tt class="py-docstring">""" this actually does not make the folder. it has to be there """</tt> </tt>
<a name="L389"></a><tt class="py-lineno"> 389</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt id="link-135" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-135', 'thread', 'link-27');">thread</a></tt><tt class="py-op">,</tt><tt class="py-string">'folder'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L390"></a><tt class="py-lineno"> 390</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt id="link-136" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-136', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> </tt>
<a name="L391"></a><tt class="py-lineno"> 391</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L392"></a><tt class="py-lineno"> 392</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt id="link-137" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-137', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L393"></a><tt class="py-lineno"> 393</tt>  <tt class="py-line"> </tt>
<a name="L394"></a><tt class="py-lineno"> 394</tt>  <tt class="py-line">        <tt class="py-comment"># Creating the folder if it does not exist</tt> </tt>
<a name="L395"></a><tt class="py-lineno"> 395</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">False</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-138" class="py-name" targets="Static Method web2py.gluon.dal.DatabaseStoredFile.exists()=web2py.gluon.dal.DatabaseStoredFile-class.html#exists"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-138', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L396"></a><tt class="py-lineno"> 396</tt>  <tt class="py-line">            <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">mkdir</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">)</tt> </tt>
</div><a name="L397"></a><tt class="py-lineno"> 397</tt>  <tt class="py-line"> </tt>
<a name="ConnectionPool.pool_connection"></a><div id="ConnectionPool.pool_connection-def"><a name="L398"></a><tt class="py-lineno"> 398</tt> <a class="py-toggle" href="#" id="ConnectionPool.pool_connection-toggle" onclick="return toggle('ConnectionPool.pool_connection');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.ConnectionPool-class.html#pool_connection">pool_connection</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">f</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="ConnectionPool.pool_connection-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="ConnectionPool.pool_connection-expanded"><a name="L399"></a><tt class="py-lineno"> 399</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt><tt class="py-op">:</tt> </tt>
<a name="L400"></a><tt class="py-lineno"> 400</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt> <tt class="py-op">=</tt> <tt class="py-name">f</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L401"></a><tt class="py-lineno"> 401</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L402"></a><tt class="py-lineno"> 402</tt>  <tt class="py-line">            <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> </tt>
<a name="L403"></a><tt class="py-lineno"> 403</tt>  <tt class="py-line">            <tt id="link-139" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-139', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-140" class="py-name"><a title="web2py.gluon.newcron.Token.acquire" class="py-name" href="#" onclick="return doclink('link-140', 'acquire', 'link-128');">acquire</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L404"></a><tt class="py-lineno"> 404</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">uri</tt> <tt class="py-keyword">in</tt> <tt id="link-141" class="py-name"><a title="web2py.gluon.dal.ConnectionPool" class="py-name" href="#" onclick="return doclink('link-141', 'ConnectionPool', 'link-129');">ConnectionPool</a></tt><tt class="py-op">.</tt><tt id="link-142" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pools" class="py-name" href="#" onclick="return doclink('link-142', 'pools', 'link-120');">pools</a></tt><tt class="py-op">:</tt> </tt>
<a name="L405"></a><tt class="py-lineno"> 405</tt>  <tt class="py-line">                <tt id="link-143" class="py-name"><a title="web2py.gluon.dal.ConnectionPool" class="py-name" href="#" onclick="return doclink('link-143', 'ConnectionPool', 'link-129');">ConnectionPool</a></tt><tt class="py-op">.</tt><tt id="link-144" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pools" class="py-name" href="#" onclick="return doclink('link-144', 'pools', 'link-120');">pools</a></tt><tt class="py-op">[</tt><tt class="py-name">uri</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L406"></a><tt class="py-lineno"> 406</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-145" class="py-name"><a title="web2py.gluon.dal.ConnectionPool" class="py-name" href="#" onclick="return doclink('link-145', 'ConnectionPool', 'link-129');">ConnectionPool</a></tt><tt class="py-op">.</tt><tt id="link-146" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pools" class="py-name" href="#" onclick="return doclink('link-146', 'pools', 'link-120');">pools</a></tt><tt class="py-op">[</tt><tt class="py-name">uri</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L407"></a><tt class="py-lineno"> 407</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt> <tt class="py-op">=</tt> <tt id="link-147" class="py-name"><a title="web2py.gluon.dal.ConnectionPool" class="py-name" href="#" onclick="return doclink('link-147', 'ConnectionPool', 'link-129');">ConnectionPool</a></tt><tt class="py-op">.</tt><tt id="link-148" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pools" class="py-name" href="#" onclick="return doclink('link-148', 'pools', 'link-120');">pools</a></tt><tt class="py-op">[</tt><tt class="py-name">uri</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L408"></a><tt class="py-lineno"> 408</tt>  <tt class="py-line">                <tt id="link-149" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-149', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-150" class="py-name"><a title="web2py.gluon.newcron.Token.release" class="py-name" href="#" onclick="return doclink('link-150', 'release', 'link-134');">release</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L409"></a><tt class="py-lineno"> 409</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L410"></a><tt class="py-lineno"> 410</tt>  <tt class="py-line">                <tt id="link-151" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-151', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-152" class="py-name"><a title="web2py.gluon.newcron.Token.release" class="py-name" href="#" onclick="return doclink('link-152', 'release', 'link-134');">release</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L411"></a><tt class="py-lineno"> 411</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt> <tt class="py-op">=</tt> <tt class="py-name">f</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L412"></a><tt class="py-lineno"> 412</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt id="link-153" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-153', 'thread', 'link-27');">thread</a></tt><tt class="py-op">,</tt><tt class="py-string">'instances'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L413"></a><tt class="py-lineno"> 413</tt>  <tt class="py-line">            <tt id="link-154" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-154', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt id="link-155" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-155', 'instances', 'link-124');">instances</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L414"></a><tt class="py-lineno"> 414</tt>  <tt class="py-line">        <tt id="link-156" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-156', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt id="link-157" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-157', 'instances', 'link-124');">instances</a></tt><tt class="py-op">.</tt><tt id="link-158" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-158', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L415"></a><tt class="py-lineno"> 415</tt>  <tt class="py-line"> </tt>
<a name="L416"></a><tt class="py-lineno"> 416</tt>  <tt class="py-line"> </tt>
<a name="L417"></a><tt class="py-lineno"> 417</tt>  <tt class="py-line"><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L418"></a><tt class="py-lineno"> 418</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># this is a generic adapter that does nothing; all others are derived form this one</tt> </tt>
<a name="L419"></a><tt class="py-lineno"> 419</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L420"></a><tt class="py-lineno"> 420</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="BaseAdapter"></a><div id="BaseAdapter-def"><a name="L421"></a><tt class="py-lineno"> 421</tt> <a class="py-toggle" href="#" id="BaseAdapter-toggle" onclick="return toggle('BaseAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html">BaseAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">ConnectionPool</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="BaseAdapter-expanded"><a name="L422"></a><tt class="py-lineno"> 422</tt>  <tt class="py-line"> </tt>
<a name="L423"></a><tt class="py-lineno"> 423</tt>  <tt class="py-line">    <tt id="link-159" class="py-name" targets="Variable web2py.gluon.dal.BaseAdapter.driver=web2py.gluon.dal.BaseAdapter-class.html#driver,Variable web2py.gluon.dal.CubridAdapter.driver=web2py.gluon.dal.CubridAdapter-class.html#driver,Variable web2py.gluon.dal.DB2Adapter.driver=web2py.gluon.dal.DB2Adapter-class.html#driver,Variable web2py.gluon.dal.FireBirdAdapter.driver=web2py.gluon.dal.FireBirdAdapter-class.html#driver,Variable web2py.gluon.dal.InformixAdapter.driver=web2py.gluon.dal.InformixAdapter-class.html#driver,Variable web2py.gluon.dal.IngresAdapter.driver=web2py.gluon.dal.IngresAdapter-class.html#driver,Variable web2py.gluon.dal.JDBCSQLiteAdapter.driver=web2py.gluon.dal.JDBCSQLiteAdapter-class.html#driver,Variable web2py.gluon.dal.MSSQLAdapter.driver=web2py.gluon.dal.MSSQLAdapter-class.html#driver,Variable web2py.gluon.dal.OracleAdapter.driver=web2py.gluon.dal.OracleAdapter-class.html#driver,Variable web2py.gluon.dal.SAPDBAdapter.driver=web2py.gluon.dal.SAPDBAdapter-class.html#driver,Variable web2py.gluon.dal.TeradataAdapter.driver=web2py.gluon.dal.TeradataAdapter-class.html#driver"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-159', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L424"></a><tt class="py-lineno"> 424</tt>  <tt class="py-line">    <tt id="link-160" class="py-name" targets="Variable web2py.gluon.dal.BaseAdapter.maxcharlength=web2py.gluon.dal.BaseAdapter-class.html#maxcharlength,Variable web2py.gluon.dal.MySQLAdapter.maxcharlength=web2py.gluon.dal.MySQLAdapter-class.html#maxcharlength"><a title="web2py.gluon.dal.BaseAdapter.maxcharlength
web2py.gluon.dal.MySQLAdapter.maxcharlength" class="py-name" href="#" onclick="return doclink('link-160', 'maxcharlength', 'link-160');">maxcharlength</a></tt> <tt class="py-op">=</tt> <tt id="link-161" class="py-name"><a title="web2py.gluon.dal.INFINITY" class="py-name" href="#" onclick="return doclink('link-161', 'INFINITY', 'link-1');">INFINITY</a></tt> </tt>
<a name="L425"></a><tt class="py-lineno"> 425</tt>  <tt class="py-line">    <tt id="link-162" class="py-name" targets="Variable web2py.gluon.dal.BaseAdapter.commit_on_alter_table=web2py.gluon.dal.BaseAdapter-class.html#commit_on_alter_table,Variable web2py.gluon.dal.FireBirdAdapter.commit_on_alter_table=web2py.gluon.dal.FireBirdAdapter-class.html#commit_on_alter_table,Variable web2py.gluon.dal.MySQLAdapter.commit_on_alter_table=web2py.gluon.dal.MySQLAdapter-class.html#commit_on_alter_table,Variable web2py.gluon.dal.OracleAdapter.commit_on_alter_table=web2py.gluon.dal.OracleAdapter-class.html#commit_on_alter_table"><a title="web2py.gluon.dal.BaseAdapter.commit_on_alter_table
web2py.gluon.dal.FireBirdAdapter.commit_on_alter_table
web2py.gluon.dal.MySQLAdapter.commit_on_alter_table
web2py.gluon.dal.OracleAdapter.commit_on_alter_table" class="py-name" href="#" onclick="return doclink('link-162', 'commit_on_alter_table', 'link-162');">commit_on_alter_table</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L426"></a><tt class="py-lineno"> 426</tt>  <tt class="py-line">    <tt id="link-163" class="py-name" targets="Variable web2py.gluon.dal.BaseAdapter.support_distributed_transaction=web2py.gluon.dal.BaseAdapter-class.html#support_distributed_transaction,Variable web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction=web2py.gluon.dal.FireBirdAdapter-class.html#support_distributed_transaction,Variable web2py.gluon.dal.MySQLAdapter.support_distributed_transaction=web2py.gluon.dal.MySQLAdapter-class.html#support_distributed_transaction,Variable web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction=web2py.gluon.dal.PostgreSQLAdapter-class.html#support_distributed_transaction,Variable web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction=web2py.gluon.dal.SAPDBAdapter-class.html#support_distributed_transaction"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-163', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L427"></a><tt class="py-lineno"> 427</tt>  <tt class="py-line">    <tt id="link-164" class="py-name" targets="Variable web2py.gluon.dal.BaseAdapter.uploads_in_blob=web2py.gluon.dal.BaseAdapter-class.html#uploads_in_blob,Variable web2py.gluon.dal.CouchDBAdapter.uploads_in_blob=web2py.gluon.dal.CouchDBAdapter-class.html#uploads_in_blob,Variable web2py.gluon.dal.GoogleDatastoreAdapter.uploads_in_blob=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#uploads_in_blob,Variable web2py.gluon.dal.MongoDBAdapter.uploads_in_blob=web2py.gluon.dal.MongoDBAdapter-class.html#uploads_in_blob"><a title="web2py.gluon.dal.BaseAdapter.uploads_in_blob
web2py.gluon.dal.CouchDBAdapter.uploads_in_blob
web2py.gluon.dal.GoogleDatastoreAdapter.uploads_in_blob
web2py.gluon.dal.MongoDBAdapter.uploads_in_blob" class="py-name" href="#" onclick="return doclink('link-164', 'uploads_in_blob', 'link-164');">uploads_in_blob</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L428"></a><tt class="py-lineno"> 428</tt>  <tt class="py-line">    <tt id="link-165" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-165', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L429"></a><tt class="py-lineno"> 429</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L430"></a><tt class="py-lineno"> 430</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L431"></a><tt class="py-lineno"> 431</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L432"></a><tt class="py-lineno"> 432</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L433"></a><tt class="py-lineno"> 433</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L434"></a><tt class="py-lineno"> 434</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L435"></a><tt class="py-lineno"> 435</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER'</tt><tt class="py-op">,</tt> </tt>
<a name="L436"></a><tt class="py-lineno"> 436</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'DOUBLE'</tt><tt class="py-op">,</tt> </tt>
<a name="L437"></a><tt class="py-lineno"> 437</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'DOUBLE'</tt><tt class="py-op">,</tt> </tt>
<a name="L438"></a><tt class="py-lineno"> 438</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L439"></a><tt class="py-lineno"> 439</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L440"></a><tt class="py-lineno"> 440</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP'</tt><tt class="py-op">,</tt> </tt>
<a name="L441"></a><tt class="py-lineno"> 441</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER PRIMARY KEY AUTOINCREMENT'</tt><tt class="py-op">,</tt> </tt>
<a name="L442"></a><tt class="py-lineno"> 442</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L443"></a><tt class="py-lineno"> 443</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L444"></a><tt class="py-lineno"> 444</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L445"></a><tt class="py-lineno"> 445</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L446"></a><tt class="py-lineno"> 446</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L447"></a><tt class="py-lineno"> 447</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.integrity_error"></a><div id="BaseAdapter.integrity_error-def"><a name="L448"></a><tt class="py-lineno"> 448</tt> <a class="py-toggle" href="#" id="BaseAdapter.integrity_error-toggle" onclick="return toggle('BaseAdapter.integrity_error');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#integrity_error">integrity_error</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.integrity_error-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.integrity_error-expanded"><a name="L449"></a><tt class="py-lineno"> 449</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-166" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-166', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-167" class="py-name" targets="Class psycopg2.IntegrityError=psycopg2.IntegrityError-class.html,Class web2py.gluon.contrib.pymysql.err.IntegrityError=web2py.gluon.contrib.pymysql.err.IntegrityError-class.html"><a title="psycopg2.IntegrityError
web2py.gluon.contrib.pymysql.err.IntegrityError" class="py-name" href="#" onclick="return doclink('link-167', 'IntegrityError', 'link-167');">IntegrityError</a></tt> </tt>
</div><a name="L450"></a><tt class="py-lineno"> 450</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.file_exists"></a><div id="BaseAdapter.file_exists-def"><a name="L451"></a><tt class="py-lineno"> 451</tt> <a class="py-toggle" href="#" id="BaseAdapter.file_exists-toggle" onclick="return toggle('BaseAdapter.file_exists');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#file_exists">file_exists</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.file_exists-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.file_exists-expanded"><a name="L452"></a><tt class="py-lineno"> 452</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L453"></a><tt class="py-lineno"> 453</tt>  <tt class="py-line"><tt class="py-docstring">        to be used ONLY for files that on GAE may not be on filesystem</tt> </tt>
<a name="L454"></a><tt class="py-lineno"> 454</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L455"></a><tt class="py-lineno"> 455</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-168" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-168', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt> </tt>
</div><a name="L456"></a><tt class="py-lineno"> 456</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.file_open"></a><div id="BaseAdapter.file_open-def"><a name="L457"></a><tt class="py-lineno"> 457</tt> <a class="py-toggle" href="#" id="BaseAdapter.file_open-toggle" onclick="return toggle('BaseAdapter.file_open');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#file_open">file_open</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt><tt class="py-op">=</tt><tt class="py-string">'rb'</tt><tt class="py-op">,</tt> <tt class="py-param">lock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.file_open-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.file_open-expanded"><a name="L458"></a><tt class="py-lineno"> 458</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L459"></a><tt class="py-lineno"> 459</tt>  <tt class="py-line"><tt class="py-docstring">        to be used ONLY for files that on GAE may not be on filesystem</tt> </tt>
<a name="L460"></a><tt class="py-lineno"> 460</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L461"></a><tt class="py-lineno"> 461</tt>  <tt class="py-line">        <tt class="py-name">fileobj</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt><tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
<a name="L462"></a><tt class="py-lineno"> 462</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-169" class="py-name"><a title="web2py.gluon.dal.have_portalocker" class="py-name" href="#" onclick="return doclink('link-169', 'have_portalocker', 'link-16');">have_portalocker</a></tt> <tt class="py-keyword">and</tt> <tt id="link-170" class="py-name" targets="Function web2py.gluon.portalocker.lock()=web2py.gluon.portalocker-module.html#lock"><a title="web2py.gluon.portalocker.lock" class="py-name" href="#" onclick="return doclink('link-170', 'lock', 'link-170');">lock</a></tt><tt class="py-op">:</tt> </tt>
<a name="L463"></a><tt class="py-lineno"> 463</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">mode</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'r'</tt><tt class="py-op">,</tt><tt class="py-string">'rb'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L464"></a><tt class="py-lineno"> 464</tt>  <tt class="py-line">                <tt id="link-171" class="py-name"><a title="web2py.gluon.portalocker" class="py-name" href="#" onclick="return doclink('link-171', 'portalocker', 'link-15');">portalocker</a></tt><tt class="py-op">.</tt><tt id="link-172" class="py-name"><a title="web2py.gluon.portalocker.lock" class="py-name" href="#" onclick="return doclink('link-172', 'lock', 'link-170');">lock</a></tt><tt class="py-op">(</tt><tt class="py-name">fileobj</tt><tt class="py-op">,</tt><tt id="link-173" class="py-name"><a title="web2py.gluon.portalocker" class="py-name" href="#" onclick="return doclink('link-173', 'portalocker', 'link-15');">portalocker</a></tt><tt class="py-op">.</tt><tt id="link-174" class="py-name" targets="Variable web2py.gluon.portalocker.LOCK_SH=web2py.gluon.portalocker-module.html#LOCK_SH"><a title="web2py.gluon.portalocker.LOCK_SH" class="py-name" href="#" onclick="return doclink('link-174', 'LOCK_SH', 'link-174');">LOCK_SH</a></tt><tt class="py-op">)</tt> </tt>
<a name="L465"></a><tt class="py-lineno"> 465</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">mode</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'w'</tt><tt class="py-op">,</tt><tt class="py-string">'wb'</tt><tt class="py-op">,</tt><tt class="py-string">'a'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L466"></a><tt class="py-lineno"> 466</tt>  <tt class="py-line">                <tt id="link-175" class="py-name"><a title="web2py.gluon.portalocker" class="py-name" href="#" onclick="return doclink('link-175', 'portalocker', 'link-15');">portalocker</a></tt><tt class="py-op">.</tt><tt id="link-176" class="py-name"><a title="web2py.gluon.portalocker.lock" class="py-name" href="#" onclick="return doclink('link-176', 'lock', 'link-170');">lock</a></tt><tt class="py-op">(</tt><tt class="py-name">fileobj</tt><tt class="py-op">,</tt><tt id="link-177" class="py-name"><a title="web2py.gluon.portalocker" class="py-name" href="#" onclick="return doclink('link-177', 'portalocker', 'link-15');">portalocker</a></tt><tt class="py-op">.</tt><tt id="link-178" class="py-name" targets="Variable web2py.gluon.portalocker.LOCK_EX=web2py.gluon.portalocker-module.html#LOCK_EX"><a title="web2py.gluon.portalocker.LOCK_EX" class="py-name" href="#" onclick="return doclink('link-178', 'LOCK_EX', 'link-178');">LOCK_EX</a></tt><tt class="py-op">)</tt> </tt>
<a name="L467"></a><tt class="py-lineno"> 467</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L468"></a><tt class="py-lineno"> 468</tt>  <tt class="py-line">                <tt class="py-name">fileobj</tt><tt class="py-op">.</tt><tt id="link-179" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.close()=web2py.gluon.dal.BaseAdapter-class.html#close,Method web2py.gluon.dal.DatabaseStoredFile.close()=web2py.gluon.dal.DatabaseStoredFile-class.html#close,Method web2py.gluon.dal.NoSQLAdapter.close()=web2py.gluon.dal.NoSQLAdapter-class.html#close,Method web2py.gluon.rocket.Connection.close()=web2py.gluon.rocket.Connection-class.html#close"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-179', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L469"></a><tt class="py-lineno"> 469</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Unsupported file_open mode"</tt> </tt>
<a name="L470"></a><tt class="py-lineno"> 470</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">fileobj</tt> </tt>
</div><a name="L471"></a><tt class="py-lineno"> 471</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.file_close"></a><div id="BaseAdapter.file_close-def"><a name="L472"></a><tt class="py-lineno"> 472</tt> <a class="py-toggle" href="#" id="BaseAdapter.file_close-toggle" onclick="return toggle('BaseAdapter.file_close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#file_close">file_close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">fileobj</tt><tt class="py-op">,</tt> <tt class="py-param">unlock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.file_close-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.file_close-expanded"><a name="L473"></a><tt class="py-lineno"> 473</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L474"></a><tt class="py-lineno"> 474</tt>  <tt class="py-line"><tt class="py-docstring">        to be used ONLY for files that on GAE may not be on filesystem</tt> </tt>
<a name="L475"></a><tt class="py-lineno"> 475</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L476"></a><tt class="py-lineno"> 476</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fileobj</tt><tt class="py-op">:</tt> </tt>
<a name="L477"></a><tt class="py-lineno"> 477</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-180" class="py-name"><a title="web2py.gluon.dal.have_portalocker" class="py-name" href="#" onclick="return doclink('link-180', 'have_portalocker', 'link-16');">have_portalocker</a></tt> <tt class="py-keyword">and</tt> <tt id="link-181" class="py-name" targets="Function web2py.gluon.portalocker.unlock()=web2py.gluon.portalocker-module.html#unlock"><a title="web2py.gluon.portalocker.unlock" class="py-name" href="#" onclick="return doclink('link-181', 'unlock', 'link-181');">unlock</a></tt><tt class="py-op">:</tt> </tt>
<a name="L478"></a><tt class="py-lineno"> 478</tt>  <tt class="py-line">                <tt id="link-182" class="py-name"><a title="web2py.gluon.portalocker" class="py-name" href="#" onclick="return doclink('link-182', 'portalocker', 'link-15');">portalocker</a></tt><tt class="py-op">.</tt><tt id="link-183" class="py-name"><a title="web2py.gluon.portalocker.unlock" class="py-name" href="#" onclick="return doclink('link-183', 'unlock', 'link-181');">unlock</a></tt><tt class="py-op">(</tt><tt class="py-name">fileobj</tt><tt class="py-op">)</tt> </tt>
<a name="L479"></a><tt class="py-lineno"> 479</tt>  <tt class="py-line">            <tt class="py-name">fileobj</tt><tt class="py-op">.</tt><tt id="link-184" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-184', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L480"></a><tt class="py-lineno"> 480</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.file_delete"></a><div id="BaseAdapter.file_delete-def"><a name="L481"></a><tt class="py-lineno"> 481</tt> <a class="py-toggle" href="#" id="BaseAdapter.file_delete-toggle" onclick="return toggle('BaseAdapter.file_delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#file_delete">file_delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.file_delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.file_delete-expanded"><a name="L482"></a><tt class="py-lineno"> 482</tt>  <tt class="py-line">        <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">unlink</tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt> </tt>
</div><a name="L483"></a><tt class="py-lineno"> 483</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.__init__"></a><div id="BaseAdapter.__init__-def"><a name="L484"></a><tt class="py-lineno"> 484</tt> <a class="py-toggle" href="#" id="BaseAdapter.__init__-toggle" onclick="return toggle('BaseAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L485"></a><tt class="py-lineno"> 485</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-185" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-185', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-186" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-186', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L486"></a><tt class="py-lineno"> 486</tt>  <tt class="py-line">                 <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.__init__-expanded"><a name="L487"></a><tt class="py-lineno"> 487</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L488"></a><tt class="py-lineno"> 488</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"None"</tt> </tt>
<a name="L489"></a><tt class="py-lineno"> 489</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L490"></a><tt class="py-lineno"> 490</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L491"></a><tt class="py-lineno"> 491</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L492"></a><tt class="py-lineno"> 492</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L493"></a><tt class="py-lineno"> 493</tt>  <tt class="py-line">        <tt class="py-keyword">class</tt> <tt class="py-def-name">Dummy</tt><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L494"></a><tt class="py-lineno"> 494</tt>  <tt class="py-line">            <tt id="link-187" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.lastrowid()=web2py.gluon.dal.BaseAdapter-class.html#lastrowid,Method web2py.gluon.dal.DB2Adapter.lastrowid()=web2py.gluon.dal.DB2Adapter-class.html#lastrowid,Method web2py.gluon.dal.FireBirdAdapter.lastrowid()=web2py.gluon.dal.FireBirdAdapter-class.html#lastrowid,Method web2py.gluon.dal.InformixAdapter.lastrowid()=web2py.gluon.dal.InformixAdapter-class.html#lastrowid,Method web2py.gluon.dal.IngresAdapter.lastrowid()=web2py.gluon.dal.IngresAdapter-class.html#lastrowid,Method web2py.gluon.dal.MSSQLAdapter.lastrowid()=web2py.gluon.dal.MSSQLAdapter-class.html#lastrowid,Method web2py.gluon.dal.MySQLAdapter.lastrowid()=web2py.gluon.dal.MySQLAdapter-class.html#lastrowid,Method web2py.gluon.dal.NoSQLAdapter.lastrowid()=web2py.gluon.dal.NoSQLAdapter-class.html#lastrowid,Method web2py.gluon.dal.OracleAdapter.lastrowid()=web2py.gluon.dal.OracleAdapter-class.html#lastrowid,Method web2py.gluon.dal.PostgreSQLAdapter.lastrowid()=web2py.gluon.dal.PostgreSQLAdapter-class.html#lastrowid,Method web2py.gluon.dal.SAPDBAdapter.lastrowid()=web2py.gluon.dal.SAPDBAdapter-class.html#lastrowid,Method web2py.gluon.dal.SQLiteAdapter.lastrowid()=web2py.gluon.dal.SQLiteAdapter-class.html#lastrowid"><a title="web2py.gluon.dal.BaseAdapter.lastrowid
web2py.gluon.dal.DB2Adapter.lastrowid
web2py.gluon.dal.FireBirdAdapter.lastrowid
web2py.gluon.dal.InformixAdapter.lastrowid
web2py.gluon.dal.IngresAdapter.lastrowid
web2py.gluon.dal.MSSQLAdapter.lastrowid
web2py.gluon.dal.MySQLAdapter.lastrowid
web2py.gluon.dal.NoSQLAdapter.lastrowid
web2py.gluon.dal.OracleAdapter.lastrowid
web2py.gluon.dal.PostgreSQLAdapter.lastrowid
web2py.gluon.dal.SAPDBAdapter.lastrowid
web2py.gluon.dal.SQLiteAdapter.lastrowid" class="py-name" href="#" onclick="return doclink('link-187', 'lastrowid', 'link-187');">lastrowid</a></tt> <tt class="py-op">=</tt> <tt class="py-number">1</tt> </tt>
<a name="L495"></a><tt class="py-lineno"> 495</tt>  <tt class="py-line">            <tt class="py-keyword">def</tt> <tt class="py-def-name">__getattr__</tt><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L496"></a><tt class="py-lineno"> 496</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-keyword">lambda</tt> <tt class="py-op">*</tt><tt class="py-name">a</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt id="link-188" class="py-name" targets="Function web2py.gluon.rocket.b()=web2py.gluon.rocket-module.html#b"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-188', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
</div></div><a name="L497"></a><tt class="py-lineno"> 497</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt> <tt class="py-op">=</tt> <tt class="py-name">Dummy</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L498"></a><tt class="py-lineno"> 498</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">Dummy</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L499"></a><tt class="py-lineno"> 499</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.sequence_name"></a><div id="BaseAdapter.sequence_name-def"><a name="L500"></a><tt class="py-lineno"> 500</tt> <a class="py-toggle" href="#" id="BaseAdapter.sequence_name-toggle" onclick="return toggle('BaseAdapter.sequence_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#sequence_name">sequence_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.sequence_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.sequence_name-expanded"><a name="L501"></a><tt class="py-lineno"> 501</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_sequence'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
</div><a name="L502"></a><tt class="py-lineno"> 502</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.trigger_name"></a><div id="BaseAdapter.trigger_name-def"><a name="L503"></a><tt class="py-lineno"> 503</tt> <a class="py-toggle" href="#" id="BaseAdapter.trigger_name-toggle" onclick="return toggle('BaseAdapter.trigger_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#trigger_name">trigger_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.trigger_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.trigger_name-expanded"><a name="L504"></a><tt class="py-lineno"> 504</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_sequence'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
</div><a name="L505"></a><tt class="py-lineno"> 505</tt>  <tt class="py-line"> </tt>
<a name="L506"></a><tt class="py-lineno"> 506</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.create_table"></a><div id="BaseAdapter.create_table-def"><a name="L507"></a><tt class="py-lineno"> 507</tt> <a class="py-toggle" href="#" id="BaseAdapter.create_table-toggle" onclick="return toggle('BaseAdapter.create_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#create_table">create_table</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-param">migrate</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> <tt class="py-param">polymodel</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.create_table-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.create_table-expanded"><a name="L508"></a><tt class="py-lineno"> 508</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L509"></a><tt class="py-lineno"> 509</tt>  <tt class="py-line">        <tt class="py-name">sql_fields</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L510"></a><tt class="py-lineno"> 510</tt>  <tt class="py-line">        <tt class="py-name">sql_fields_aux</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L511"></a><tt class="py-lineno"> 511</tt>  <tt class="py-line">        <tt class="py-name">TFK</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L512"></a><tt class="py-lineno"> 512</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L513"></a><tt class="py-lineno"> 513</tt>  <tt class="py-line">        <tt class="py-name">sortable</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
<a name="L514"></a><tt class="py-lineno"> 514</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">:</tt> </tt>
<a name="L515"></a><tt class="py-lineno"> 515</tt>  <tt class="py-line">            <tt class="py-name">sortable</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
<a name="L516"></a><tt class="py-lineno"> 516</tt>  <tt class="py-line">            <tt id="link-189" class="py-name" targets="Variable psycopg2.k=psycopg2-module.html#k"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-189', 'k', 'link-189');">k</a></tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-190" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-190', 'name', 'link-119');">name</a></tt> </tt>
<a name="L517"></a><tt class="py-lineno"> 517</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt><tt id="link-191" class="py-name" targets="Class web2py.gluon.dal.SQLCustomType=web2py.gluon.dal.SQLCustomType-class.html"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-191', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L518"></a><tt class="py-lineno"> 518</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt class="py-name">native</tt> <tt class="py-keyword">or</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L519"></a><tt class="py-lineno"> 519</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-192" class="py-name" targets="Method web2py.gluon.dal.Expression.startswith()=web2py.gluon.dal.Expression-class.html#startswith,Method web2py.gluon.dal.SQLCustomType.startswith()=web2py.gluon.dal.SQLCustomType-class.html#startswith"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-192', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L520"></a><tt class="py-lineno"> 520</tt>  <tt class="py-line">                <tt class="py-name">referenced</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-193" class="py-name" targets="Method web2py.gluon.sanitizer.XssCleaner.strip()=web2py.gluon.sanitizer.XssCleaner-class.html#strip"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-193', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L521"></a><tt class="py-lineno"> 521</tt>  <tt class="py-line">                <tt id="link-194" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.constraint_name()=web2py.gluon.dal.BaseAdapter-class.html#constraint_name,Method web2py.gluon.dal.NoSQLAdapter.constraint_name()=web2py.gluon.dal.NoSQLAdapter-class.html#constraint_name,Method web2py.gluon.dal.OracleAdapter.constraint_name()=web2py.gluon.dal.OracleAdapter-class.html#constraint_name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-194', 'constraint_name', 'link-194');">constraint_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-195" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-195', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-196" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-196', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L522"></a><tt class="py-lineno"> 522</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L523"></a><tt class="py-lineno"> 523</tt>  <tt class="py-line">                    <tt class="py-name">rtablename</tt><tt class="py-op">,</tt><tt class="py-name">rfieldname</tt> <tt class="py-op">=</tt> <tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L524"></a><tt class="py-lineno"> 524</tt>  <tt class="py-line">                    <tt class="py-name">rtable</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt> </tt>
<a name="L525"></a><tt class="py-lineno"> 525</tt>  <tt class="py-line">                    <tt class="py-name">rfield</tt> <tt class="py-op">=</tt> <tt class="py-name">rtable</tt><tt class="py-op">[</tt><tt class="py-name">rfieldname</tt><tt class="py-op">]</tt> </tt>
<a name="L526"></a><tt class="py-lineno"> 526</tt>  <tt class="py-line">                    <tt class="py-comment"># must be PK reference or unique</tt> </tt>
<a name="L527"></a><tt class="py-lineno"> 527</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-keyword">if</tt> <tt class="py-name">rfieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">rtable</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt> <tt class="py-keyword">or</tt> <tt class="py-name">rfield</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt><tt class="py-op">:</tt> </tt>
<a name="L528"></a><tt class="py-lineno"> 528</tt>  <tt class="py-line">                        <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-197" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-197', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">rfield</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">9</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> <tt class="py-op">%</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">length</tt><tt class="py-op">=</tt><tt class="py-name">rfield</tt><tt class="py-op">.</tt><tt class="py-name">length</tt><tt class="py-op">)</tt> </tt>
<a name="L529"></a><tt class="py-lineno"> 529</tt>  <tt class="py-line">                        <tt class="py-comment"># multicolumn primary key reference?</tt> </tt>
<a name="L530"></a><tt class="py-lineno"> 530</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">rfield</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt> <tt class="py-keyword">and</tt> <tt id="link-198" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-198', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">rtable</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">)</tt><tt class="py-op">&gt;</tt><tt class="py-number">1</tt> <tt class="py-op">:</tt> </tt>
<a name="L531"></a><tt class="py-lineno"> 531</tt>  <tt class="py-line">                            <tt class="py-comment"># then it has to be a table level FK</tt> </tt>
<a name="L532"></a><tt class="py-lineno"> 532</tt>  <tt class="py-line"><tt class="py-comment"></tt>                            <tt class="py-keyword">if</tt> <tt class="py-name">rtablename</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">TFK</tt><tt class="py-op">:</tt> </tt>
<a name="L533"></a><tt class="py-lineno"> 533</tt>  <tt class="py-line">                                <tt class="py-name">TFK</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L534"></a><tt class="py-lineno"> 534</tt>  <tt class="py-line">                            <tt class="py-name">TFK</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">rfieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-199" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-199', 'name', 'link-119');">name</a></tt> </tt>
<a name="L535"></a><tt class="py-lineno"> 535</tt>  <tt class="py-line">                        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L536"></a><tt class="py-lineno"> 536</tt>  <tt class="py-line">                            <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">ftype</tt> <tt class="py-op">+</tt> \ </tt>
<a name="L537"></a><tt class="py-lineno"> 537</tt>  <tt class="py-line">                                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-200" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-200', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-string">'reference FK'</tt><tt class="py-op">]</tt> <tt class="py-op">%</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt>\ </tt>
<a name="L538"></a><tt class="py-lineno"> 538</tt>  <tt class="py-line">                                <tt id="link-201" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-201', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">=</tt><tt id="link-202" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-202', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">,</tt> </tt>
<a name="L539"></a><tt class="py-lineno"> 539</tt>  <tt class="py-line">                                <tt class="py-name">table_name</tt><tt class="py-op">=</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L540"></a><tt class="py-lineno"> 540</tt>  <tt class="py-line">                                <tt class="py-name">field_name</tt><tt class="py-op">=</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-203" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-203', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> </tt>
<a name="L541"></a><tt class="py-lineno"> 541</tt>  <tt class="py-line">                                <tt class="py-name">foreign_key</tt><tt class="py-op">=</tt><tt class="py-string">'%s (%s)'</tt><tt class="py-op">%</tt><tt class="py-op">(</tt><tt class="py-name">rtablename</tt><tt class="py-op">,</tt> <tt class="py-name">rfieldname</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L542"></a><tt class="py-lineno"> 542</tt>  <tt class="py-line">                                <tt class="py-name">on_delete_action</tt><tt class="py-op">=</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">ondelete</tt><tt class="py-op">)</tt> </tt>
<a name="L543"></a><tt class="py-lineno"> 543</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L544"></a><tt class="py-lineno"> 544</tt>  <tt class="py-line">                    <tt class="py-comment"># make a guess here for circular references</tt> </tt>
<a name="L545"></a><tt class="py-lineno"> 545</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-name">id_fieldname</tt> <tt class="py-op">=</tt> <tt class="py-name">referenced</tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">referenced</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-204" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-204', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">or</tt> <tt class="py-string">'id'</tt> </tt>
<a name="L546"></a><tt class="py-lineno"> 546</tt>  <tt class="py-line">                    <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-205" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-205', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">9</tt><tt class="py-op">]</tt><tt class="py-op">]</tt>\ </tt>
<a name="L547"></a><tt class="py-lineno"> 547</tt>  <tt class="py-line">                        <tt class="py-op">%</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">table_name</tt><tt class="py-op">=</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L548"></a><tt class="py-lineno"> 548</tt>  <tt class="py-line">                               <tt class="py-name">field_name</tt><tt class="py-op">=</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-206" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-206', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> </tt>
<a name="L549"></a><tt class="py-lineno"> 549</tt>  <tt class="py-line">                               <tt id="link-207" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-207', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">=</tt><tt id="link-208" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-208', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">,</tt> </tt>
<a name="L550"></a><tt class="py-lineno"> 550</tt>  <tt class="py-line">                               <tt class="py-name">foreign_key</tt><tt class="py-op">=</tt><tt class="py-name">referenced</tt> <tt class="py-op">+</tt> <tt class="py-op">(</tt><tt class="py-string">'(%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">id_fieldname</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L551"></a><tt class="py-lineno"> 551</tt>  <tt class="py-line">                               <tt class="py-name">on_delete_action</tt><tt class="py-op">=</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">ondelete</tt><tt class="py-op">)</tt> </tt>
<a name="L552"></a><tt class="py-lineno"> 552</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-209" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-209', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L553"></a><tt class="py-lineno"> 553</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-210" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-210', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">14</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> </tt>
<a name="L554"></a><tt class="py-lineno"> 554</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-211" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-211', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'decimal'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L555"></a><tt class="py-lineno"> 555</tt>  <tt class="py-line">                <tt class="py-name">precision</tt><tt class="py-op">,</tt> <tt class="py-name">scale</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">8</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">','</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L556"></a><tt class="py-lineno"> 556</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-212" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-212', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">7</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L557"></a><tt class="py-lineno"> 557</tt>  <tt class="py-line">                    <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">precision</tt><tt class="py-op">=</tt><tt class="py-name">precision</tt><tt class="py-op">,</tt><tt class="py-name">scale</tt><tt class="py-op">=</tt><tt class="py-name">scale</tt><tt class="py-op">)</tt> </tt>
<a name="L558"></a><tt class="py-lineno"> 558</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-213" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-213', 'types', 'link-2');">types</a></tt><tt class="py-op">:</tt> </tt>
<a name="L559"></a><tt class="py-lineno"> 559</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Field: unknown field type: %s for %s'</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L560"></a><tt class="py-lineno"> 560</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-214" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-214', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L561"></a><tt class="py-lineno"> 561</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L562"></a><tt class="py-lineno"> 562</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-215" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-215', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">]</tt>\ </tt>
<a name="L563"></a><tt class="py-lineno"> 563</tt>  <tt class="py-line">                     <tt class="py-op">%</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">length</tt><tt class="py-op">=</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">length</tt><tt class="py-op">)</tt> </tt>
<a name="L564"></a><tt class="py-lineno"> 564</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-216" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-216', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'id'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-217" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-217', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L565"></a><tt class="py-lineno"> 565</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt><tt class="py-op">:</tt> </tt>
<a name="L566"></a><tt class="py-lineno"> 566</tt>  <tt class="py-line">                    <tt class="py-name">ftype</tt> <tt class="py-op">+=</tt> <tt class="py-string">' NOT NULL'</tt> </tt>
<a name="L567"></a><tt class="py-lineno"> 567</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L568"></a><tt class="py-lineno"> 568</tt>  <tt class="py-line">                    <tt class="py-name">ftype</tt> <tt class="py-op">+=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-218" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.ALLOW_NULL()=web2py.gluon.dal.BaseAdapter-class.html#ALLOW_NULL,Method web2py.gluon.dal.MSSQLAdapter.ALLOW_NULL()=web2py.gluon.dal.MSSQLAdapter-class.html#ALLOW_NULL"><a title="web2py.gluon.dal.BaseAdapter.ALLOW_NULL
web2py.gluon.dal.MSSQLAdapter.ALLOW_NULL" class="py-name" href="#" onclick="return doclink('link-218', 'ALLOW_NULL', 'link-218');">ALLOW_NULL</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L569"></a><tt class="py-lineno"> 569</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt><tt class="py-op">:</tt> </tt>
<a name="L570"></a><tt class="py-lineno"> 570</tt>  <tt class="py-line">                    <tt class="py-name">ftype</tt> <tt class="py-op">+=</tt> <tt class="py-string">' UNIQUE'</tt> </tt>
<a name="L571"></a><tt class="py-lineno"> 571</tt>  <tt class="py-line"> </tt>
<a name="L572"></a><tt class="py-lineno"> 572</tt>  <tt class="py-line">            <tt class="py-comment"># add to list of fields</tt> </tt>
<a name="L573"></a><tt class="py-lineno"> 573</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-219" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-219', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">sortable</tt><tt class="py-op">=</tt><tt class="py-name">sortable</tt><tt class="py-op">,</tt> </tt>
<a name="L574"></a><tt class="py-lineno"> 574</tt>  <tt class="py-line">                                          <tt class="py-name">type</tt><tt class="py-op">=</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L575"></a><tt class="py-lineno"> 575</tt>  <tt class="py-line">                                          <tt id="link-220" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-220', 'sql', 'link-88');">sql</a></tt><tt class="py-op">=</tt><tt class="py-name">ftype</tt><tt class="py-op">)</tt> </tt>
<a name="L576"></a><tt class="py-lineno"> 576</tt>  <tt class="py-line"> </tt>
<a name="L577"></a><tt class="py-lineno"> 577</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">default</tt><tt class="py-op">,</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">,</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">float</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L578"></a><tt class="py-lineno"> 578</tt>  <tt class="py-line">                <tt class="py-comment"># caveat: sql_fields and sql_fields_aux differ for default values</tt> </tt>
<a name="L579"></a><tt class="py-lineno"> 579</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-comment"># sql_fields is used to trigger migrations and sql_fields_aux</tt> </tt>
<a name="L580"></a><tt class="py-lineno"> 580</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-comment"># are used for create table</tt> </tt>
<a name="L581"></a><tt class="py-lineno"> 581</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-comment"># the reason is that we do not want to trigger a migration simply</tt> </tt>
<a name="L582"></a><tt class="py-lineno"> 582</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-comment"># because a default value changes</tt> </tt>
<a name="L583"></a><tt class="py-lineno"> 583</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-name">not_null</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-221" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.NOT_NULL()=web2py.gluon.dal.BaseAdapter-class.html#NOT_NULL,Method web2py.gluon.dal.FireBirdAdapter.NOT_NULL()=web2py.gluon.dal.FireBirdAdapter-class.html#NOT_NULL,Method web2py.gluon.dal.InformixAdapter.NOT_NULL()=web2py.gluon.dal.InformixAdapter-class.html#NOT_NULL,Method web2py.gluon.dal.OracleAdapter.NOT_NULL()=web2py.gluon.dal.OracleAdapter-class.html#NOT_NULL"><a title="web2py.gluon.dal.BaseAdapter.NOT_NULL
web2py.gluon.dal.FireBirdAdapter.NOT_NULL
web2py.gluon.dal.InformixAdapter.NOT_NULL
web2py.gluon.dal.OracleAdapter.NOT_NULL" class="py-name" href="#" onclick="return doclink('link-221', 'NOT_NULL', 'link-221');">NOT_NULL</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">default</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
<a name="L584"></a><tt class="py-lineno"> 584</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">ftype</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'NOT NULL'</tt><tt class="py-op">,</tt><tt class="py-name">not_null</tt><tt class="py-op">)</tt> </tt>
<a name="L585"></a><tt class="py-lineno"> 585</tt>  <tt class="py-line">            <tt class="py-name">sql_fields_aux</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-222" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-222', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt id="link-223" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-223', 'sql', 'link-88');">sql</a></tt><tt class="py-op">=</tt><tt class="py-name">ftype</tt><tt class="py-op">)</tt> </tt>
<a name="L586"></a><tt class="py-lineno"> 586</tt>  <tt class="py-line"> </tt>
<a name="L587"></a><tt class="py-lineno"> 587</tt>  <tt class="py-line">            <tt class="py-name">fields</tt><tt class="py-op">.</tt><tt id="link-224" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-224', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'%s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-225" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-225', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">ftype</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L588"></a><tt class="py-lineno"> 588</tt>  <tt class="py-line">        <tt class="py-name">other</tt> <tt class="py-op">=</tt> <tt class="py-string">';'</tt> </tt>
<a name="L589"></a><tt class="py-lineno"> 589</tt>  <tt class="py-line"> </tt>
<a name="L590"></a><tt class="py-lineno"> 590</tt>  <tt class="py-line">        <tt class="py-comment"># backend-specific extensions to fields</tt> </tt>
<a name="L591"></a><tt class="py-lineno"> 591</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">==</tt> <tt class="py-string">'mysql'</tt><tt class="py-op">:</tt> </tt>
<a name="L592"></a><tt class="py-lineno"> 592</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-string">"_primarykey"</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L593"></a><tt class="py-lineno"> 593</tt>  <tt class="py-line">                <tt class="py-name">fields</tt><tt class="py-op">.</tt><tt id="link-226" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-226', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-string">'PRIMARY KEY(%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-227" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-227', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L594"></a><tt class="py-lineno"> 594</tt>  <tt class="py-line">            <tt class="py-name">other</tt> <tt class="py-op">=</tt> <tt class="py-string">' ENGINE=InnoDB CHARACTER SET utf8;'</tt> </tt>
<a name="L595"></a><tt class="py-lineno"> 595</tt>  <tt class="py-line"> </tt>
<a name="L596"></a><tt class="py-lineno"> 596</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-string">',\n    '</tt><tt class="py-op">.</tt><tt id="link-228" class="py-name" targets="Function web2py.gluon.html.join()=web2py.gluon.html-module.html#join"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-228', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L597"></a><tt class="py-lineno"> 597</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">rtablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">TFK</tt><tt class="py-op">:</tt> </tt>
<a name="L598"></a><tt class="py-lineno"> 598</tt>  <tt class="py-line">            <tt class="py-name">rfields</tt> <tt class="py-op">=</tt> <tt class="py-name">TFK</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt> </tt>
<a name="L599"></a><tt class="py-lineno"> 599</tt>  <tt class="py-line">            <tt class="py-name">pkeys</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt> </tt>
<a name="L600"></a><tt class="py-lineno"> 600</tt>  <tt class="py-line">            <tt class="py-name">fkeys</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> <tt class="py-name">rfields</tt><tt class="py-op">[</tt><tt id="link-229" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-229', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt id="link-230" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-230', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">pkeys</tt> <tt class="py-op">]</tt> </tt>
<a name="L601"></a><tt class="py-lineno"> 601</tt>  <tt class="py-line">            <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">fields</tt> <tt class="py-op">+</tt> <tt class="py-string">',\n    '</tt> <tt class="py-op">+</tt> \ </tt>
<a name="L602"></a><tt class="py-lineno"> 602</tt>  <tt class="py-line">                     <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-231" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-231', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-string">'reference TFK'</tt><tt class="py-op">]</tt> <tt class="py-op">%</tt>\ </tt>
<a name="L603"></a><tt class="py-lineno"> 603</tt>  <tt class="py-line">                     <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">table_name</tt><tt class="py-op">=</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L604"></a><tt class="py-lineno"> 604</tt>  <tt class="py-line">                     <tt class="py-name">field_name</tt><tt class="py-op">=</tt><tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-232" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-232', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">fkeys</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L605"></a><tt class="py-lineno"> 605</tt>  <tt class="py-line">                     <tt class="py-name">foreign_table</tt><tt class="py-op">=</tt><tt class="py-name">rtablename</tt><tt class="py-op">,</tt> </tt>
<a name="L606"></a><tt class="py-lineno"> 606</tt>  <tt class="py-line">                     <tt class="py-name">foreign_key</tt><tt class="py-op">=</tt><tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-233" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-233', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">pkeys</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L607"></a><tt class="py-lineno"> 607</tt>  <tt class="py-line">                     <tt class="py-name">on_delete_action</tt><tt class="py-op">=</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">ondelete</tt><tt class="py-op">)</tt> </tt>
<a name="L608"></a><tt class="py-lineno"> 608</tt>  <tt class="py-line"> </tt>
<a name="L609"></a><tt class="py-lineno"> 609</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L610"></a><tt class="py-lineno"> 610</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-string">'''CREATE TABLE %s(\n    %s,\n    %s) %s'''</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L611"></a><tt class="py-lineno"> 611</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-234" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.PRIMARY_KEY()=web2py.gluon.dal.BaseAdapter-class.html#PRIMARY_KEY,Method web2py.gluon.dal.MSSQLAdapter.PRIMARY_KEY()=web2py.gluon.dal.MSSQLAdapter-class.html#PRIMARY_KEY,Method web2py.gluon.dal.NoSQLAdapter.PRIMARY_KEY()=web2py.gluon.dal.NoSQLAdapter-class.html#PRIMARY_KEY"><a title="web2py.gluon.dal.BaseAdapter.PRIMARY_KEY
web2py.gluon.dal.MSSQLAdapter.PRIMARY_KEY
web2py.gluon.dal.NoSQLAdapter.PRIMARY_KEY" class="py-name" href="#" onclick="return doclink('link-234', 'PRIMARY_KEY', 'link-234');">PRIMARY_KEY</a></tt><tt class="py-op">(</tt><tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-235" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-235', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">)</tt> </tt>
<a name="L612"></a><tt class="py-lineno"> 612</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L613"></a><tt class="py-lineno"> 613</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-string">'''CREATE TABLE %s(\n    %s\n)%s'''</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L614"></a><tt class="py-lineno"> 614</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">,</tt> <tt class="py-name">other</tt><tt class="py-op">)</tt> </tt>
<a name="L615"></a><tt class="py-lineno"> 615</tt>  <tt class="py-line"> </tt>
<a name="L616"></a><tt class="py-lineno"> 616</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">.</tt><tt id="link-236" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-236', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'sqlite:///'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L617"></a><tt class="py-lineno"> 617</tt>  <tt class="py-line">            <tt class="py-name">path_encoding</tt> <tt class="py-op">=</tt> <tt class="py-name">sys</tt><tt class="py-op">.</tt><tt class="py-name">getfilesystemencoding</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">locale</tt><tt class="py-op">.</tt><tt class="py-name">getdefaultlocale</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'utf8'</tt> </tt>
<a name="L618"></a><tt class="py-lineno"> 618</tt>  <tt class="py-line">            <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">[</tt><tt class="py-number">9</tt><tt class="py-op">:</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">rfind</tt><tt class="py-op">(</tt><tt class="py-string">'/'</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-237" class="py-name" targets="Method web2py.gluon.languages.lazyT.decode()=web2py.gluon.languages.lazyT-class.html#decode"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-237', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-238" class="py-name" targets="Method web2py.gluon.languages.lazyT.encode()=web2py.gluon.languages.lazyT-class.html#encode"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-238', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-name">path_encoding</tt><tt class="py-op">)</tt> </tt>
<a name="L619"></a><tt class="py-lineno"> 619</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L620"></a><tt class="py-lineno"> 620</tt>  <tt class="py-line">            <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> </tt>
<a name="L621"></a><tt class="py-lineno"> 621</tt>  <tt class="py-line"> </tt>
<a name="L622"></a><tt class="py-lineno"> 622</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L623"></a><tt class="py-lineno"> 623</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">query</tt> </tt>
<a name="L624"></a><tt class="py-lineno"> 624</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">.</tt><tt id="link-239" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-239', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'sqlite:memory'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L625"></a><tt class="py-lineno"> 625</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L626"></a><tt class="py-lineno"> 626</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">migrate</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L627"></a><tt class="py-lineno"> 627</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-240" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-240', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">dbpath</tt><tt class="py-op">,</tt> <tt class="py-name">migrate</tt><tt class="py-op">)</tt> </tt>
<a name="L628"></a><tt class="py-lineno"> 628</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L629"></a><tt class="py-lineno"> 629</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-241" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-241', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">dbpath</tt><tt class="py-op">,</tt> <tt class="py-string">'%s_%s.table'</tt> \ </tt>
<a name="L630"></a><tt class="py-lineno"> 630</tt>  <tt class="py-line">                                          <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_uri_hash</tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L631"></a><tt class="py-lineno"> 631</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L632"></a><tt class="py-lineno"> 632</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_loggername</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-242" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-242', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">dbpath</tt><tt class="py-op">,</tt> <tt class="py-string">'sql.log'</tt><tt class="py-op">)</tt> </tt>
<a name="L633"></a><tt class="py-lineno"> 633</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-243" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.file_open()=web2py.gluon.dal.BaseAdapter-class.html#file_open,Method web2py.gluon.dal.CouchDBAdapter.file_open()=web2py.gluon.dal.CouchDBAdapter-class.html#file_open,Method web2py.gluon.dal.GoogleDatastoreAdapter.file_open()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#file_open,Method web2py.gluon.dal.UseDatabaseStoredFile.file_open()=web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_open"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-243', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_loggername</tt><tt class="py-op">,</tt> <tt class="py-string">'a'</tt><tt class="py-op">)</tt> </tt>
<a name="L634"></a><tt class="py-lineno"> 634</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L635"></a><tt class="py-lineno"> 635</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L636"></a><tt class="py-lineno"> 636</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt> <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-244" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.file_exists()=web2py.gluon.dal.BaseAdapter-class.html#file_exists,Method web2py.gluon.dal.CouchDBAdapter.file_exists()=web2py.gluon.dal.CouchDBAdapter-class.html#file_exists,Method web2py.gluon.dal.GoogleDatastoreAdapter.file_exists()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#file_exists,Method web2py.gluon.dal.UseDatabaseStoredFile.file_exists()=web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_exists"><a title="web2py.gluon.dal.BaseAdapter.file_exists
web2py.gluon.dal.CouchDBAdapter.file_exists
web2py.gluon.dal.GoogleDatastoreAdapter.file_exists
web2py.gluon.dal.UseDatabaseStoredFile.file_exists" class="py-name" href="#" onclick="return doclink('link-244', 'file_exists', 'link-244');">file_exists</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L637"></a><tt class="py-lineno"> 637</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L638"></a><tt class="py-lineno"> 638</tt>  <tt class="py-line">                <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-245" class="py-name" targets="Method web2py.gluon.dal.DatabaseStoredFile.write()=web2py.gluon.dal.DatabaseStoredFile-class.html#write,Method web2py.gluon.debug.Pipe.write()=web2py.gluon.debug.Pipe-class.html#write,Method web2py.gluon.globals.Response.write()=web2py.gluon.globals.Response-class.html#write,Method web2py.gluon.rocket.WSGIWorker.write()=web2py.gluon.rocket.WSGIWorker-class.html#write,Method web2py.gluon.widget.IO.write()=web2py.gluon.widget.IO-class.html#write"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-245', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'timestamp: %s\n'</tt> </tt>
<a name="L639"></a><tt class="py-lineno"> 639</tt>  <tt class="py-line">                               <tt class="py-op">%</tt> <tt id="link-246" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-246', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-247" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-247', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt class="py-name">today</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L640"></a><tt class="py-lineno"> 640</tt>  <tt class="py-line">                <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-248" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-248', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt> <tt class="py-op">+</tt> <tt class="py-string">'\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L641"></a><tt class="py-lineno"> 641</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fake_migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L642"></a><tt class="py-lineno"> 642</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-249" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.create_sequence_and_triggers()=web2py.gluon.dal.BaseAdapter-class.html#create_sequence_and_triggers,Method web2py.gluon.dal.FireBirdAdapter.create_sequence_and_triggers()=web2py.gluon.dal.FireBirdAdapter-class.html#create_sequence_and_triggers,Method web2py.gluon.dal.IngresAdapter.create_sequence_and_triggers()=web2py.gluon.dal.IngresAdapter-class.html#create_sequence_and_triggers,Method web2py.gluon.dal.NoSQLAdapter.create_sequence_and_triggers()=web2py.gluon.dal.NoSQLAdapter-class.html#create_sequence_and_triggers,Method web2py.gluon.dal.OracleAdapter.create_sequence_and_triggers()=web2py.gluon.dal.OracleAdapter-class.html#create_sequence_and_triggers,Method web2py.gluon.dal.PostgreSQLAdapter.create_sequence_and_triggers()=web2py.gluon.dal.PostgreSQLAdapter-class.html#create_sequence_and_triggers,Method web2py.gluon.dal.SAPDBAdapter.create_sequence_and_triggers()=web2py.gluon.dal.SAPDBAdapter-class.html#create_sequence_and_triggers"><a title="web2py.gluon.dal.BaseAdapter.create_sequence_and_triggers
web2py.gluon.dal.FireBirdAdapter.create_sequence_and_triggers
web2py.gluon.dal.IngresAdapter.create_sequence_and_triggers
web2py.gluon.dal.NoSQLAdapter.create_sequence_and_triggers
web2py.gluon.dal.OracleAdapter.create_sequence_and_triggers
web2py.gluon.dal.PostgreSQLAdapter.create_sequence_and_triggers
web2py.gluon.dal.SAPDBAdapter.create_sequence_and_triggers" class="py-name" href="#" onclick="return doclink('link-249', 'create_sequence_and_triggers', 'link-249');">create_sequence_and_triggers</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">table</tt><tt class="py-op">)</tt> </tt>
<a name="L643"></a><tt class="py-lineno"> 643</tt>  <tt class="py-line">                <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-250" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.commit()=web2py.gluon.dal.BaseAdapter-class.html#commit,Method web2py.gluon.dal.DAL.commit()=web2py.gluon.dal.DAL-class.html#commit,Method web2py.gluon.dal.NoSQLAdapter.commit()=web2py.gluon.dal.NoSQLAdapter-class.html#commit"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-250', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L644"></a><tt class="py-lineno"> 644</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L645"></a><tt class="py-lineno"> 645</tt>  <tt class="py-line">                <tt class="py-name">tfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-251" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-251', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">,</tt> <tt class="py-string">'w'</tt><tt class="py-op">)</tt> </tt>
<a name="L646"></a><tt class="py-lineno"> 646</tt>  <tt class="py-line">                <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">dump</tt><tt class="py-op">(</tt><tt class="py-name">sql_fields</tt><tt class="py-op">,</tt> <tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L647"></a><tt class="py-lineno"> 647</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-252" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.file_close()=web2py.gluon.dal.BaseAdapter-class.html#file_close,Method web2py.gluon.dal.CouchDBAdapter.file_close()=web2py.gluon.dal.CouchDBAdapter-class.html#file_close,Method web2py.gluon.dal.GoogleDatastoreAdapter.file_close()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#file_close,Method web2py.gluon.dal.UseDatabaseStoredFile.file_close()=web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_close"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-252', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L648"></a><tt class="py-lineno"> 648</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">fake_migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L649"></a><tt class="py-lineno"> 649</tt>  <tt class="py-line">                    <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-253" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-253', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'faked!\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L650"></a><tt class="py-lineno"> 650</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L651"></a><tt class="py-lineno"> 651</tt>  <tt class="py-line">                    <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-254" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-254', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'success!\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L652"></a><tt class="py-lineno"> 652</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L653"></a><tt class="py-lineno"> 653</tt>  <tt class="py-line">            <tt class="py-name">tfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-255" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-255', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">,</tt> <tt class="py-string">'r'</tt><tt class="py-op">)</tt> </tt>
<a name="L654"></a><tt class="py-lineno"> 654</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L655"></a><tt class="py-lineno"> 655</tt>  <tt class="py-line">                <tt class="py-name">sql_fields_old</tt> <tt class="py-op">=</tt> <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt id="link-256" class="py-name" targets="Method web2py.gluon.restricted.RestrictedError.load()=web2py.gluon.restricted.RestrictedError-class.html#load,Method web2py.gluon.restricted.TicketStorage.load()=web2py.gluon.restricted.TicketStorage-class.html#load,Function web2py.gluon.rewrite.load()=web2py.gluon.rewrite-module.html#load"><a title="web2py.gluon.restricted.RestrictedError.load
web2py.gluon.restricted.TicketStorage.load
web2py.gluon.rewrite.load" class="py-name" href="#" onclick="return doclink('link-256', 'load', 'link-256');">load</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L656"></a><tt class="py-lineno"> 656</tt>  <tt class="py-line">            <tt class="py-keyword">except</tt> <tt class="py-name">EOFError</tt><tt class="py-op">:</tt> </tt>
<a name="L657"></a><tt class="py-lineno"> 657</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-257" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-257', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L658"></a><tt class="py-lineno"> 658</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-258" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-258', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">logfile</tt><tt class="py-op">)</tt> </tt>
<a name="L659"></a><tt class="py-lineno"> 659</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">'File %s appears corrupted'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt> </tt>
<a name="L660"></a><tt class="py-lineno"> 660</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-259" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-259', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L661"></a><tt class="py-lineno"> 661</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">sql_fields</tt> <tt class="py-op">!=</tt> <tt class="py-name">sql_fields_old</tt><tt class="py-op">:</tt> </tt>
<a name="L662"></a><tt class="py-lineno"> 662</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-260" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.migrate_table()=web2py.gluon.dal.BaseAdapter-class.html#migrate_table,Method web2py.gluon.dal.NoSQLAdapter.migrate_table()=web2py.gluon.dal.NoSQLAdapter-class.html#migrate_table"><a title="web2py.gluon.dal.BaseAdapter.migrate_table
web2py.gluon.dal.NoSQLAdapter.migrate_table" class="py-name" href="#" onclick="return doclink('link-260', 'migrate_table', 'link-260');">migrate_table</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> </tt>
<a name="L663"></a><tt class="py-lineno"> 663</tt>  <tt class="py-line">                                   <tt class="py-name">sql_fields</tt><tt class="py-op">,</tt> <tt class="py-name">sql_fields_old</tt><tt class="py-op">,</tt> </tt>
<a name="L664"></a><tt class="py-lineno"> 664</tt>  <tt class="py-line">                                   <tt class="py-name">sql_fields_aux</tt><tt class="py-op">,</tt> <tt class="py-name">logfile</tt><tt class="py-op">,</tt> </tt>
<a name="L665"></a><tt class="py-lineno"> 665</tt>  <tt class="py-line">                                   <tt class="py-name">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">fake_migrate</tt><tt class="py-op">)</tt> </tt>
<a name="L666"></a><tt class="py-lineno"> 666</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-261" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-261', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">logfile</tt><tt class="py-op">)</tt> </tt>
<a name="L667"></a><tt class="py-lineno"> 667</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">query</tt> </tt>
</div><a name="L668"></a><tt class="py-lineno"> 668</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.migrate_table"></a><div id="BaseAdapter.migrate_table-def"><a name="L669"></a><tt class="py-lineno"> 669</tt> <a class="py-toggle" href="#" id="BaseAdapter.migrate_table-toggle" onclick="return toggle('BaseAdapter.migrate_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#migrate_table">migrate_table</a><tt class="py-op">(</tt> </tt>
<a name="L670"></a><tt class="py-lineno"> 670</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L671"></a><tt class="py-lineno"> 671</tt>  <tt class="py-line">        <tt class="py-param">table</tt><tt class="py-op">,</tt> </tt>
<a name="L672"></a><tt class="py-lineno"> 672</tt>  <tt class="py-line">        <tt class="py-param">sql_fields</tt><tt class="py-op">,</tt> </tt>
<a name="L673"></a><tt class="py-lineno"> 673</tt>  <tt class="py-line">        <tt class="py-param">sql_fields_old</tt><tt class="py-op">,</tt> </tt>
<a name="L674"></a><tt class="py-lineno"> 674</tt>  <tt class="py-line">        <tt class="py-param">sql_fields_aux</tt><tt class="py-op">,</tt> </tt>
<a name="L675"></a><tt class="py-lineno"> 675</tt>  <tt class="py-line">        <tt class="py-param">logfile</tt><tt class="py-op">,</tt> </tt>
<a name="L676"></a><tt class="py-lineno"> 676</tt>  <tt class="py-line">        <tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L677"></a><tt class="py-lineno"> 677</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.migrate_table-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.migrate_table-expanded"><a name="L678"></a><tt class="py-lineno"> 678</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L679"></a><tt class="py-lineno"> 679</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">fix</tt><tt class="py-op">(</tt><tt class="py-param">item</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L680"></a><tt class="py-lineno"> 680</tt>  <tt class="py-line">            <tt id="link-262" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-262', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt><tt class="py-op">=</tt><tt class="py-name">item</tt> </tt>
<a name="L681"></a><tt class="py-lineno"> 681</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L682"></a><tt class="py-lineno"> 682</tt>  <tt class="py-line">                <tt class="py-name">v</tt><tt class="py-op">=</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">type</tt><tt class="py-op">=</tt><tt class="py-string">'unkown'</tt><tt class="py-op">,</tt><tt id="link-263" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-263', 'sql', 'link-88');">sql</a></tt><tt class="py-op">=</tt><tt class="py-name">v</tt><tt class="py-op">)</tt> </tt>
<a name="L683"></a><tt class="py-lineno"> 683</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-264" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-264', 'k', 'link-189');">k</a></tt><tt class="py-op">.</tt><tt id="link-265" class="py-name" targets="Method web2py.gluon.dal.Expression.lower()=web2py.gluon.dal.Expression-class.html#lower"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-265', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">v</tt> </tt>
</div><a name="L684"></a><tt class="py-lineno"> 684</tt>  <tt class="py-line">        <tt class="py-comment">### make sure all field names are lower case to avoid conflicts</tt> </tt>
<a name="L685"></a><tt class="py-lineno"> 685</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">sql_fields</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">fix</tt><tt class="py-op">,</tt><tt class="py-name">sql_fields</tt><tt class="py-op">.</tt><tt id="link-266" class="py-name" targets="Method web2py.gluon.rocket.Headers.items()=web2py.gluon.rocket.Headers-class.html#items"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-266', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L686"></a><tt class="py-lineno"> 686</tt>  <tt class="py-line">        <tt class="py-name">sql_fields_old</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">fix</tt><tt class="py-op">,</tt><tt class="py-name">sql_fields_old</tt><tt class="py-op">.</tt><tt id="link-267" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-267', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L687"></a><tt class="py-lineno"> 687</tt>  <tt class="py-line">        <tt class="py-name">sql_fields_aux</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">fix</tt><tt class="py-op">,</tt><tt class="py-name">sql_fields_aux</tt><tt class="py-op">.</tt><tt id="link-268" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-268', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L688"></a><tt class="py-lineno"> 688</tt>  <tt class="py-line"> </tt>
<a name="L689"></a><tt class="py-lineno"> 689</tt>  <tt class="py-line">        <tt id="link-269" class="py-name" targets="Method web2py.gluon.rocket.Headers.keys()=web2py.gluon.rocket.Headers-class.html#keys,Method web2py.gluon.tools.PluginManager.keys()=web2py.gluon.tools.PluginManager-class.html#keys"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-269', 'keys', 'link-269');">keys</a></tt> <tt class="py-op">=</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">.</tt><tt id="link-270" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-270', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L690"></a><tt class="py-lineno"> 690</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sql_fields_old</tt><tt class="py-op">:</tt> </tt>
<a name="L691"></a><tt class="py-lineno"> 691</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt id="link-271" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-271', 'keys', 'link-269');">keys</a></tt><tt class="py-op">:</tt> </tt>
<a name="L692"></a><tt class="py-lineno"> 692</tt>  <tt class="py-line">                <tt id="link-272" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-272', 'keys', 'link-269');">keys</a></tt><tt class="py-op">.</tt><tt id="link-273" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-273', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L693"></a><tt class="py-lineno"> 693</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">==</tt> <tt class="py-string">'mssql'</tt><tt class="py-op">:</tt> </tt>
<a name="L694"></a><tt class="py-lineno"> 694</tt>  <tt class="py-line">            <tt class="py-name">new_add</tt> <tt class="py-op">=</tt> <tt class="py-string">'; ALTER TABLE %s ADD '</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L695"></a><tt class="py-lineno"> 695</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L696"></a><tt class="py-lineno"> 696</tt>  <tt class="py-line">            <tt class="py-name">new_add</tt> <tt class="py-op">=</tt> <tt class="py-string">', ADD '</tt> </tt>
<a name="L697"></a><tt class="py-lineno"> 697</tt>  <tt class="py-line"> </tt>
<a name="L698"></a><tt class="py-lineno"> 698</tt>  <tt class="py-line">        <tt class="py-name">metadata_change</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L699"></a><tt class="py-lineno"> 699</tt>  <tt class="py-line">        <tt class="py-name">sql_fields_current</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">sql_fields_old</tt><tt class="py-op">)</tt> </tt>
<a name="L700"></a><tt class="py-lineno"> 700</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt id="link-274" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-274', 'keys', 'link-269');">keys</a></tt><tt class="py-op">:</tt> </tt>
<a name="L701"></a><tt class="py-lineno"> 701</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L702"></a><tt class="py-lineno"> 702</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sql_fields_old</tt><tt class="py-op">:</tt> </tt>
<a name="L703"></a><tt class="py-lineno"> 703</tt>  <tt class="py-line">                <tt class="py-name">sql_fields_current</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
<a name="L704"></a><tt class="py-lineno"> 704</tt>  <tt class="py-line">                <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'ALTER TABLE %s ADD %s %s;'</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L705"></a><tt class="py-lineno"> 705</tt>  <tt class="py-line">                         <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> </tt>
<a name="L706"></a><tt class="py-lineno"> 706</tt>  <tt class="py-line">                          <tt class="py-name">sql_fields_aux</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'sql'</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">', '</tt><tt class="py-op">,</tt> <tt class="py-name">new_add</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L707"></a><tt class="py-lineno"> 707</tt>  <tt class="py-line">                <tt class="py-name">metadata_change</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L708"></a><tt class="py-lineno"> 708</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">==</tt> <tt class="py-string">'sqlite'</tt><tt class="py-op">:</tt> </tt>
<a name="L709"></a><tt class="py-lineno"> 709</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">:</tt> </tt>
<a name="L710"></a><tt class="py-lineno"> 710</tt>  <tt class="py-line">                    <tt class="py-name">sql_fields_current</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
<a name="L711"></a><tt class="py-lineno"> 711</tt>  <tt class="py-line">                <tt class="py-name">metadata_change</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L712"></a><tt class="py-lineno"> 712</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">:</tt> </tt>
<a name="L713"></a><tt class="py-lineno"> 713</tt>  <tt class="py-line">                <tt class="py-keyword">del</tt> <tt class="py-name">sql_fields_current</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
<a name="L714"></a><tt class="py-lineno"> 714</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'firebird'</tt><tt class="py-op">,</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L715"></a><tt class="py-lineno"> 715</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'ALTER TABLE %s DROP COLUMN %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L716"></a><tt class="py-lineno"> 716</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L717"></a><tt class="py-lineno"> 717</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'ALTER TABLE %s DROP %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L718"></a><tt class="py-lineno"> 718</tt>  <tt class="py-line">                <tt class="py-name">metadata_change</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L719"></a><tt class="py-lineno"> 719</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'sql'</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-name">sql_fields_old</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'sql'</tt><tt class="py-op">]</tt> \ </tt>
<a name="L720"></a><tt class="py-lineno"> 720</tt>  <tt class="py-line">                  <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt> <tt id="link-275" class="py-name"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-275', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt> \ </tt>
<a name="L721"></a><tt class="py-lineno"> 721</tt>  <tt class="py-line">                  <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-276" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-276', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L722"></a><tt class="py-lineno"> 722</tt>  <tt class="py-line">                      <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'sql'</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-277" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-277', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'INT,'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L723"></a><tt class="py-lineno"> 723</tt>  <tt class="py-line">                      <tt class="py-name">sql_fields_old</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'sql'</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-278" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-278', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'INT NOT NULL,'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L724"></a><tt class="py-lineno"> 724</tt>  <tt class="py-line">                <tt class="py-name">sql_fields_current</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
<a name="L725"></a><tt class="py-lineno"> 725</tt>  <tt class="py-line">                <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L726"></a><tt class="py-lineno"> 726</tt>  <tt class="py-line">                <tt class="py-name">tt</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_fields_aux</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'sql'</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">', '</tt><tt class="py-op">,</tt> <tt class="py-name">new_add</tt><tt class="py-op">)</tt> </tt>
<a name="L727"></a><tt class="py-lineno"> 727</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'firebird'</tt><tt class="py-op">,</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L728"></a><tt class="py-lineno"> 728</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'ALTER TABLE %s ADD %s__tmp %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">tt</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L729"></a><tt class="py-lineno"> 729</tt>  <tt class="py-line">                             <tt class="py-string">'UPDATE %s SET %s__tmp=%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L730"></a><tt class="py-lineno"> 730</tt>  <tt class="py-line">                             <tt class="py-string">'ALTER TABLE %s DROP COLUMN %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L731"></a><tt class="py-lineno"> 731</tt>  <tt class="py-line">                             <tt class="py-string">'ALTER TABLE %s ADD %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">tt</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L732"></a><tt class="py-lineno"> 732</tt>  <tt class="py-line">                             <tt class="py-string">'UPDATE %s SET %s=%s__tmp;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L733"></a><tt class="py-lineno"> 733</tt>  <tt class="py-line">                             <tt class="py-string">'ALTER TABLE %s DROP COLUMN %s__tmp;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L734"></a><tt class="py-lineno"> 734</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L735"></a><tt class="py-lineno"> 735</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'ALTER TABLE %s ADD %s__tmp %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">tt</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L736"></a><tt class="py-lineno"> 736</tt>  <tt class="py-line">                             <tt class="py-string">'UPDATE %s SET %s__tmp=%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L737"></a><tt class="py-lineno"> 737</tt>  <tt class="py-line">                             <tt class="py-string">'ALTER TABLE %s DROP %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L738"></a><tt class="py-lineno"> 738</tt>  <tt class="py-line">                             <tt class="py-string">'ALTER TABLE %s ADD %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">tt</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L739"></a><tt class="py-lineno"> 739</tt>  <tt class="py-line">                             <tt class="py-string">'UPDATE %s SET %s=%s__tmp;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L740"></a><tt class="py-lineno"> 740</tt>  <tt class="py-line">                             <tt class="py-string">'ALTER TABLE %s DROP %s__tmp;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L741"></a><tt class="py-lineno"> 741</tt>  <tt class="py-line">                <tt class="py-name">metadata_change</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L742"></a><tt class="py-lineno"> 742</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'type'</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-name">sql_fields_old</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-string">'type'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L743"></a><tt class="py-lineno"> 743</tt>  <tt class="py-line">                <tt class="py-name">sql_fields_current</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
<a name="L744"></a><tt class="py-lineno"> 744</tt>  <tt class="py-line">                <tt class="py-name">metadata_change</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L745"></a><tt class="py-lineno"> 745</tt>  <tt class="py-line"> </tt>
<a name="L746"></a><tt class="py-lineno"> 746</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L747"></a><tt class="py-lineno"> 747</tt>  <tt class="py-line">                <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-279" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-279', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'timestamp: %s\n'</tt> </tt>
<a name="L748"></a><tt class="py-lineno"> 748</tt>  <tt class="py-line">                              <tt class="py-op">%</tt> <tt id="link-280" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-280', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-281" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-281', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt class="py-name">today</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L749"></a><tt class="py-lineno"> 749</tt>  <tt class="py-line">                <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-string">'_lastsql'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-string">'\n'</tt><tt class="py-op">.</tt><tt id="link-282" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-282', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L750"></a><tt class="py-lineno"> 750</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">sub_query</tt> <tt class="py-keyword">in</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L751"></a><tt class="py-lineno"> 751</tt>  <tt class="py-line">                    <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-283" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-283', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-name">sub_query</tt> <tt class="py-op">+</tt> <tt class="py-string">'\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L752"></a><tt class="py-lineno"> 752</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fake_migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L753"></a><tt class="py-lineno"> 753</tt>  <tt class="py-line">                        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-284" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.execute()=web2py.gluon.dal.BaseAdapter-class.html#execute,Method web2py.gluon.dal.DB2Adapter.execute()=web2py.gluon.dal.DB2Adapter-class.html#execute,Method web2py.gluon.dal.InformixAdapter.execute()=web2py.gluon.dal.InformixAdapter-class.html#execute,Method web2py.gluon.dal.JDBCSQLiteAdapter.execute()=web2py.gluon.dal.JDBCSQLiteAdapter-class.html#execute,Method web2py.gluon.dal.MSSQL2Adapter.execute()=web2py.gluon.dal.MSSQL2Adapter-class.html#execute,Method web2py.gluon.dal.NoSQLAdapter.execute()=web2py.gluon.dal.NoSQLAdapter-class.html#execute,Method web2py.gluon.dal.OracleAdapter.execute()=web2py.gluon.dal.OracleAdapter-class.html#execute"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-284', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">sub_query</tt><tt class="py-op">)</tt> </tt>
<a name="L754"></a><tt class="py-lineno"> 754</tt>  <tt class="py-line">                        <tt class="py-comment"># caveat. mysql, oracle and firebird do not allow multiple alter table</tt> </tt>
<a name="L755"></a><tt class="py-lineno"> 755</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-comment"># in one transaction so we must commit partial transactions and</tt> </tt>
<a name="L756"></a><tt class="py-lineno"> 756</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-comment"># update table._dbt after alter table.</tt> </tt>
<a name="L757"></a><tt class="py-lineno"> 757</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-285" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit_on_alter_table
web2py.gluon.dal.FireBirdAdapter.commit_on_alter_table
web2py.gluon.dal.MySQLAdapter.commit_on_alter_table
web2py.gluon.dal.OracleAdapter.commit_on_alter_table" class="py-name" href="#" onclick="return doclink('link-285', 'commit_on_alter_table', 'link-162');">commit_on_alter_table</a></tt><tt class="py-op">:</tt> </tt>
<a name="L758"></a><tt class="py-lineno"> 758</tt>  <tt class="py-line">                            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-286" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-286', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L759"></a><tt class="py-lineno"> 759</tt>  <tt class="py-line">                            <tt class="py-name">tfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-287" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-287', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">,</tt> <tt class="py-string">'w'</tt><tt class="py-op">)</tt> </tt>
<a name="L760"></a><tt class="py-lineno"> 760</tt>  <tt class="py-line">                            <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">dump</tt><tt class="py-op">(</tt><tt class="py-name">sql_fields_current</tt><tt class="py-op">,</tt> <tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L761"></a><tt class="py-lineno"> 761</tt>  <tt class="py-line">                            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-288" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-288', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L762"></a><tt class="py-lineno"> 762</tt>  <tt class="py-line">                            <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-289" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-289', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'success!\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L763"></a><tt class="py-lineno"> 763</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L764"></a><tt class="py-lineno"> 764</tt>  <tt class="py-line">                        <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-290" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-290', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'faked!\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L765"></a><tt class="py-lineno"> 765</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">metadata_change</tt><tt class="py-op">:</tt> </tt>
<a name="L766"></a><tt class="py-lineno"> 766</tt>  <tt class="py-line">                <tt class="py-name">tfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-291" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-291', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">,</tt> <tt class="py-string">'w'</tt><tt class="py-op">)</tt> </tt>
<a name="L767"></a><tt class="py-lineno"> 767</tt>  <tt class="py-line">                <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">dump</tt><tt class="py-op">(</tt><tt class="py-name">sql_fields_current</tt><tt class="py-op">,</tt> <tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L768"></a><tt class="py-lineno"> 768</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-292" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-292', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L769"></a><tt class="py-lineno"> 769</tt>  <tt class="py-line"> </tt>
<a name="L770"></a><tt class="py-lineno"> 770</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">metadata_change</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L771"></a><tt class="py-lineno"> 771</tt>  <tt class="py-line">                <tt class="py-keyword">not</tt> <tt class="py-op">(</tt><tt class="py-name">query</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'mysql'</tt><tt class="py-op">,</tt><tt class="py-string">'oracle'</tt><tt class="py-op">,</tt><tt class="py-string">'firebird'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L772"></a><tt class="py-lineno"> 772</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-293" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-293', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L773"></a><tt class="py-lineno"> 773</tt>  <tt class="py-line">            <tt class="py-name">tfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-294" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-294', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">,</tt> <tt class="py-string">'w'</tt><tt class="py-op">)</tt> </tt>
<a name="L774"></a><tt class="py-lineno"> 774</tt>  <tt class="py-line">            <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">dump</tt><tt class="py-op">(</tt><tt class="py-name">sql_fields_current</tt><tt class="py-op">,</tt> <tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L775"></a><tt class="py-lineno"> 775</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-295" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-295', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
</div><a name="L776"></a><tt class="py-lineno"> 776</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.LOWER"></a><div id="BaseAdapter.LOWER-def"><a name="L777"></a><tt class="py-lineno"> 777</tt> <a class="py-toggle" href="#" id="BaseAdapter.LOWER-toggle" onclick="return toggle('BaseAdapter.LOWER');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#LOWER">LOWER</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.LOWER-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.LOWER-expanded"><a name="L778"></a><tt class="py-lineno"> 778</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'LOWER(%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-296" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.expand()=web2py.gluon.dal.BaseAdapter-class.html#expand,Method web2py.gluon.dal.CouchDBAdapter.expand()=web2py.gluon.dal.CouchDBAdapter-class.html#expand,Method web2py.gluon.dal.GoogleDatastoreAdapter.expand()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#expand"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-296', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-297" class="py-name" targets="Method web2py.gluon.dal.Rows.first()=web2py.gluon.dal.Rows-class.html#first"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-297', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L779"></a><tt class="py-lineno"> 779</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.UPPER"></a><div id="BaseAdapter.UPPER-def"><a name="L780"></a><tt class="py-lineno"> 780</tt> <a class="py-toggle" href="#" id="BaseAdapter.UPPER-toggle" onclick="return toggle('BaseAdapter.UPPER');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#UPPER">UPPER</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.UPPER-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.UPPER-expanded"><a name="L781"></a><tt class="py-lineno"> 781</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'UPPER(%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-298" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-298', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-299" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-299', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L782"></a><tt class="py-lineno"> 782</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.EXTRACT"></a><div id="BaseAdapter.EXTRACT-def"><a name="L783"></a><tt class="py-lineno"> 783</tt> <a class="py-toggle" href="#" id="BaseAdapter.EXTRACT-toggle" onclick="return toggle('BaseAdapter.EXTRACT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#EXTRACT">EXTRACT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">what</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.EXTRACT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.EXTRACT-expanded"><a name="L784"></a><tt class="py-lineno"> 784</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">"EXTRACT(%s FROM %s)"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">what</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-300" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-300', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-301" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-301', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L785"></a><tt class="py-lineno"> 785</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.AGGREGATE"></a><div id="BaseAdapter.AGGREGATE-def"><a name="L786"></a><tt class="py-lineno"> 786</tt> <a class="py-toggle" href="#" id="BaseAdapter.AGGREGATE-toggle" onclick="return toggle('BaseAdapter.AGGREGATE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#AGGREGATE">AGGREGATE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">what</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.AGGREGATE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.AGGREGATE-expanded"><a name="L787"></a><tt class="py-lineno"> 787</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">"%s(%s)"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">what</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-302" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-302', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-303" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-303', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L788"></a><tt class="py-lineno"> 788</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.JOIN"></a><div id="BaseAdapter.JOIN-def"><a name="L789"></a><tt class="py-lineno"> 789</tt> <a class="py-toggle" href="#" id="BaseAdapter.JOIN-toggle" onclick="return toggle('BaseAdapter.JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#JOIN">JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.JOIN-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.JOIN-expanded"><a name="L790"></a><tt class="py-lineno"> 790</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'JOIN'</tt> </tt>
</div><a name="L791"></a><tt class="py-lineno"> 791</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.LEFT_JOIN"></a><div id="BaseAdapter.LEFT_JOIN-def"><a name="L792"></a><tt class="py-lineno"> 792</tt> <a class="py-toggle" href="#" id="BaseAdapter.LEFT_JOIN-toggle" onclick="return toggle('BaseAdapter.LEFT_JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#LEFT_JOIN">LEFT_JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.LEFT_JOIN-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.LEFT_JOIN-expanded"><a name="L793"></a><tt class="py-lineno"> 793</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'LEFT JOIN'</tt> </tt>
</div><a name="L794"></a><tt class="py-lineno"> 794</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.RANDOM"></a><div id="BaseAdapter.RANDOM-def"><a name="L795"></a><tt class="py-lineno"> 795</tt> <a class="py-toggle" href="#" id="BaseAdapter.RANDOM-toggle" onclick="return toggle('BaseAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.RANDOM-expanded"><a name="L796"></a><tt class="py-lineno"> 796</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'Random()'</tt> </tt>
</div><a name="L797"></a><tt class="py-lineno"> 797</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.NOT_NULL"></a><div id="BaseAdapter.NOT_NULL-def"><a name="L798"></a><tt class="py-lineno"> 798</tt> <a class="py-toggle" href="#" id="BaseAdapter.NOT_NULL-toggle" onclick="return toggle('BaseAdapter.NOT_NULL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#NOT_NULL">NOT_NULL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">default</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.NOT_NULL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.NOT_NULL-expanded"><a name="L799"></a><tt class="py-lineno"> 799</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'NOT NULL DEFAULT %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-304" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.represent()=web2py.gluon.dal.BaseAdapter-class.html#represent,Method web2py.gluon.dal.CouchDBAdapter.represent()=web2py.gluon.dal.CouchDBAdapter-class.html#represent,Method web2py.gluon.dal.MSSQL2Adapter.represent()=web2py.gluon.dal.MSSQL2Adapter-class.html#represent,Method web2py.gluon.dal.NoSQLAdapter.represent()=web2py.gluon.dal.NoSQLAdapter-class.html#represent,Static Method web2py.gluon.sqlhtml.UploadWidget.represent()=web2py.gluon.sqlhtml.UploadWidget-class.html#represent,Function web2py.gluon.sqlhtml.represent()=web2py.gluon.sqlhtml-module.html#represent"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-304', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">default</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L800"></a><tt class="py-lineno"> 800</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.COALESCE_ZERO"></a><div id="BaseAdapter.COALESCE_ZERO-def"><a name="L801"></a><tt class="py-lineno"> 801</tt> <a class="py-toggle" href="#" id="BaseAdapter.COALESCE_ZERO-toggle" onclick="return toggle('BaseAdapter.COALESCE_ZERO');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#COALESCE_ZERO">COALESCE_ZERO</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.COALESCE_ZERO-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.COALESCE_ZERO-expanded"><a name="L802"></a><tt class="py-lineno"> 802</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'COALESCE(%s,0)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-305" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-305', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-306" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-306', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L803"></a><tt class="py-lineno"> 803</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.ALLOW_NULL"></a><div id="BaseAdapter.ALLOW_NULL-def"><a name="L804"></a><tt class="py-lineno"> 804</tt> <a class="py-toggle" href="#" id="BaseAdapter.ALLOW_NULL-toggle" onclick="return toggle('BaseAdapter.ALLOW_NULL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#ALLOW_NULL">ALLOW_NULL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.ALLOW_NULL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.ALLOW_NULL-expanded"><a name="L805"></a><tt class="py-lineno"> 805</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">''</tt> </tt>
</div><a name="L806"></a><tt class="py-lineno"> 806</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.SUBSTRING"></a><div id="BaseAdapter.SUBSTRING-def"><a name="L807"></a><tt class="py-lineno"> 807</tt> <a class="py-toggle" href="#" id="BaseAdapter.SUBSTRING-toggle" onclick="return toggle('BaseAdapter.SUBSTRING');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#SUBSTRING">SUBSTRING</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">parameters</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.SUBSTRING-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.SUBSTRING-expanded"><a name="L808"></a><tt class="py-lineno"> 808</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SUBSTR(%s,%s,%s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-307" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-307', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L809"></a><tt class="py-lineno"> 809</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.PRIMARY_KEY"></a><div id="BaseAdapter.PRIMARY_KEY-def"><a name="L810"></a><tt class="py-lineno"> 810</tt> <a class="py-toggle" href="#" id="BaseAdapter.PRIMARY_KEY-toggle" onclick="return toggle('BaseAdapter.PRIMARY_KEY');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#PRIMARY_KEY">PRIMARY_KEY</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.PRIMARY_KEY-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.PRIMARY_KEY-expanded"><a name="L811"></a><tt class="py-lineno"> 811</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'PRIMARY KEY(%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
</div><a name="L812"></a><tt class="py-lineno"> 812</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._drop"></a><div id="BaseAdapter._drop-def"><a name="L813"></a><tt class="py-lineno"> 813</tt> <a class="py-toggle" href="#" id="BaseAdapter._drop-toggle" onclick="return toggle('BaseAdapter._drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_drop">_drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._drop-expanded"><a name="L814"></a><tt class="py-lineno"> 814</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'DROP TABLE %s;'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">]</tt> </tt>
</div><a name="L815"></a><tt class="py-lineno"> 815</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.drop"></a><div id="BaseAdapter.drop-def"><a name="L816"></a><tt class="py-lineno"> 816</tt> <a class="py-toggle" href="#" id="BaseAdapter.drop-toggle" onclick="return toggle('BaseAdapter.drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#drop">drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt><tt class="py-op">=</tt><tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.drop-expanded"><a name="L817"></a><tt class="py-lineno"> 817</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L818"></a><tt class="py-lineno"> 818</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-308" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-308', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_loggername</tt><tt class="py-op">,</tt> <tt class="py-string">'a'</tt><tt class="py-op">)</tt> </tt>
<a name="L819"></a><tt class="py-lineno"> 819</tt>  <tt class="py-line">        <tt class="py-name">queries</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-309" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._drop()=web2py.gluon.dal.BaseAdapter-class.html#_drop,Method web2py.gluon.dal.FireBirdAdapter._drop()=web2py.gluon.dal.FireBirdAdapter-class.html#_drop,Method web2py.gluon.dal.MySQLAdapter._drop()=web2py.gluon.dal.MySQLAdapter-class.html#_drop,Method web2py.gluon.dal.OracleAdapter._drop()=web2py.gluon.dal.OracleAdapter-class.html#_drop,Method web2py.gluon.dal.Table._drop()=web2py.gluon.dal.Table-class.html#_drop"><a title="web2py.gluon.dal.BaseAdapter._drop
web2py.gluon.dal.FireBirdAdapter._drop
web2py.gluon.dal.MySQLAdapter._drop
web2py.gluon.dal.OracleAdapter._drop
web2py.gluon.dal.Table._drop" class="py-name" href="#" onclick="return doclink('link-309', '_drop', 'link-309');">_drop</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
<a name="L820"></a><tt class="py-lineno"> 820</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">query</tt> <tt class="py-keyword">in</tt> <tt class="py-name">queries</tt><tt class="py-op">:</tt> </tt>
<a name="L821"></a><tt class="py-lineno"> 821</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L822"></a><tt class="py-lineno"> 822</tt>  <tt class="py-line">                <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-310" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-310', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt> <tt class="py-op">+</tt> <tt class="py-string">'\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L823"></a><tt class="py-lineno"> 823</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-311" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-311', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L824"></a><tt class="py-lineno"> 824</tt>  <tt class="py-line">        <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-312" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-312', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L825"></a><tt class="py-lineno"> 825</tt>  <tt class="py-line">        <tt class="py-keyword">del</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L826"></a><tt class="py-lineno"> 826</tt>  <tt class="py-line">        <tt class="py-keyword">del</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-313" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.tables()=web2py.gluon.dal.BaseAdapter-class.html#tables,Method web2py.gluon.tools.Crud.tables()=web2py.gluon.tools.Crud-class.html#tables"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-313', 'tables', 'link-313');">tables</a></tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-314" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-314', 'tables', 'link-313');">tables</a></tt><tt class="py-op">.</tt><tt class="py-name">index</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L827"></a><tt class="py-lineno"> 827</tt>  <tt class="py-line">        <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-315" class="py-name" targets="Method web2py.gluon.dal.DAL._update_referenced_by()=web2py.gluon.dal.DAL-class.html#_update_referenced_by"><a title="web2py.gluon.dal.DAL._update_referenced_by" class="py-name" href="#" onclick="return doclink('link-315', '_update_referenced_by', 'link-315');">_update_referenced_by</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L828"></a><tt class="py-lineno"> 828</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L829"></a><tt class="py-lineno"> 829</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-316" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.file_delete()=web2py.gluon.dal.BaseAdapter-class.html#file_delete,Method web2py.gluon.dal.UseDatabaseStoredFile.file_delete()=web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_delete"><a title="web2py.gluon.dal.BaseAdapter.file_delete
web2py.gluon.dal.UseDatabaseStoredFile.file_delete" class="py-name" href="#" onclick="return doclink('link-316', 'file_delete', 'link-316');">file_delete</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">)</tt> </tt>
<a name="L830"></a><tt class="py-lineno"> 830</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-317" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-317', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'success!\n'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L831"></a><tt class="py-lineno"> 831</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._insert"></a><div id="BaseAdapter._insert-def"><a name="L832"></a><tt class="py-lineno"> 832</tt> <a class="py-toggle" href="#" id="BaseAdapter._insert-toggle" onclick="return toggle('BaseAdapter._insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_insert">_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._insert-expanded"><a name="L833"></a><tt class="py-lineno"> 833</tt>  <tt class="py-line">        <tt id="link-318" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-318', 'keys', 'link-269');">keys</a></tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-319" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-319', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt id="link-320" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-320', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L834"></a><tt class="py-lineno"> 834</tt>  <tt class="py-line">        <tt id="link-321" class="py-name" targets="Method web2py.gluon.rocket.Headers.values()=web2py.gluon.rocket.Headers-class.html#values"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-321', 'values', 'link-321');">values</a></tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-322" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-322', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-323" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-323', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L835"></a><tt class="py-lineno"> 835</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'INSERT INTO %s(%s) VALUES (%s);'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt id="link-324" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-324', 'keys', 'link-269');">keys</a></tt><tt class="py-op">,</tt> <tt id="link-325" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-325', 'values', 'link-321');">values</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L836"></a><tt class="py-lineno"> 836</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.insert"></a><div id="BaseAdapter.insert-def"><a name="L837"></a><tt class="py-lineno"> 837</tt> <a class="py-toggle" href="#" id="BaseAdapter.insert-toggle" onclick="return toggle('BaseAdapter.insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#insert">insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.insert-expanded"><a name="L838"></a><tt class="py-lineno"> 838</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-326" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._insert()=web2py.gluon.dal.BaseAdapter-class.html#_insert,Method web2py.gluon.dal.NoSQLAdapter._insert()=web2py.gluon.dal.NoSQLAdapter-class.html#_insert,Method web2py.gluon.dal.Table._insert()=web2py.gluon.dal.Table-class.html#_insert,Method web2py.gluon.template.Content._insert()=web2py.gluon.template.Content-class.html#_insert"><a title="web2py.gluon.dal.BaseAdapter._insert
web2py.gluon.dal.NoSQLAdapter._insert
web2py.gluon.dal.Table._insert
web2py.gluon.template.Content._insert" class="py-name" href="#" onclick="return doclink('link-326', '_insert', 'link-326');">_insert</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L839"></a><tt class="py-lineno"> 839</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L840"></a><tt class="py-lineno"> 840</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-327" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-327', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L841"></a><tt class="py-lineno"> 841</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt> <tt id="link-328" class="py-name" targets="Class exceptions.Exception=exceptions.Exception-class.html"><a title="exceptions.Exception" class="py-name" href="#" onclick="return doclink('link-328', 'Exception', 'link-328');">Exception</a></tt><tt class="py-op">,</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt>
<a name="L842"></a><tt class="py-lineno"> 842</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">e</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-329" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.integrity_error_class()=web2py.gluon.dal.BaseAdapter-class.html#integrity_error_class,Method web2py.gluon.dal.InformixAdapter.integrity_error_class()=web2py.gluon.dal.InformixAdapter-class.html#integrity_error_class,Method web2py.gluon.dal.IngresAdapter.integrity_error_class()=web2py.gluon.dal.IngresAdapter-class.html#integrity_error_class,Method web2py.gluon.dal.MSSQLAdapter.integrity_error_class()=web2py.gluon.dal.MSSQLAdapter-class.html#integrity_error_class,Method web2py.gluon.dal.NoSQLAdapter.integrity_error_class()=web2py.gluon.dal.NoSQLAdapter-class.html#integrity_error_class"><a title="web2py.gluon.dal.BaseAdapter.integrity_error_class
web2py.gluon.dal.InformixAdapter.integrity_error_class
web2py.gluon.dal.IngresAdapter.integrity_error_class
web2py.gluon.dal.MSSQLAdapter.integrity_error_class
web2py.gluon.dal.NoSQLAdapter.integrity_error_class" class="py-name" href="#" onclick="return doclink('link-329', 'integrity_error_class', 'link-329');">integrity_error_class</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L843"></a><tt class="py-lineno"> 843</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L844"></a><tt class="py-lineno"> 844</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">e</tt> </tt>
<a name="L845"></a><tt class="py-lineno"> 845</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L846"></a><tt class="py-lineno"> 846</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">(</tt><tt id="link-330" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-330', 'k', 'link-189');">k</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-331" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-331', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt id="link-332" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-332', 'k', 'link-189');">k</a></tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-333" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-333', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt> \ </tt>
<a name="L847"></a><tt class="py-lineno"> 847</tt>  <tt class="py-line">                             <tt class="py-keyword">if</tt> <tt id="link-334" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-334', 'k', 'link-189');">k</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-335" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-335', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L848"></a><tt class="py-lineno"> 848</tt>  <tt class="py-line">        <tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-336" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.lastrowid
web2py.gluon.dal.DB2Adapter.lastrowid
web2py.gluon.dal.FireBirdAdapter.lastrowid
web2py.gluon.dal.InformixAdapter.lastrowid
web2py.gluon.dal.IngresAdapter.lastrowid
web2py.gluon.dal.MSSQLAdapter.lastrowid
web2py.gluon.dal.MySQLAdapter.lastrowid
web2py.gluon.dal.NoSQLAdapter.lastrowid
web2py.gluon.dal.OracleAdapter.lastrowid
web2py.gluon.dal.PostgreSQLAdapter.lastrowid
web2py.gluon.dal.SAPDBAdapter.lastrowid
web2py.gluon.dal.SQLiteAdapter.lastrowid" class="py-name" href="#" onclick="return doclink('link-336', 'lastrowid', 'link-187');">lastrowid</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">)</tt> </tt>
<a name="L849"></a><tt class="py-lineno"> 849</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">,</tt><tt class="py-name">int</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L850"></a><tt class="py-lineno"> 850</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">id</tt> </tt>
<a name="L851"></a><tt class="py-lineno"> 851</tt>  <tt class="py-line">        <tt class="py-name">rid</tt> <tt class="py-op">=</tt> <tt id="link-337" class="py-name" targets="Class web2py.gluon.dal.Reference=web2py.gluon.dal.Reference-class.html"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-337', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">)</tt> </tt>
<a name="L852"></a><tt class="py-lineno"> 852</tt>  <tt class="py-line">        <tt class="py-op">(</tt><tt class="py-name">rid</tt><tt class="py-op">.</tt><tt class="py-name">_table</tt><tt class="py-op">,</tt> <tt class="py-name">rid</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L853"></a><tt class="py-lineno"> 853</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">rid</tt> </tt>
</div><a name="L854"></a><tt class="py-lineno"> 854</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.bulk_insert"></a><div id="BaseAdapter.bulk_insert-def"><a name="L855"></a><tt class="py-lineno"> 855</tt> <a class="py-toggle" href="#" id="BaseAdapter.bulk_insert-toggle" onclick="return toggle('BaseAdapter.bulk_insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#bulk_insert">bulk_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">items</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.bulk_insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.bulk_insert-expanded"><a name="L856"></a><tt class="py-lineno"> 856</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-338" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.insert()=web2py.gluon.dal.BaseAdapter-class.html#insert,Method web2py.gluon.dal.CouchDBAdapter.insert()=web2py.gluon.dal.CouchDBAdapter-class.html#insert,Method web2py.gluon.dal.GoogleDatastoreAdapter.insert()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#insert,Method web2py.gluon.dal.MongoDBAdapter.insert()=web2py.gluon.dal.MongoDBAdapter-class.html#insert,Method web2py.gluon.dal.Table.insert()=web2py.gluon.dal.Table-class.html#insert,Method web2py.gluon.html.DIV.insert()=web2py.gluon.html.DIV-class.html#insert,Method web2py.gluon.template.Content.insert()=web2py.gluon.template.Content-class.html#insert"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-338', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-339" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-339', 'items', 'link-266');">items</a></tt><tt class="py-op">]</tt> </tt>
</div><a name="L857"></a><tt class="py-lineno"> 857</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.NOT"></a><div id="BaseAdapter.NOT-def"><a name="L858"></a><tt class="py-lineno"> 858</tt> <a class="py-toggle" href="#" id="BaseAdapter.NOT-toggle" onclick="return toggle('BaseAdapter.NOT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#NOT">NOT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.NOT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.NOT-expanded"><a name="L859"></a><tt class="py-lineno"> 859</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(NOT %s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-340" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-340', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-341" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-341', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L860"></a><tt class="py-lineno"> 860</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.AND"></a><div id="BaseAdapter.AND-def"><a name="L861"></a><tt class="py-lineno"> 861</tt> <a class="py-toggle" href="#" id="BaseAdapter.AND-toggle" onclick="return toggle('BaseAdapter.AND');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#AND">AND</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.AND-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.AND-expanded"><a name="L862"></a><tt class="py-lineno"> 862</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s AND %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-342" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-342', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-343" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-343', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-344" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-344', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L863"></a><tt class="py-lineno"> 863</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.OR"></a><div id="BaseAdapter.OR-def"><a name="L864"></a><tt class="py-lineno"> 864</tt> <a class="py-toggle" href="#" id="BaseAdapter.OR-toggle" onclick="return toggle('BaseAdapter.OR');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#OR">OR</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.OR-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.OR-expanded"><a name="L865"></a><tt class="py-lineno"> 865</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s OR %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-345" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-345', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-346" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-346', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-347" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-347', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L866"></a><tt class="py-lineno"> 866</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.BELONGS"></a><div id="BaseAdapter.BELONGS-def"><a name="L867"></a><tt class="py-lineno"> 867</tt> <a class="py-toggle" href="#" id="BaseAdapter.BELONGS-toggle" onclick="return toggle('BaseAdapter.BELONGS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#BELONGS">BELONGS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.BELONGS-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.BELONGS-expanded"><a name="L868"></a><tt class="py-lineno"> 868</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L869"></a><tt class="py-lineno"> 869</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'(%s IN (%s))'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-348" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-348', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-349" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-349', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L870"></a><tt class="py-lineno"> 870</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">second</tt><tt class="py-op">==</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-name">second</tt><tt class="py-op">==</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L871"></a><tt class="py-lineno"> 871</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'(0)'</tt> </tt>
<a name="L872"></a><tt class="py-lineno"> 872</tt>  <tt class="py-line">        <tt id="link-350" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-350', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt><tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-351" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-351', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-352" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-352', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt id="link-353" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-353', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">second</tt><tt class="py-op">)</tt> </tt>
<a name="L873"></a><tt class="py-lineno"> 873</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s IN (%s))'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-354" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-354', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-355" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-355', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt id="link-356" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-356', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L874"></a><tt class="py-lineno"> 874</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.LIKE"></a><div id="BaseAdapter.LIKE-def"><a name="L875"></a><tt class="py-lineno"> 875</tt> <a class="py-toggle" href="#" id="BaseAdapter.LIKE-toggle" onclick="return toggle('BaseAdapter.LIKE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#LIKE">LIKE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.LIKE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.LIKE-expanded"><a name="L876"></a><tt class="py-lineno"> 876</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s LIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-357" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-357', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-358" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-358', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-359" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-359', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L877"></a><tt class="py-lineno"> 877</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.STARTSWITH"></a><div id="BaseAdapter.STARTSWITH-def"><a name="L878"></a><tt class="py-lineno"> 878</tt> <a class="py-toggle" href="#" id="BaseAdapter.STARTSWITH-toggle" onclick="return toggle('BaseAdapter.STARTSWITH');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#STARTSWITH">STARTSWITH</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.STARTSWITH-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.STARTSWITH-expanded"><a name="L879"></a><tt class="py-lineno"> 879</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s LIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-360" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-360', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-361" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-361', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-362" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-362', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">+</tt><tt class="py-string">'%'</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L880"></a><tt class="py-lineno"> 880</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.ENDSWITH"></a><div id="BaseAdapter.ENDSWITH-def"><a name="L881"></a><tt class="py-lineno"> 881</tt> <a class="py-toggle" href="#" id="BaseAdapter.ENDSWITH-toggle" onclick="return toggle('BaseAdapter.ENDSWITH');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#ENDSWITH">ENDSWITH</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.ENDSWITH-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.ENDSWITH-expanded"><a name="L882"></a><tt class="py-lineno"> 882</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s LIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-363" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-363', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-364" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-364', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-365" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-365', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-string">'%'</tt><tt class="py-op">+</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L883"></a><tt class="py-lineno"> 883</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.CONTAINS"></a><div id="BaseAdapter.CONTAINS-def"><a name="L884"></a><tt class="py-lineno"> 884</tt> <a class="py-toggle" href="#" id="BaseAdapter.CONTAINS-toggle" onclick="return toggle('BaseAdapter.CONTAINS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#CONTAINS">CONTAINS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.CONTAINS-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.CONTAINS-expanded"><a name="L885"></a><tt class="py-lineno"> 885</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-366" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-366', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt><tt class="py-string">'text'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L886"></a><tt class="py-lineno"> 886</tt>  <tt class="py-line">            <tt class="py-name">key</tt> <tt class="py-op">=</tt> <tt class="py-string">'%'</tt><tt class="py-op">+</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'%'</tt><tt class="py-op">,</tt><tt class="py-string">'%%'</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">'%'</tt> </tt>
<a name="L887"></a><tt class="py-lineno"> 887</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt id="link-367" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-367', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-368" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-368', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L888"></a><tt class="py-lineno"> 888</tt>  <tt class="py-line">            <tt class="py-name">key</tt> <tt class="py-op">=</tt> <tt class="py-string">'%|'</tt><tt class="py-op">+</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'|'</tt><tt class="py-op">,</tt><tt class="py-string">'||'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'%'</tt><tt class="py-op">,</tt><tt class="py-string">'%%'</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">'|%'</tt> </tt>
<a name="L889"></a><tt class="py-lineno"> 889</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s LIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-369" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-369', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-370" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-370', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-371" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-371', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L890"></a><tt class="py-lineno"> 890</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.EQ"></a><div id="BaseAdapter.EQ-def"><a name="L891"></a><tt class="py-lineno"> 891</tt> <a class="py-toggle" href="#" id="BaseAdapter.EQ-toggle" onclick="return toggle('BaseAdapter.EQ');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#EQ">EQ</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.EQ-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.EQ-expanded"><a name="L892"></a><tt class="py-lineno"> 892</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">second</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L893"></a><tt class="py-lineno"> 893</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'(%s IS NULL)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-372" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-372', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-373" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-373', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L894"></a><tt class="py-lineno"> 894</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s = %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-374" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-374', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-375" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-375', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-376" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-376', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-377" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-377', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L895"></a><tt class="py-lineno"> 895</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.NE"></a><div id="BaseAdapter.NE-def"><a name="L896"></a><tt class="py-lineno"> 896</tt> <a class="py-toggle" href="#" id="BaseAdapter.NE-toggle" onclick="return toggle('BaseAdapter.NE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#NE">NE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.NE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.NE-expanded"><a name="L897"></a><tt class="py-lineno"> 897</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">second</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L898"></a><tt class="py-lineno"> 898</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'(%s IS NOT NULL)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-378" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-378', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-379" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-379', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L899"></a><tt class="py-lineno"> 899</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s &lt;&gt; %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-380" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-380', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-381" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-381', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-382" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-382', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-383" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-383', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L900"></a><tt class="py-lineno"> 900</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.LT"></a><div id="BaseAdapter.LT-def"><a name="L901"></a><tt class="py-lineno"> 901</tt> <a class="py-toggle" href="#" id="BaseAdapter.LT-toggle" onclick="return toggle('BaseAdapter.LT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#LT">LT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.LT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.LT-expanded"><a name="L902"></a><tt class="py-lineno"> 902</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s &lt; %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-384" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-384', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-385" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-385', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-386" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-386', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-387" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-387', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L903"></a><tt class="py-lineno"> 903</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.LE"></a><div id="BaseAdapter.LE-def"><a name="L904"></a><tt class="py-lineno"> 904</tt> <a class="py-toggle" href="#" id="BaseAdapter.LE-toggle" onclick="return toggle('BaseAdapter.LE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#LE">LE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.LE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.LE-expanded"><a name="L905"></a><tt class="py-lineno"> 905</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s &lt;= %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-388" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-388', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-389" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-389', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-390" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-390', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-391" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-391', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L906"></a><tt class="py-lineno"> 906</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.GT"></a><div id="BaseAdapter.GT-def"><a name="L907"></a><tt class="py-lineno"> 907</tt> <a class="py-toggle" href="#" id="BaseAdapter.GT-toggle" onclick="return toggle('BaseAdapter.GT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#GT">GT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.GT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.GT-expanded"><a name="L908"></a><tt class="py-lineno"> 908</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s &gt; %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-392" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-392', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-393" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-393', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-394" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-394', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-395" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-395', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L909"></a><tt class="py-lineno"> 909</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.GE"></a><div id="BaseAdapter.GE-def"><a name="L910"></a><tt class="py-lineno"> 910</tt> <a class="py-toggle" href="#" id="BaseAdapter.GE-toggle" onclick="return toggle('BaseAdapter.GE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#GE">GE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.GE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.GE-expanded"><a name="L911"></a><tt class="py-lineno"> 911</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s &gt;= %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-396" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-396', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-397" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-397', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-398" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-398', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-399" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-399', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L912"></a><tt class="py-lineno"> 912</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.ADD"></a><div id="BaseAdapter.ADD-def"><a name="L913"></a><tt class="py-lineno"> 913</tt> <a class="py-toggle" href="#" id="BaseAdapter.ADD-toggle" onclick="return toggle('BaseAdapter.ADD');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#ADD">ADD</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.ADD-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.ADD-expanded"><a name="L914"></a><tt class="py-lineno"> 914</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s + %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-400" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-400', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-401" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-401', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-402" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-402', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-403" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-403', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L915"></a><tt class="py-lineno"> 915</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.SUB"></a><div id="BaseAdapter.SUB-def"><a name="L916"></a><tt class="py-lineno"> 916</tt> <a class="py-toggle" href="#" id="BaseAdapter.SUB-toggle" onclick="return toggle('BaseAdapter.SUB');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#SUB">SUB</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.SUB-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.SUB-expanded"><a name="L917"></a><tt class="py-lineno"> 917</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s - %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-404" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-404', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-405" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-405', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-406" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-406', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-407" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-407', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L918"></a><tt class="py-lineno"> 918</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.MUL"></a><div id="BaseAdapter.MUL-def"><a name="L919"></a><tt class="py-lineno"> 919</tt> <a class="py-toggle" href="#" id="BaseAdapter.MUL-toggle" onclick="return toggle('BaseAdapter.MUL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#MUL">MUL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.MUL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.MUL-expanded"><a name="L920"></a><tt class="py-lineno"> 920</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s * %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-408" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-408', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-409" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-409', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-410" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-410', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-411" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-411', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L921"></a><tt class="py-lineno"> 921</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.DIV"></a><div id="BaseAdapter.DIV-def"><a name="L922"></a><tt class="py-lineno"> 922</tt> <a class="py-toggle" href="#" id="BaseAdapter.DIV-toggle" onclick="return toggle('BaseAdapter.DIV');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#DIV">DIV</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.DIV-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.DIV-expanded"><a name="L923"></a><tt class="py-lineno"> 923</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s / %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-412" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-412', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-413" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-413', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-414" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-414', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-415" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-415', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L924"></a><tt class="py-lineno"> 924</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.MOD"></a><div id="BaseAdapter.MOD-def"><a name="L925"></a><tt class="py-lineno"> 925</tt> <a class="py-toggle" href="#" id="BaseAdapter.MOD-toggle" onclick="return toggle('BaseAdapter.MOD');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#MOD">MOD</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.MOD-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.MOD-expanded"><a name="L926"></a><tt class="py-lineno"> 926</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s %% %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-416" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-416', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-417" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-417', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-418" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-418', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-419" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-419', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L927"></a><tt class="py-lineno"> 927</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.AS"></a><div id="BaseAdapter.AS-def"><a name="L928"></a><tt class="py-lineno"> 928</tt> <a class="py-toggle" href="#" id="BaseAdapter.AS-toggle" onclick="return toggle('BaseAdapter.AS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#AS">AS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.AS-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.AS-expanded"><a name="L929"></a><tt class="py-lineno"> 929</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s AS %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-420" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-420', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-421" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-421', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">)</tt> </tt>
</div><a name="L930"></a><tt class="py-lineno"> 930</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.ON"></a><div id="BaseAdapter.ON-def"><a name="L931"></a><tt class="py-lineno"> 931</tt> <a class="py-toggle" href="#" id="BaseAdapter.ON-toggle" onclick="return toggle('BaseAdapter.ON');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#ON">ON</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.ON-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.ON-expanded"><a name="L932"></a><tt class="py-lineno"> 932</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s ON %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-422" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-422', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-423" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-423', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-424" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-424', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L933"></a><tt class="py-lineno"> 933</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.INVERT"></a><div id="BaseAdapter.INVERT-def"><a name="L934"></a><tt class="py-lineno"> 934</tt> <a class="py-toggle" href="#" id="BaseAdapter.INVERT-toggle" onclick="return toggle('BaseAdapter.INVERT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#INVERT">INVERT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.INVERT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.INVERT-expanded"><a name="L935"></a><tt class="py-lineno"> 935</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s DESC'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-425" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-425', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-426" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-426', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L936"></a><tt class="py-lineno"> 936</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.COMMA"></a><div id="BaseAdapter.COMMA-def"><a name="L937"></a><tt class="py-lineno"> 937</tt> <a class="py-toggle" href="#" id="BaseAdapter.COMMA-toggle" onclick="return toggle('BaseAdapter.COMMA');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#COMMA">COMMA</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.COMMA-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.COMMA-expanded"><a name="L938"></a><tt class="py-lineno"> 938</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s, %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-427" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-427', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-428" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-428', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-429" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-429', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L939"></a><tt class="py-lineno"> 939</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.expand"></a><div id="BaseAdapter.expand-def"><a name="L940"></a><tt class="py-lineno"> 940</tt> <a class="py-toggle" href="#" id="BaseAdapter.expand-toggle" onclick="return toggle('BaseAdapter.expand');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#expand">expand</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">expression</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.expand-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.expand-expanded"><a name="L941"></a><tt class="py-lineno"> 941</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt id="link-430" class="py-name" targets="Class web2py.gluon.dal.Field=web2py.gluon.dal.Field-class.html"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-430', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L942"></a><tt class="py-lineno"> 942</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">)</tt> </tt>
<a name="L943"></a><tt class="py-lineno"> 943</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-431" class="py-name" targets="Class web2py.gluon.dal.Expression=web2py.gluon.dal.Expression-class.html"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-431', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">,</tt> <tt id="link-432" class="py-name" targets="Class web2py.gluon.dal.Query=web2py.gluon.dal.Query-class.html"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-432', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L944"></a><tt class="py-lineno"> 944</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L945"></a><tt class="py-lineno"> 945</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-433" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-433', 'first', 'link-297');">first</a></tt><tt class="py-op">,</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">second</tt><tt class="py-op">)</tt> </tt>
<a name="L946"></a><tt class="py-lineno"> 946</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-434" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-434', 'first', 'link-297');">first</a></tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L947"></a><tt class="py-lineno"> 947</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-435" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-435', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L948"></a><tt class="py-lineno"> 948</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L949"></a><tt class="py-lineno"> 949</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L950"></a><tt class="py-lineno"> 950</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">:</tt> </tt>
<a name="L951"></a><tt class="py-lineno"> 951</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-436" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-436', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
<a name="L952"></a><tt class="py-lineno"> 952</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt><tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L953"></a><tt class="py-lineno"> 953</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-437" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-437', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-438" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-438', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">expression</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L954"></a><tt class="py-lineno"> 954</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L955"></a><tt class="py-lineno"> 955</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">)</tt> </tt>
</div><a name="L956"></a><tt class="py-lineno"> 956</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.alias"></a><div id="BaseAdapter.alias-def"><a name="L957"></a><tt class="py-lineno"> 957</tt> <a class="py-toggle" href="#" id="BaseAdapter.alias-toggle" onclick="return toggle('BaseAdapter.alias');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#alias">alias</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">alias</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.alias-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.alias-expanded"><a name="L958"></a><tt class="py-lineno"> 958</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L959"></a><tt class="py-lineno"> 959</tt>  <tt class="py-line"><tt class="py-docstring">        given a table object, makes a new table object</tt> </tt>
<a name="L960"></a><tt class="py-lineno"> 960</tt>  <tt class="py-line"><tt class="py-docstring">        with alias name.</tt> </tt>
<a name="L961"></a><tt class="py-lineno"> 961</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L962"></a><tt class="py-lineno"> 962</tt>  <tt class="py-line">        <tt class="py-name">other</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">)</tt> </tt>
<a name="L963"></a><tt class="py-lineno"> 963</tt>  <tt class="py-line">        <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-string">'_ot'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">other</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L964"></a><tt class="py-lineno"> 964</tt>  <tt class="py-line">        <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-string">'ALL'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-439" class="py-name" targets="Class web2py.gluon.dal.SQLALL=web2py.gluon.dal.SQLALL-class.html"><a title="web2py.gluon.dal.SQLALL" class="py-name" href="#" onclick="return doclink('link-439', 'SQLALL', 'link-439');">SQLALL</a></tt><tt class="py-op">(</tt><tt class="py-name">other</tt><tt class="py-op">)</tt> </tt>
<a name="L965"></a><tt class="py-lineno"> 965</tt>  <tt class="py-line">        <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-string">'_tablename'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-440" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.alias()=web2py.gluon.dal.BaseAdapter-class.html#alias,Method web2py.gluon.dal.NoSQLAdapter.alias()=web2py.gluon.dal.NoSQLAdapter-class.html#alias"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-440', 'alias', 'link-440');">alias</a></tt> </tt>
<a name="L966"></a><tt class="py-lineno"> 966</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">fieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">other</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L967"></a><tt class="py-lineno"> 967</tt>  <tt class="py-line">            <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L968"></a><tt class="py-lineno"> 968</tt>  <tt class="py-line">            <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-op">=</tt> <tt id="link-441" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-441', 'alias', 'link-440');">alias</a></tt> </tt>
<a name="L969"></a><tt class="py-lineno"> 969</tt>  <tt class="py-line">            <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt id="link-442" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-442', 'alias', 'link-440');">alias</a></tt> </tt>
<a name="L970"></a><tt class="py-lineno"> 970</tt>  <tt class="py-line">            <tt class="py-name">other</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">other</tt> </tt>
<a name="L971"></a><tt class="py-lineno"> 971</tt>  <tt class="py-line">        <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt id="link-443" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-443', 'alias', 'link-440');">alias</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">other</tt> </tt>
<a name="L972"></a><tt class="py-lineno"> 972</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">other</tt> </tt>
</div><a name="L973"></a><tt class="py-lineno"> 973</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._truncate"></a><div id="BaseAdapter._truncate-def"><a name="L974"></a><tt class="py-lineno"> 974</tt> <a class="py-toggle" href="#" id="BaseAdapter._truncate-toggle" onclick="return toggle('BaseAdapter._truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_truncate">_truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._truncate-expanded"><a name="L975"></a><tt class="py-lineno"> 975</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L976"></a><tt class="py-lineno"> 976</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'TRUNCATE TABLE %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt> <tt class="py-keyword">or</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L977"></a><tt class="py-lineno"> 977</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.truncate"></a><div id="BaseAdapter.truncate-def"><a name="L978"></a><tt class="py-lineno"> 978</tt> <a class="py-toggle" href="#" id="BaseAdapter.truncate-toggle" onclick="return toggle('BaseAdapter.truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#truncate">truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">=</tt> <tt class="py-string">' '</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.truncate-expanded"><a name="L979"></a><tt class="py-lineno"> 979</tt>  <tt class="py-line">        <tt class="py-comment"># Prepare functions "write_to_logfile" and "close_logfile"</tt> </tt>
<a name="L980"></a><tt class="py-lineno"> 980</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt><tt class="py-op">:</tt> </tt>
<a name="L981"></a><tt class="py-lineno"> 981</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-444" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-444', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_loggername</tt><tt class="py-op">,</tt> <tt class="py-string">'a'</tt><tt class="py-op">)</tt> </tt>
<a name="L982"></a><tt class="py-lineno"> 982</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L983"></a><tt class="py-lineno"> 983</tt>  <tt class="py-line">            <tt class="py-keyword">class</tt> <tt class="py-def-name">Logfile</tt><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L984"></a><tt class="py-lineno"> 984</tt>  <tt class="py-line">                <tt class="py-keyword">def</tt> <tt class="py-def-name">write</tt><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L985"></a><tt class="py-lineno"> 985</tt>  <tt class="py-line">                    <tt class="py-keyword">pass</tt> </tt>
</div><a name="L986"></a><tt class="py-lineno"> 986</tt>  <tt class="py-line">                <tt class="py-keyword">def</tt> <tt class="py-def-name">close</tt><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L987"></a><tt class="py-lineno"> 987</tt>  <tt class="py-line">                    <tt class="py-keyword">pass</tt> </tt>
</div></div><a name="L988"></a><tt class="py-lineno"> 988</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt> <tt class="py-op">=</tt> <tt class="py-name">Logfile</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L989"></a><tt class="py-lineno"> 989</tt>  <tt class="py-line"> </tt>
<a name="L990"></a><tt class="py-lineno"> 990</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L991"></a><tt class="py-lineno"> 991</tt>  <tt class="py-line">            <tt class="py-name">queries</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-445" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._truncate()=web2py.gluon.dal.BaseAdapter-class.html#_truncate,Method web2py.gluon.dal.FireBirdAdapter._truncate()=web2py.gluon.dal.FireBirdAdapter-class.html#_truncate,Method web2py.gluon.dal.SQLiteAdapter._truncate()=web2py.gluon.dal.SQLiteAdapter-class.html#_truncate,Method web2py.gluon.dal.Table._truncate()=web2py.gluon.dal.Table-class.html#_truncate"><a title="web2py.gluon.dal.BaseAdapter._truncate
web2py.gluon.dal.FireBirdAdapter._truncate
web2py.gluon.dal.SQLiteAdapter._truncate
web2py.gluon.dal.Table._truncate" class="py-name" href="#" onclick="return doclink('link-445', '_truncate', 'link-445');">_truncate</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
<a name="L992"></a><tt class="py-lineno"> 992</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">query</tt> <tt class="py-keyword">in</tt> <tt class="py-name">queries</tt><tt class="py-op">:</tt> </tt>
<a name="L993"></a><tt class="py-lineno"> 993</tt>  <tt class="py-line">                <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-446" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-446', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt> <tt class="py-op">+</tt> <tt class="py-string">'\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L994"></a><tt class="py-lineno"> 994</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-447" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-447', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L995"></a><tt class="py-lineno"> 995</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-448" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-448', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L996"></a><tt class="py-lineno"> 996</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-449" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-449', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'success!\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L997"></a><tt class="py-lineno"> 997</tt>  <tt class="py-line">        <tt class="py-keyword">finally</tt><tt class="py-op">:</tt> </tt>
<a name="L998"></a><tt class="py-lineno"> 998</tt>  <tt class="py-line">            <tt class="py-name">logfile</tt><tt class="py-op">.</tt><tt id="link-450" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-450', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L999"></a><tt class="py-lineno"> 999</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._update"></a><div id="BaseAdapter._update-def"><a name="L1000"></a><tt class="py-lineno">1000</tt> <a class="py-toggle" href="#" id="BaseAdapter._update-toggle" onclick="return toggle('BaseAdapter._update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_update">_update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._update-expanded"><a name="L1001"></a><tt class="py-lineno">1001</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L1002"></a><tt class="py-lineno">1002</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">' WHERE '</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-451" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-451', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1003"></a><tt class="py-lineno">1003</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1004"></a><tt class="py-lineno">1004</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1005"></a><tt class="py-lineno">1005</tt>  <tt class="py-line">        <tt class="py-name">sql_v</tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-452" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-452', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">'%s=%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-453" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-453', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-454" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-454', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1006"></a><tt class="py-lineno">1006</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'UPDATE %s SET %s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">sql_v</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1007"></a><tt class="py-lineno">1007</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.update"></a><div id="BaseAdapter.update-def"><a name="L1008"></a><tt class="py-lineno">1008</tt> <a class="py-toggle" href="#" id="BaseAdapter.update-toggle" onclick="return toggle('BaseAdapter.update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#update">update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.update-expanded"><a name="L1009"></a><tt class="py-lineno">1009</tt>  <tt class="py-line">        <tt id="link-455" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-455', 'sql', 'link-88');">sql</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-456" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._update()=web2py.gluon.dal.BaseAdapter-class.html#_update,Method web2py.gluon.dal.NoSQLAdapter._update()=web2py.gluon.dal.NoSQLAdapter-class.html#_update,Method web2py.gluon.dal.Set._update()=web2py.gluon.dal.Set-class.html#_update"><a title="web2py.gluon.dal.BaseAdapter._update
web2py.gluon.dal.NoSQLAdapter._update
web2py.gluon.dal.Set._update" class="py-name" href="#" onclick="return doclink('link-456', '_update', 'link-456');">_update</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L1010"></a><tt class="py-lineno">1010</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-457" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-457', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt id="link-458" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-458', 'sql', 'link-88');">sql</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1011"></a><tt class="py-lineno">1011</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L1012"></a><tt class="py-lineno">1012</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">rowcount</tt> </tt>
<a name="L1013"></a><tt class="py-lineno">1013</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L1014"></a><tt class="py-lineno">1014</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L1015"></a><tt class="py-lineno">1015</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._delete"></a><div id="BaseAdapter._delete-def"><a name="L1016"></a><tt class="py-lineno">1016</tt> <a class="py-toggle" href="#" id="BaseAdapter._delete-toggle" onclick="return toggle('BaseAdapter._delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_delete">_delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._delete-expanded"><a name="L1017"></a><tt class="py-lineno">1017</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L1018"></a><tt class="py-lineno">1018</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">' WHERE '</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-459" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-459', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1019"></a><tt class="py-lineno">1019</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1020"></a><tt class="py-lineno">1020</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1021"></a><tt class="py-lineno">1021</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'DELETE FROM %s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1022"></a><tt class="py-lineno">1022</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.delete"></a><div id="BaseAdapter.delete-def"><a name="L1023"></a><tt class="py-lineno">1023</tt> <a class="py-toggle" href="#" id="BaseAdapter.delete-toggle" onclick="return toggle('BaseAdapter.delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#delete">delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.delete-expanded"><a name="L1024"></a><tt class="py-lineno">1024</tt>  <tt class="py-line">        <tt id="link-460" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-460', 'sql', 'link-88');">sql</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-461" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._delete()=web2py.gluon.dal.BaseAdapter-class.html#_delete,Method web2py.gluon.dal.NoSQLAdapter._delete()=web2py.gluon.dal.NoSQLAdapter-class.html#_delete,Method web2py.gluon.dal.Set._delete()=web2py.gluon.dal.Set-class.html#_delete"><a title="web2py.gluon.dal.BaseAdapter._delete
web2py.gluon.dal.NoSQLAdapter._delete
web2py.gluon.dal.Set._delete" class="py-name" href="#" onclick="return doclink('link-461', '_delete', 'link-461');">_delete</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1025"></a><tt class="py-lineno">1025</tt>  <tt class="py-line">        <tt class="py-comment">### special code to handle CASCADE in SQLite</tt> </tt>
<a name="L1026"></a><tt class="py-lineno">1026</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> </tt>
<a name="L1027"></a><tt class="py-lineno">1027</tt>  <tt class="py-line">        <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L1028"></a><tt class="py-lineno">1028</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'sqlite'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt><tt class="py-op">:</tt> </tt>
<a name="L1029"></a><tt class="py-lineno">1029</tt>  <tt class="py-line">            <tt class="py-name">deleted</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt id="link-462" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-462', 'x', 'link-114');">x</a></tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-463" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-463', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt id="link-464" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-464', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-465" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.select()=web2py.gluon.dal.BaseAdapter-class.html#select,Method web2py.gluon.dal.CouchDBAdapter.select()=web2py.gluon.dal.CouchDBAdapter-class.html#select,Method web2py.gluon.dal.GoogleDatastoreAdapter.select()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#select,Method web2py.gluon.dal.MongoDBAdapter.select()=web2py.gluon.dal.MongoDBAdapter-class.html#select,Method web2py.gluon.dal.Set.select()=web2py.gluon.dal.Set-class.html#select,Method web2py.gluon.tools.Crud.select()=web2py.gluon.tools.Crud-class.html#select"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-465', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L1030"></a><tt class="py-lineno">1030</tt>  <tt class="py-line">        <tt class="py-comment">### end special code to handle CASCADE in SQLite</tt> </tt>
<a name="L1031"></a><tt class="py-lineno">1031</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-466" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-466', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt id="link-467" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-467', 'sql', 'link-88');">sql</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1032"></a><tt class="py-lineno">1032</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L1033"></a><tt class="py-lineno">1033</tt>  <tt class="py-line">            <tt class="py-name">counter</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">rowcount</tt> </tt>
<a name="L1034"></a><tt class="py-lineno">1034</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L1035"></a><tt class="py-lineno">1035</tt>  <tt class="py-line">            <tt class="py-name">counter</tt> <tt class="py-op">=</tt>  <tt class="py-name">None</tt> </tt>
<a name="L1036"></a><tt class="py-lineno">1036</tt>  <tt class="py-line">        <tt class="py-comment">### special code to handle CASCADE in SQLite</tt> </tt>
<a name="L1037"></a><tt class="py-lineno">1037</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'sqlite'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">counter</tt><tt class="py-op">:</tt> </tt>
<a name="L1038"></a><tt class="py-lineno">1038</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">fieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt><tt class="py-op">:</tt> </tt>
<a name="L1039"></a><tt class="py-lineno">1039</tt>  <tt class="py-line">                <tt class="py-name">f</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> </tt>
<a name="L1040"></a><tt class="py-lineno">1040</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'reference '</tt><tt class="py-op">+</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-keyword">and</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">ondelete</tt><tt class="py-op">==</tt><tt class="py-string">'CASCADE'</tt><tt class="py-op">:</tt> </tt>
<a name="L1041"></a><tt class="py-lineno">1041</tt>  <tt class="py-line">                    <tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-468" class="py-name" targets="Method web2py.gluon.dal.Expression.belongs()=web2py.gluon.dal.Expression-class.html#belongs"><a title="web2py.gluon.dal.Expression.belongs" class="py-name" href="#" onclick="return doclink('link-468', 'belongs', 'link-468');">belongs</a></tt><tt class="py-op">(</tt><tt class="py-name">deleted</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-469" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.delete()=web2py.gluon.dal.BaseAdapter-class.html#delete,Method web2py.gluon.dal.CouchDBAdapter.delete()=web2py.gluon.dal.CouchDBAdapter-class.html#delete,Method web2py.gluon.dal.GoogleDatastoreAdapter.delete()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#delete,Method web2py.gluon.dal.MongoDBAdapter.delete()=web2py.gluon.dal.MongoDBAdapter-class.html#delete,Method web2py.gluon.dal.Set.delete()=web2py.gluon.dal.Set-class.html#delete,Method web2py.gluon.tools.Crud.delete()=web2py.gluon.tools.Crud-class.html#delete"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-469', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1042"></a><tt class="py-lineno">1042</tt>  <tt class="py-line">        <tt class="py-comment">### end special code to handle CASCADE in SQLite</tt> </tt>
<a name="L1043"></a><tt class="py-lineno">1043</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">return</tt> <tt class="py-name">counter</tt> </tt>
</div><a name="L1044"></a><tt class="py-lineno">1044</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.get_table"></a><div id="BaseAdapter.get_table-def"><a name="L1045"></a><tt class="py-lineno">1045</tt> <a class="py-toggle" href="#" id="BaseAdapter.get_table-toggle" onclick="return toggle('BaseAdapter.get_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#get_table">get_table</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.get_table-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.get_table-expanded"><a name="L1046"></a><tt class="py-lineno">1046</tt>  <tt class="py-line">        <tt class="py-name">tablenames</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-470" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-470', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1047"></a><tt class="py-lineno">1047</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-471" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-471', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tablenames</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
<a name="L1048"></a><tt class="py-lineno">1048</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">tablenames</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L1049"></a><tt class="py-lineno">1049</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt id="link-472" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-472', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tablenames</tt><tt class="py-op">)</tt><tt class="py-op">&lt;</tt><tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
<a name="L1050"></a><tt class="py-lineno">1050</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"No table selected"</tt> </tt>
<a name="L1051"></a><tt class="py-lineno">1051</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1052"></a><tt class="py-lineno">1052</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Too many tables selected"</tt> </tt>
</div><a name="L1053"></a><tt class="py-lineno">1053</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._select"></a><div id="BaseAdapter._select-def"><a name="L1054"></a><tt class="py-lineno">1054</tt> <a class="py-toggle" href="#" id="BaseAdapter._select-toggle" onclick="return toggle('BaseAdapter._select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_select">_select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">fields</tt><tt class="py-op">,</tt> <tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._select-expanded"><a name="L1055"></a><tt class="py-lineno">1055</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-473" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-473', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">-</tt><tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-string">'orderby'</tt><tt class="py-op">,</tt><tt class="py-string">'groupby'</tt><tt class="py-op">,</tt><tt class="py-string">'limitby'</tt><tt class="py-op">,</tt> </tt>
<a name="L1056"></a><tt class="py-lineno">1056</tt>  <tt class="py-line">                                               <tt class="py-string">'required'</tt><tt class="py-op">,</tt><tt class="py-string">'cache'</tt><tt class="py-op">,</tt><tt class="py-string">'left'</tt><tt class="py-op">,</tt> </tt>
<a name="L1057"></a><tt class="py-lineno">1057</tt>  <tt class="py-line">                                               <tt class="py-string">'distinct'</tt><tt class="py-op">,</tt><tt class="py-string">'having'</tt><tt class="py-op">,</tt> <tt class="py-string">'join'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1058"></a><tt class="py-lineno">1058</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'invalid select attribute: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
<a name="L1059"></a><tt class="py-lineno">1059</tt>  <tt class="py-line">        <tt class="py-comment"># ## if not fields specified take them all from the requested tables</tt> </tt>
<a name="L1060"></a><tt class="py-lineno">1060</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">new_fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L1061"></a><tt class="py-lineno">1061</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L1062"></a><tt class="py-lineno">1062</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt id="link-474" class="py-name"><a title="web2py.gluon.dal.SQLALL" class="py-name" href="#" onclick="return doclink('link-474', 'SQLALL', 'link-439');">SQLALL</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1063"></a><tt class="py-lineno">1063</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt> <tt class="py-op">+=</tt> <tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">table</tt> </tt>
<a name="L1064"></a><tt class="py-lineno">1064</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1065"></a><tt class="py-lineno">1065</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-475" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-475', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> </tt>
<a name="L1066"></a><tt class="py-lineno">1066</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">new_fields</tt> </tt>
<a name="L1067"></a><tt class="py-lineno">1067</tt>  <tt class="py-line">        <tt class="py-name">tablenames</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-476" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-476', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1068"></a><tt class="py-lineno">1068</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-477" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.filter_tenant()=web2py.gluon.dal.BaseAdapter-class.html#filter_tenant"><a title="web2py.gluon.dal.BaseAdapter.filter_tenant" class="py-name" href="#" onclick="return doclink('link-477', 'filter_tenant', 'link-477');">filter_tenant</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">tablenames</tt><tt class="py-op">)</tt> </tt>
<a name="L1069"></a><tt class="py-lineno">1069</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L1070"></a><tt class="py-lineno">1070</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">table</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt><tt class="py-op">:</tt> </tt>
<a name="L1071"></a><tt class="py-lineno">1071</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L1072"></a><tt class="py-lineno">1072</tt>  <tt class="py-line">                    <tt class="py-name">fields</tt><tt class="py-op">.</tt><tt id="link-478" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-478', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L1073"></a><tt class="py-lineno">1073</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1074"></a><tt class="py-lineno">1074</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L1075"></a><tt class="py-lineno">1075</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt><tt class="py-name">basestring</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt id="link-479" class="py-name"><a title="web2py.gluon.dal.table_field
web2py.gluon.sqlhtml.table_field" class="py-name" href="#" onclick="return doclink('link-479', 'table_field', 'link-29');">table_field</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1076"></a><tt class="py-lineno">1076</tt>  <tt class="py-line">                    <tt class="py-name">tn</tt><tt class="py-op">,</tt><tt class="py-name">fn</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L1077"></a><tt class="py-lineno">1077</tt>  <tt class="py-line">                    <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tn</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">fn</tt><tt class="py-op">]</tt> </tt>
<a name="L1078"></a><tt class="py-lineno">1078</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-480" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-480', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1079"></a><tt class="py-lineno">1079</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt><tt class="py-op">:</tt> </tt>
<a name="L1080"></a><tt class="py-lineno">1080</tt>  <tt class="py-line">                        <tt class="py-name">tablenames</tt><tt class="py-op">.</tt><tt id="link-481" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-481', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L1081"></a><tt class="py-lineno">1081</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-482" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-482', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tablenames</tt><tt class="py-op">)</tt> <tt class="py-op">&lt;</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
<a name="L1082"></a><tt class="py-lineno">1082</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Set: no tables selected'</tt> </tt>
<a name="L1083"></a><tt class="py-lineno">1083</tt>  <tt class="py-line">        <tt class="py-name">sql_f</tt> <tt class="py-op">=</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-483" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-483', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-484" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-484', 'expand', 'link-296');">expand</a></tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1084"></a><tt class="py-lineno">1084</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_colnames</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">c</tt><tt class="py-op">.</tt><tt id="link-485" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-485', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">c</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sql_f</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">', '</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L1085"></a><tt class="py-lineno">1085</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L1086"></a><tt class="py-lineno">1086</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">' WHERE '</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-486" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-486', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1087"></a><tt class="py-lineno">1087</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1088"></a><tt class="py-lineno">1088</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1089"></a><tt class="py-lineno">1089</tt>  <tt class="py-line">        <tt class="py-name">sql_o</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1090"></a><tt class="py-lineno">1090</tt>  <tt class="py-line">        <tt class="py-name">sql_s</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1091"></a><tt class="py-lineno">1091</tt>  <tt class="py-line">        <tt class="py-name">left</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-487" class="py-name" targets="Method web2py.gluon.rocket.Headers.get()=web2py.gluon.rocket.Headers-class.html#get"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-487', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'left'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1092"></a><tt class="py-lineno">1092</tt>  <tt class="py-line">        <tt class="py-name">inner_join</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-488" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-488', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'join'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1093"></a><tt class="py-lineno">1093</tt>  <tt class="py-line">        <tt class="py-name">distinct</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-489" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-489', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'distinct'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1094"></a><tt class="py-lineno">1094</tt>  <tt class="py-line">        <tt class="py-name">groupby</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-490" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-490', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'groupby'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1095"></a><tt class="py-lineno">1095</tt>  <tt class="py-line">        <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-491" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-491', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'orderby'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1096"></a><tt class="py-lineno">1096</tt>  <tt class="py-line">        <tt class="py-name">having</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-492" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-492', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'having'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1097"></a><tt class="py-lineno">1097</tt>  <tt class="py-line">        <tt class="py-name">limitby</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-493" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-493', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'limitby'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L1098"></a><tt class="py-lineno">1098</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">distinct</tt> <tt class="py-keyword">is</tt> <tt class="py-name">True</tt><tt class="py-op">:</tt> </tt>
<a name="L1099"></a><tt class="py-lineno">1099</tt>  <tt class="py-line">            <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">'DISTINCT'</tt> </tt>
<a name="L1100"></a><tt class="py-lineno">1100</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">distinct</tt><tt class="py-op">:</tt> </tt>
<a name="L1101"></a><tt class="py-lineno">1101</tt>  <tt class="py-line">            <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">'DISTINCT ON (%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">distinct</tt> </tt>
<a name="L1102"></a><tt class="py-lineno">1102</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">inner_join</tt><tt class="py-op">:</tt> </tt>
<a name="L1103"></a><tt class="py-lineno">1103</tt>  <tt class="py-line">            <tt class="py-name">icommand</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-494" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.JOIN()=web2py.gluon.dal.BaseAdapter-class.html#JOIN"><a title="web2py.gluon.dal.BaseAdapter.JOIN" class="py-name" href="#" onclick="return doclink('link-494', 'JOIN', 'link-494');">JOIN</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1104"></a><tt class="py-lineno">1104</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">inner_join</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">tuple</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1105"></a><tt class="py-lineno">1105</tt>  <tt class="py-line">                <tt class="py-name">inner_join</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">inner_join</tt><tt class="py-op">]</tt> </tt>
<a name="L1106"></a><tt class="py-lineno">1106</tt>  <tt class="py-line">            <tt class="py-name">ijoint</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">inner_join</tt> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt><tt id="link-495" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-495', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L1107"></a><tt class="py-lineno">1107</tt>  <tt class="py-line">            <tt class="py-name">ijoinon</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">inner_join</tt> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt id="link-496" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-496', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L1108"></a><tt class="py-lineno">1108</tt>  <tt class="py-line">            <tt class="py-name">ijoinont</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">.</tt><tt id="link-497" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-497', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ijoinon</tt><tt class="py-op">]</tt> </tt>
<a name="L1109"></a><tt class="py-lineno">1109</tt>  <tt class="py-line">            <tt class="py-name">iexcluded</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ijoint</tt> <tt class="py-op">+</tt> <tt class="py-name">ijoinont</tt><tt class="py-op">]</tt> </tt>
<a name="L1110"></a><tt class="py-lineno">1110</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">left</tt><tt class="py-op">:</tt> </tt>
<a name="L1111"></a><tt class="py-lineno">1111</tt>  <tt class="py-line">            <tt id="link-498" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-498', 'join', 'link-228');">join</a></tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">[</tt><tt class="py-string">'left'</tt><tt class="py-op">]</tt> </tt>
<a name="L1112"></a><tt class="py-lineno">1112</tt>  <tt class="py-line">            <tt class="py-name">command</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-499" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.LEFT_JOIN()=web2py.gluon.dal.BaseAdapter-class.html#LEFT_JOIN,Method web2py.gluon.dal.DB2Adapter.LEFT_JOIN()=web2py.gluon.dal.DB2Adapter-class.html#LEFT_JOIN,Method web2py.gluon.dal.IngresAdapter.LEFT_JOIN()=web2py.gluon.dal.IngresAdapter-class.html#LEFT_JOIN,Method web2py.gluon.dal.MSSQLAdapter.LEFT_JOIN()=web2py.gluon.dal.MSSQLAdapter-class.html#LEFT_JOIN,Method web2py.gluon.dal.NoSQLAdapter.LEFT_JOIN()=web2py.gluon.dal.NoSQLAdapter-class.html#LEFT_JOIN,Method web2py.gluon.dal.OracleAdapter.LEFT_JOIN()=web2py.gluon.dal.OracleAdapter-class.html#LEFT_JOIN"><a title="web2py.gluon.dal.BaseAdapter.LEFT_JOIN
web2py.gluon.dal.DB2Adapter.LEFT_JOIN
web2py.gluon.dal.IngresAdapter.LEFT_JOIN
web2py.gluon.dal.MSSQLAdapter.LEFT_JOIN
web2py.gluon.dal.NoSQLAdapter.LEFT_JOIN
web2py.gluon.dal.OracleAdapter.LEFT_JOIN" class="py-name" href="#" onclick="return doclink('link-499', 'LEFT_JOIN', 'link-499');">LEFT_JOIN</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1113"></a><tt class="py-lineno">1113</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-500" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-500', 'join', 'link-228');">join</a></tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">tuple</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1114"></a><tt class="py-lineno">1114</tt>  <tt class="py-line">                <tt id="link-501" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-501', 'join', 'link-228');">join</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt id="link-502" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-502', 'join', 'link-228');">join</a></tt><tt class="py-op">]</tt> </tt>
<a name="L1115"></a><tt class="py-lineno">1115</tt>  <tt class="py-line">            <tt class="py-name">joint</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt id="link-503" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-503', 'join', 'link-228');">join</a></tt> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt><tt id="link-504" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-504', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L1116"></a><tt class="py-lineno">1116</tt>  <tt class="py-line">            <tt class="py-name">joinon</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt id="link-505" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-505', 'join', 'link-228');">join</a></tt> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt id="link-506" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-506', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L1117"></a><tt class="py-lineno">1117</tt>  <tt class="py-line">            <tt class="py-comment">#patch join+left patch (solves problem with ordering in left joins)</tt> </tt>
<a name="L1118"></a><tt class="py-lineno">1118</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">tables_to_merge</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L1119"></a><tt class="py-lineno">1119</tt>  <tt class="py-line">            <tt class="py-op">[</tt><tt class="py-name">tables_to_merge</tt><tt class="py-op">.</tt><tt id="link-507" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.update()=web2py.gluon.dal.BaseAdapter-class.html#update,Method web2py.gluon.dal.CouchDBAdapter.update()=web2py.gluon.dal.CouchDBAdapter-class.html#update,Method web2py.gluon.dal.GoogleDatastoreAdapter.update()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#update,Method web2py.gluon.dal.MongoDBAdapter.update()=web2py.gluon.dal.MongoDBAdapter-class.html#update,Method web2py.gluon.dal.Set.update()=web2py.gluon.dal.Set-class.html#update,Method web2py.gluon.html.DIV.update()=web2py.gluon.html.DIV-class.html#update,Method web2py.gluon.tools.Crud.update()=web2py.gluon.tools.Crud-class.html#update,Method web2py.gluon.widget.web2pyDialog.update()=web2py.gluon.widget.web2pyDialog-class.html#update"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-507', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">.</tt><tt class="py-name">fromkeys</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-508" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-508', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joinon</tt><tt class="py-op">]</tt> </tt>
<a name="L1120"></a><tt class="py-lineno">1120</tt>  <tt class="py-line">            <tt class="py-name">joinont</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">.</tt><tt id="link-509" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-509', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joinon</tt><tt class="py-op">]</tt> </tt>
<a name="L1121"></a><tt class="py-lineno">1121</tt>  <tt class="py-line">            <tt class="py-op">[</tt><tt class="py-name">tables_to_merge</tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joinont</tt> <tt class="py-keyword">if</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tables_to_merge</tt><tt class="py-op">]</tt> </tt>
<a name="L1122"></a><tt class="py-lineno">1122</tt>  <tt class="py-line">            <tt class="py-name">important_tablenames</tt> <tt class="py-op">=</tt> <tt class="py-name">joint</tt> <tt class="py-op">+</tt> <tt class="py-name">joinont</tt> <tt class="py-op">+</tt> <tt class="py-name">tables_to_merge</tt><tt class="py-op">.</tt><tt id="link-510" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-510', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1123"></a><tt class="py-lineno">1123</tt>  <tt class="py-line">            <tt class="py-name">excluded</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">t</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">important_tablenames</tt> <tt class="py-op">]</tt> </tt>
<a name="L1124"></a><tt class="py-lineno">1124</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">alias</tt><tt class="py-op">(</tt><tt class="py-param">t</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1125"></a><tt class="py-lineno">1125</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1126"></a><tt class="py-lineno">1126</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">inner_join</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">left</tt><tt class="py-op">:</tt> </tt>
<a name="L1127"></a><tt class="py-lineno">1127</tt>  <tt class="py-line">            <tt class="py-name">sql_t</tt> <tt class="py-op">=</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-511" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-511', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt id="link-512" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-512', 'alias', 'link-440');">alias</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iexcluded</tt><tt class="py-op">)</tt> </tt>
<a name="L1128"></a><tt class="py-lineno">1128</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ijoinon</tt><tt class="py-op">:</tt> </tt>
<a name="L1129"></a><tt class="py-lineno">1129</tt>  <tt class="py-line">                <tt class="py-name">sql_t</tt> <tt class="py-op">+=</tt> <tt class="py-string">' %s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">icommand</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1130"></a><tt class="py-lineno">1130</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">inner_join</tt> <tt class="py-keyword">and</tt> <tt class="py-name">left</tt><tt class="py-op">:</tt> </tt>
<a name="L1131"></a><tt class="py-lineno">1131</tt>  <tt class="py-line">            <tt class="py-name">sql_t</tt> <tt class="py-op">=</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-513" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-513', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt id="link-514" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-514', 'alias', 'link-440');">alias</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">excluded</tt> <tt class="py-op">+</tt> <tt class="py-name">tables_to_merge</tt><tt class="py-op">.</tt><tt id="link-515" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-515', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1132"></a><tt class="py-lineno">1132</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">joint</tt><tt class="py-op">:</tt> </tt>
<a name="L1133"></a><tt class="py-lineno">1133</tt>  <tt class="py-line">                <tt class="py-name">sql_t</tt> <tt class="py-op">+=</tt> <tt class="py-string">' %s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">,</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-516" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-516', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">t</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joint</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1134"></a><tt class="py-lineno">1134</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joinon</tt><tt class="py-op">:</tt> </tt>
<a name="L1135"></a><tt class="py-lineno">1135</tt>  <tt class="py-line">                <tt class="py-name">sql_t</tt> <tt class="py-op">+=</tt> <tt class="py-string">' %s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1136"></a><tt class="py-lineno">1136</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">inner_join</tt> <tt class="py-keyword">and</tt> <tt class="py-name">left</tt><tt class="py-op">:</tt> </tt>
<a name="L1137"></a><tt class="py-lineno">1137</tt>  <tt class="py-line">            <tt class="py-name">sql_t</tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-517" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-517', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt id="link-518" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-518', 'alias', 'link-440');">alias</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">excluded</tt> <tt class="py-op">+</tt> \ </tt>
<a name="L1138"></a><tt class="py-lineno">1138</tt>  <tt class="py-line">                                  <tt class="py-name">tables_to_merge</tt><tt class="py-op">.</tt><tt id="link-519" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-519', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">if</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">iexcluded</tt> <tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1139"></a><tt class="py-lineno">1139</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ijoinon</tt><tt class="py-op">:</tt> </tt>
<a name="L1140"></a><tt class="py-lineno">1140</tt>  <tt class="py-line">                <tt class="py-name">sql_t</tt> <tt class="py-op">+=</tt> <tt class="py-string">' %s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">icommand</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1141"></a><tt class="py-lineno">1141</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">joint</tt><tt class="py-op">:</tt> </tt>
<a name="L1142"></a><tt class="py-lineno">1142</tt>  <tt class="py-line">                <tt class="py-name">sql_t</tt> <tt class="py-op">+=</tt> <tt class="py-string">' %s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">,</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-520" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-520', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">t</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joint</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1143"></a><tt class="py-lineno">1143</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">joinon</tt><tt class="py-op">:</tt> </tt>
<a name="L1144"></a><tt class="py-lineno">1144</tt>  <tt class="py-line">                <tt class="py-name">sql_t</tt> <tt class="py-op">+=</tt> <tt class="py-string">' %s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1145"></a><tt class="py-lineno">1145</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1146"></a><tt class="py-lineno">1146</tt>  <tt class="py-line">            <tt class="py-name">sql_t</tt> <tt class="py-op">=</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-521" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-521', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt id="link-522" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-522', 'alias', 'link-440');">alias</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt><tt class="py-op">)</tt> </tt>
<a name="L1147"></a><tt class="py-lineno">1147</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">groupby</tt><tt class="py-op">:</tt> </tt>
<a name="L1148"></a><tt class="py-lineno">1148</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">groupby</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1149"></a><tt class="py-lineno">1149</tt>  <tt class="py-line">                <tt class="py-name">groupby</tt> <tt class="py-op">=</tt> <tt id="link-523" class="py-name" targets="Function web2py.gluon.dal.xorify()=web2py.gluon.dal-module.html#xorify"><a title="web2py.gluon.dal.xorify" class="py-name" href="#" onclick="return doclink('link-523', 'xorify', 'link-523');">xorify</a></tt><tt class="py-op">(</tt><tt class="py-name">groupby</tt><tt class="py-op">)</tt> </tt>
<a name="L1150"></a><tt class="py-lineno">1150</tt>  <tt class="py-line">            <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' GROUP BY %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-524" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-524', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">groupby</tt><tt class="py-op">)</tt> </tt>
<a name="L1151"></a><tt class="py-lineno">1151</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">having</tt><tt class="py-op">:</tt> </tt>
<a name="L1152"></a><tt class="py-lineno">1152</tt>  <tt class="py-line">                <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' HAVING %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">attributes</tt><tt class="py-op">[</tt><tt class="py-string">'having'</tt><tt class="py-op">]</tt> </tt>
<a name="L1153"></a><tt class="py-lineno">1153</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">orderby</tt><tt class="py-op">:</tt> </tt>
<a name="L1154"></a><tt class="py-lineno">1154</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1155"></a><tt class="py-lineno">1155</tt>  <tt class="py-line">                <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt id="link-525" class="py-name"><a title="web2py.gluon.dal.xorify" class="py-name" href="#" onclick="return doclink('link-525', 'xorify', 'link-523');">xorify</a></tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">)</tt> </tt>
<a name="L1156"></a><tt class="py-lineno">1156</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-string">'&lt;random&gt;'</tt><tt class="py-op">:</tt> </tt>
<a name="L1157"></a><tt class="py-lineno">1157</tt>  <tt class="py-line">                <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' ORDER BY %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-526" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.RANDOM()=web2py.gluon.dal.BaseAdapter-class.html#RANDOM,Method web2py.gluon.dal.DB2Adapter.RANDOM()=web2py.gluon.dal.DB2Adapter-class.html#RANDOM,Method web2py.gluon.dal.FireBirdAdapter.RANDOM()=web2py.gluon.dal.FireBirdAdapter-class.html#RANDOM,Method web2py.gluon.dal.InformixAdapter.RANDOM()=web2py.gluon.dal.InformixAdapter-class.html#RANDOM,Method web2py.gluon.dal.IngresAdapter.RANDOM()=web2py.gluon.dal.IngresAdapter-class.html#RANDOM,Method web2py.gluon.dal.MSSQLAdapter.RANDOM()=web2py.gluon.dal.MSSQLAdapter-class.html#RANDOM,Method web2py.gluon.dal.MySQLAdapter.RANDOM()=web2py.gluon.dal.MySQLAdapter-class.html#RANDOM,Method web2py.gluon.dal.NoSQLAdapter.RANDOM()=web2py.gluon.dal.NoSQLAdapter-class.html#RANDOM,Method web2py.gluon.dal.OracleAdapter.RANDOM()=web2py.gluon.dal.OracleAdapter-class.html#RANDOM,Method web2py.gluon.dal.PostgreSQLAdapter.RANDOM()=web2py.gluon.dal.PostgreSQLAdapter-class.html#RANDOM"><a title="web2py.gluon.dal.BaseAdapter.RANDOM
web2py.gluon.dal.DB2Adapter.RANDOM
web2py.gluon.dal.FireBirdAdapter.RANDOM
web2py.gluon.dal.InformixAdapter.RANDOM
web2py.gluon.dal.IngresAdapter.RANDOM
web2py.gluon.dal.MSSQLAdapter.RANDOM
web2py.gluon.dal.MySQLAdapter.RANDOM
web2py.gluon.dal.NoSQLAdapter.RANDOM
web2py.gluon.dal.OracleAdapter.RANDOM
web2py.gluon.dal.PostgreSQLAdapter.RANDOM" class="py-name" href="#" onclick="return doclink('link-526', 'RANDOM', 'link-526');">RANDOM</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1158"></a><tt class="py-lineno">1158</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1159"></a><tt class="py-lineno">1159</tt>  <tt class="py-line">                <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' ORDER BY %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-527" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-527', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">)</tt> </tt>
<a name="L1160"></a><tt class="py-lineno">1160</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L1161"></a><tt class="py-lineno">1161</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">orderby</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tablenames</tt><tt class="py-op">:</tt> </tt>
<a name="L1162"></a><tt class="py-lineno">1162</tt>  <tt class="py-line">                <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' ORDER BY %s'</tt> <tt class="py-op">%</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-528" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-528', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">'%s.%s'</tt><tt class="py-op">%</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt><tt id="link-529" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-529', 'x', 'link-114');">x</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt> <tt class="py-keyword">for</tt> <tt id="link-530" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-530', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-531" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-531', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1163"></a><tt class="py-lineno">1163</tt>  <tt class="py-line">            <tt class="py-comment"># oracle does not support limitby</tt> </tt>
<a name="L1164"></a><tt class="py-lineno">1164</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-532" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.select_limitby()=web2py.gluon.dal.BaseAdapter-class.html#select_limitby,Method web2py.gluon.dal.DB2Adapter.select_limitby()=web2py.gluon.dal.DB2Adapter-class.html#select_limitby,Method web2py.gluon.dal.FireBirdAdapter.select_limitby()=web2py.gluon.dal.FireBirdAdapter-class.html#select_limitby,Method web2py.gluon.dal.InformixAdapter.select_limitby()=web2py.gluon.dal.InformixAdapter-class.html#select_limitby,Method web2py.gluon.dal.IngresAdapter.select_limitby()=web2py.gluon.dal.IngresAdapter-class.html#select_limitby,Method web2py.gluon.dal.MSSQLAdapter.select_limitby()=web2py.gluon.dal.MSSQLAdapter-class.html#select_limitby,Method web2py.gluon.dal.OracleAdapter.select_limitby()=web2py.gluon.dal.OracleAdapter-class.html#select_limitby,Method web2py.gluon.dal.SAPDBAdapter.select_limitby()=web2py.gluon.dal.SAPDBAdapter-class.html#select_limitby"><a title="web2py.gluon.dal.BaseAdapter.select_limitby
web2py.gluon.dal.DB2Adapter.select_limitby
web2py.gluon.dal.FireBirdAdapter.select_limitby
web2py.gluon.dal.InformixAdapter.select_limitby
web2py.gluon.dal.IngresAdapter.select_limitby
web2py.gluon.dal.MSSQLAdapter.select_limitby
web2py.gluon.dal.OracleAdapter.select_limitby
web2py.gluon.dal.SAPDBAdapter.select_limitby" class="py-name" href="#" onclick="return doclink('link-532', 'select_limitby', 'link-532');">select_limitby</a></tt><tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">,</tt> <tt class="py-name">limitby</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1165"></a><tt class="py-lineno">1165</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.select_limitby"></a><div id="BaseAdapter.select_limitby-def"><a name="L1166"></a><tt class="py-lineno">1166</tt> <a class="py-toggle" href="#" id="BaseAdapter.select_limitby-toggle" onclick="return toggle('BaseAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.select_limitby-expanded"><a name="L1167"></a><tt class="py-lineno">1167</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L1168"></a><tt class="py-lineno">1168</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L1169"></a><tt class="py-lineno">1169</tt>  <tt class="py-line">            <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' LIMIT %i OFFSET %i'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">lmax</tt> <tt class="py-op">-</tt> <tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmin</tt><tt class="py-op">)</tt> </tt>
<a name="L1170"></a><tt class="py-lineno">1170</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1171"></a><tt class="py-lineno">1171</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.select"></a><div id="BaseAdapter.select-def"><a name="L1172"></a><tt class="py-lineno">1172</tt> <a class="py-toggle" href="#" id="BaseAdapter.select-toggle" onclick="return toggle('BaseAdapter.select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#select">select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.select-expanded"><a name="L1173"></a><tt class="py-lineno">1173</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L1174"></a><tt class="py-lineno">1174</tt>  <tt class="py-line"><tt class="py-docstring">        Always returns a Rows object, even if it may be empty</tt> </tt>
<a name="L1175"></a><tt class="py-lineno">1175</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L1176"></a><tt class="py-lineno">1176</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">response</tt><tt class="py-op">(</tt><tt class="py-param">sql</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1177"></a><tt class="py-lineno">1177</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-533" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-533', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt id="link-534" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-534', 'sql', 'link-88');">sql</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1178"></a><tt class="py-lineno">1178</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchall</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1179"></a><tt class="py-lineno">1179</tt>  <tt class="py-line">        <tt id="link-535" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-535', 'sql', 'link-88');">sql</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-536" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._select()=web2py.gluon.dal.BaseAdapter-class.html#_select,Method web2py.gluon.dal.CouchDBAdapter._select()=web2py.gluon.dal.CouchDBAdapter-class.html#_select,Method web2py.gluon.dal.NoSQLAdapter._select()=web2py.gluon.dal.NoSQLAdapter-class.html#_select,Method web2py.gluon.dal.Set._select()=web2py.gluon.dal.Set-class.html#_select"><a title="web2py.gluon.dal.BaseAdapter._select
web2py.gluon.dal.CouchDBAdapter._select
web2py.gluon.dal.NoSQLAdapter._select
web2py.gluon.dal.Set._select" class="py-name" href="#" onclick="return doclink('link-536', '_select', 'link-536');">_select</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt><tt class="py-name">attributes</tt><tt class="py-op">)</tt> </tt>
<a name="L1180"></a><tt class="py-lineno">1180</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-537" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-537', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'cache'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1181"></a><tt class="py-lineno">1181</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">cache_model</tt><tt class="py-op">,</tt> <tt class="py-name">time_expire</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">[</tt><tt class="py-string">'cache'</tt><tt class="py-op">]</tt> </tt>
<a name="L1182"></a><tt class="py-lineno">1182</tt>  <tt class="py-line">            <tt class="py-keyword">del</tt> <tt class="py-name">attributes</tt><tt class="py-op">[</tt><tt class="py-string">'cache'</tt><tt class="py-op">]</tt> </tt>
<a name="L1183"></a><tt class="py-lineno">1183</tt>  <tt class="py-line">            <tt class="py-name">key</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">+</tt> <tt class="py-string">'/'</tt> <tt class="py-op">+</tt> <tt id="link-538" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-538', 'sql', 'link-88');">sql</a></tt> </tt>
<a name="L1184"></a><tt class="py-lineno">1184</tt>  <tt class="py-line">            <tt class="py-name">key</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">&lt;=</tt><tt class="py-number">200</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">key</tt> <tt class="py-keyword">or</tt> <tt class="py-name">hashlib</tt><tt class="py-op">.</tt><tt class="py-name">md5</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">hexdigest</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1185"></a><tt class="py-lineno">1185</tt>  <tt class="py-line">            <tt id="link-539" class="py-name" targets="Method web2py.gluon.tools.Crud.rows()=web2py.gluon.tools.Crud-class.html#rows"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-539', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">cache_model</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-keyword">lambda</tt><tt class="py-op">:</tt> <tt class="py-name">response</tt><tt class="py-op">(</tt><tt id="link-540" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-540', 'sql', 'link-88');">sql</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">time_expire</tt><tt class="py-op">)</tt> </tt>
<a name="L1186"></a><tt class="py-lineno">1186</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1187"></a><tt class="py-lineno">1187</tt>  <tt class="py-line">            <tt id="link-541" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-541', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">response</tt><tt class="py-op">(</tt><tt id="link-542" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-542', 'sql', 'link-88');">sql</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1188"></a><tt class="py-lineno">1188</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-543" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-543', 'rows', 'link-539');">rows</a></tt><tt class="py-op">,</tt><tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1189"></a><tt class="py-lineno">1189</tt>  <tt class="py-line">            <tt id="link-544" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-544', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt><tt id="link-545" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-545', 'rows', 'link-539');">rows</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1190"></a><tt class="py-lineno">1190</tt>  <tt class="py-line">        <tt class="py-name">limitby</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-546" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-546', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'limitby'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-op">)</tt> </tt>
<a name="L1191"></a><tt class="py-lineno">1191</tt>  <tt class="py-line">        <tt id="link-547" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-547', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-548" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.rowslice()=web2py.gluon.dal.BaseAdapter-class.html#rowslice,Method web2py.gluon.dal.DB2Adapter.rowslice()=web2py.gluon.dal.DB2Adapter-class.html#rowslice,Method web2py.gluon.dal.MSSQLAdapter.rowslice()=web2py.gluon.dal.MSSQLAdapter-class.html#rowslice,Method web2py.gluon.dal.NoSQLAdapter.rowslice()=web2py.gluon.dal.NoSQLAdapter-class.html#rowslice"><a title="web2py.gluon.dal.BaseAdapter.rowslice
web2py.gluon.dal.DB2Adapter.rowslice
web2py.gluon.dal.MSSQLAdapter.rowslice
web2py.gluon.dal.NoSQLAdapter.rowslice" class="py-name" href="#" onclick="return doclink('link-548', 'rowslice', 'link-548');">rowslice</a></tt><tt class="py-op">(</tt><tt id="link-549" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-549', 'rows', 'link-539');">rows</a></tt><tt class="py-op">,</tt><tt class="py-name">limitby</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1192"></a><tt class="py-lineno">1192</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-550" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.parse()=web2py.gluon.dal.BaseAdapter-class.html#parse,Method web2py.gluon.template.TemplateParser.parse()=web2py.gluon.template.TemplateParser-class.html#parse"><a title="web2py.gluon.dal.BaseAdapter.parse
web2py.gluon.template.TemplateParser.parse" class="py-name" href="#" onclick="return doclink('link-550', 'parse', 'link-550');">parse</a></tt><tt class="py-op">(</tt><tt id="link-551" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-551', 'rows', 'link-539');">rows</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1193"></a><tt class="py-lineno">1193</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter._count"></a><div id="BaseAdapter._count-def"><a name="L1194"></a><tt class="py-lineno">1194</tt> <a class="py-toggle" href="#" id="BaseAdapter._count-toggle" onclick="return toggle('BaseAdapter._count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#_count">_count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter._count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter._count-expanded"><a name="L1195"></a><tt class="py-lineno">1195</tt>  <tt class="py-line">        <tt class="py-name">tablenames</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-552" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-552', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1196"></a><tt class="py-lineno">1196</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L1197"></a><tt class="py-lineno">1197</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">' WHERE '</tt> <tt class="py-op">+</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-553" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-553', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1198"></a><tt class="py-lineno">1198</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1199"></a><tt class="py-lineno">1199</tt>  <tt class="py-line">            <tt class="py-name">sql_w</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1200"></a><tt class="py-lineno">1200</tt>  <tt class="py-line">        <tt class="py-name">sql_t</tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-554" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-554', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">tablenames</tt><tt class="py-op">)</tt> </tt>
<a name="L1201"></a><tt class="py-lineno">1201</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">distinct</tt><tt class="py-op">:</tt> </tt>
<a name="L1202"></a><tt class="py-lineno">1202</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">distinct</tt><tt class="py-op">,</tt><tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt><tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1203"></a><tt class="py-lineno">1203</tt>  <tt class="py-line">                <tt class="py-name">distinct</tt> <tt class="py-op">=</tt> <tt id="link-555" class="py-name"><a title="web2py.gluon.dal.xorify" class="py-name" href="#" onclick="return doclink('link-555', 'xorify', 'link-523');">xorify</a></tt><tt class="py-op">(</tt><tt class="py-name">distinct</tt><tt class="py-op">)</tt> </tt>
<a name="L1204"></a><tt class="py-lineno">1204</tt>  <tt class="py-line">            <tt class="py-name">sql_d</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-556" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-556', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">distinct</tt><tt class="py-op">)</tt> </tt>
<a name="L1205"></a><tt class="py-lineno">1205</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT count(DISTINCT %s) FROM %s%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_d</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">)</tt> </tt>
<a name="L1206"></a><tt class="py-lineno">1206</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT count(*) FROM %s%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1207"></a><tt class="py-lineno">1207</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.count"></a><div id="BaseAdapter.count-def"><a name="L1208"></a><tt class="py-lineno">1208</tt> <a class="py-toggle" href="#" id="BaseAdapter.count-toggle" onclick="return toggle('BaseAdapter.count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#count">count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.count-expanded"><a name="L1209"></a><tt class="py-lineno">1209</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-557" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-557', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-558" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter._count()=web2py.gluon.dal.BaseAdapter-class.html#_count,Method web2py.gluon.dal.NoSQLAdapter._count()=web2py.gluon.dal.NoSQLAdapter-class.html#_count,Method web2py.gluon.dal.Set._count()=web2py.gluon.dal.Set-class.html#_count"><a title="web2py.gluon.dal.BaseAdapter._count
web2py.gluon.dal.NoSQLAdapter._count
web2py.gluon.dal.Set._count" class="py-name" href="#" onclick="return doclink('link-558', '_count', 'link-558');">_count</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">distinct</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1210"></a><tt class="py-lineno">1210</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
</div><a name="L1211"></a><tt class="py-lineno">1211</tt>  <tt class="py-line"> </tt>
<a name="L1212"></a><tt class="py-lineno">1212</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.tables"></a><div id="BaseAdapter.tables-def"><a name="L1213"></a><tt class="py-lineno">1213</tt> <a class="py-toggle" href="#" id="BaseAdapter.tables-toggle" onclick="return toggle('BaseAdapter.tables');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#tables">tables</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.tables-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.tables-expanded"><a name="L1214"></a><tt class="py-lineno">1214</tt>  <tt class="py-line">        <tt id="link-559" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-559', 'tables', 'link-313');">tables</a></tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1215"></a><tt class="py-lineno">1215</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt> <tt id="link-560" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-560', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1216"></a><tt class="py-lineno">1216</tt>  <tt class="py-line">            <tt id="link-561" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-561', 'tables', 'link-313');">tables</a></tt><tt class="py-op">.</tt><tt class="py-name">add</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L1217"></a><tt class="py-lineno">1217</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-562" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-562', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">,</tt> <tt id="link-563" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-563', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1218"></a><tt class="py-lineno">1218</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-564" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-564', 'first', 'link-297');">first</a></tt><tt class="py-op">!=</tt><tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1219"></a><tt class="py-lineno">1219</tt>  <tt class="py-line">                <tt id="link-565" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-565', 'tables', 'link-313');">tables</a></tt> <tt class="py-op">=</tt> <tt id="link-566" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-566', 'tables', 'link-313');">tables</a></tt><tt class="py-op">.</tt><tt class="py-name">union</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-567" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-567', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-568" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-568', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1220"></a><tt class="py-lineno">1220</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">second</tt><tt class="py-op">!=</tt><tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1221"></a><tt class="py-lineno">1221</tt>  <tt class="py-line">                <tt id="link-569" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-569', 'tables', 'link-313');">tables</a></tt> <tt class="py-op">=</tt> <tt id="link-570" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-570', 'tables', 'link-313');">tables</a></tt><tt class="py-op">.</tt><tt class="py-name">union</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-571" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-571', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1222"></a><tt class="py-lineno">1222</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt><tt id="link-572" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-572', 'tables', 'link-313');">tables</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L1223"></a><tt class="py-lineno">1223</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.commit"></a><div id="BaseAdapter.commit-def"><a name="L1224"></a><tt class="py-lineno">1224</tt> <a class="py-toggle" href="#" id="BaseAdapter.commit-toggle" onclick="return toggle('BaseAdapter.commit');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#commit">commit</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.commit-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.commit-expanded"><a name="L1225"></a><tt class="py-lineno">1225</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-573" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-573', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1226"></a><tt class="py-lineno">1226</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.rollback"></a><div id="BaseAdapter.rollback-def"><a name="L1227"></a><tt class="py-lineno">1227</tt> <a class="py-toggle" href="#" id="BaseAdapter.rollback-toggle" onclick="return toggle('BaseAdapter.rollback');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#rollback">rollback</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.rollback-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.rollback-expanded"><a name="L1228"></a><tt class="py-lineno">1228</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-574" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.rollback()=web2py.gluon.dal.BaseAdapter-class.html#rollback,Method web2py.gluon.dal.DAL.rollback()=web2py.gluon.dal.DAL-class.html#rollback,Method web2py.gluon.dal.NoSQLAdapter.rollback()=web2py.gluon.dal.NoSQLAdapter-class.html#rollback"><a title="web2py.gluon.dal.BaseAdapter.rollback
web2py.gluon.dal.DAL.rollback
web2py.gluon.dal.NoSQLAdapter.rollback" class="py-name" href="#" onclick="return doclink('link-574', 'rollback', 'link-574');">rollback</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1229"></a><tt class="py-lineno">1229</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.close"></a><div id="BaseAdapter.close-def"><a name="L1230"></a><tt class="py-lineno">1230</tt> <a class="py-toggle" href="#" id="BaseAdapter.close-toggle" onclick="return toggle('BaseAdapter.close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#close">close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.close-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.close-expanded"><a name="L1231"></a><tt class="py-lineno">1231</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-575" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-575', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1232"></a><tt class="py-lineno">1232</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.distributed_transaction_begin"></a><div id="BaseAdapter.distributed_transaction_begin-def"><a name="L1233"></a><tt class="py-lineno">1233</tt> <a class="py-toggle" href="#" id="BaseAdapter.distributed_transaction_begin-toggle" onclick="return toggle('BaseAdapter.distributed_transaction_begin');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#distributed_transaction_begin">distributed_transaction_begin</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.distributed_transaction_begin-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.distributed_transaction_begin-expanded"><a name="L1234"></a><tt class="py-lineno">1234</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> </tt>
</div><a name="L1235"></a><tt class="py-lineno">1235</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.prepare"></a><div id="BaseAdapter.prepare-def"><a name="L1236"></a><tt class="py-lineno">1236</tt> <a class="py-toggle" href="#" id="BaseAdapter.prepare-toggle" onclick="return toggle('BaseAdapter.prepare');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#prepare">prepare</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.prepare-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.prepare-expanded"><a name="L1237"></a><tt class="py-lineno">1237</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-576" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.prepare()=web2py.gluon.dal.BaseAdapter-class.html#prepare,Method web2py.gluon.dal.MySQLAdapter.prepare()=web2py.gluon.dal.MySQLAdapter-class.html#prepare,Method web2py.gluon.dal.NoSQLAdapter.prepare()=web2py.gluon.dal.NoSQLAdapter-class.html#prepare,Method web2py.gluon.dal.PostgreSQLAdapter.prepare()=web2py.gluon.dal.PostgreSQLAdapter-class.html#prepare"><a title="web2py.gluon.dal.BaseAdapter.prepare
web2py.gluon.dal.MySQLAdapter.prepare
web2py.gluon.dal.NoSQLAdapter.prepare
web2py.gluon.dal.PostgreSQLAdapter.prepare" class="py-name" href="#" onclick="return doclink('link-576', 'prepare', 'link-576');">prepare</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1238"></a><tt class="py-lineno">1238</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.commit_prepared"></a><div id="BaseAdapter.commit_prepared-def"><a name="L1239"></a><tt class="py-lineno">1239</tt> <a class="py-toggle" href="#" id="BaseAdapter.commit_prepared-toggle" onclick="return toggle('BaseAdapter.commit_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#commit_prepared">commit_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.commit_prepared-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.commit_prepared-expanded"><a name="L1240"></a><tt class="py-lineno">1240</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-577" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-577', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1241"></a><tt class="py-lineno">1241</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.rollback_prepared"></a><div id="BaseAdapter.rollback_prepared-def"><a name="L1242"></a><tt class="py-lineno">1242</tt> <a class="py-toggle" href="#" id="BaseAdapter.rollback_prepared-toggle" onclick="return toggle('BaseAdapter.rollback_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#rollback_prepared">rollback_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.rollback_prepared-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.rollback_prepared-expanded"><a name="L1243"></a><tt class="py-lineno">1243</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-578" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.rollback
web2py.gluon.dal.DAL.rollback
web2py.gluon.dal.NoSQLAdapter.rollback" class="py-name" href="#" onclick="return doclink('link-578', 'rollback', 'link-574');">rollback</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1244"></a><tt class="py-lineno">1244</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.concat_add"></a><div id="BaseAdapter.concat_add-def"><a name="L1245"></a><tt class="py-lineno">1245</tt> <a class="py-toggle" href="#" id="BaseAdapter.concat_add-toggle" onclick="return toggle('BaseAdapter.concat_add');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#concat_add">concat_add</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.concat_add-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.concat_add-expanded"><a name="L1246"></a><tt class="py-lineno">1246</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">', ADD '</tt> </tt>
</div><a name="L1247"></a><tt class="py-lineno">1247</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.constraint_name"></a><div id="BaseAdapter.constraint_name-def"><a name="L1248"></a><tt class="py-lineno">1248</tt> <a class="py-toggle" href="#" id="BaseAdapter.constraint_name-toggle" onclick="return toggle('BaseAdapter.constraint_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#constraint_name">constraint_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-param">fieldname</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.constraint_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.constraint_name-expanded"><a name="L1249"></a><tt class="py-lineno">1249</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_%s__constraint'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">fieldname</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1250"></a><tt class="py-lineno">1250</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.create_sequence_and_triggers"></a><div id="BaseAdapter.create_sequence_and_triggers-def"><a name="L1251"></a><tt class="py-lineno">1251</tt> <a class="py-toggle" href="#" id="BaseAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('BaseAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.create_sequence_and_triggers-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.create_sequence_and_triggers-expanded"><a name="L1252"></a><tt class="py-lineno">1252</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-579" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-579', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1253"></a><tt class="py-lineno">1253</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.log_execute"></a><div id="BaseAdapter.log_execute-def"><a name="L1254"></a><tt class="py-lineno">1254</tt> <a class="py-toggle" href="#" id="BaseAdapter.log_execute-toggle" onclick="return toggle('BaseAdapter.log_execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#log_execute">log_execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-param">a</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">b</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.log_execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.log_execute-expanded"><a name="L1255"></a><tt class="py-lineno">1255</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_lastsql</tt> <tt class="py-op">=</tt> <tt class="py-name">a</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L1256"></a><tt class="py-lineno">1256</tt>  <tt class="py-line">        <tt class="py-name">t0</tt> <tt class="py-op">=</tt> <tt id="link-580" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-580', 'time', 'link-4');">time</a></tt><tt class="py-op">.</tt><tt id="link-581" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-581', 'time', 'link-4');">time</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1257"></a><tt class="py-lineno">1257</tt>  <tt class="py-line">        <tt class="py-name">ret</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt id="link-582" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-582', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-name">a</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt id="link-583" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-583', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1258"></a><tt class="py-lineno">1258</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_timings</tt><tt class="py-op">.</tt><tt id="link-584" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-584', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">a</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt id="link-585" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-585', 'time', 'link-4');">time</a></tt><tt class="py-op">.</tt><tt id="link-586" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-586', 'time', 'link-4');">time</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">-</tt><tt class="py-name">t0</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1259"></a><tt class="py-lineno">1259</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">ret</tt> </tt>
</div><a name="L1260"></a><tt class="py-lineno">1260</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.execute"></a><div id="BaseAdapter.execute-def"><a name="L1261"></a><tt class="py-lineno">1261</tt> <a class="py-toggle" href="#" id="BaseAdapter.execute-toggle" onclick="return toggle('BaseAdapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-param">a</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">b</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.execute-expanded"><a name="L1262"></a><tt class="py-lineno">1262</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-587" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.log_execute()=web2py.gluon.dal.BaseAdapter-class.html#log_execute,Method web2py.gluon.dal.NoSQLAdapter.log_execute()=web2py.gluon.dal.NoSQLAdapter-class.html#log_execute"><a title="web2py.gluon.dal.BaseAdapter.log_execute
web2py.gluon.dal.NoSQLAdapter.log_execute" class="py-name" href="#" onclick="return doclink('link-587', 'log_execute', 'link-587');">log_execute</a></tt><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-name">a</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt id="link-588" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-588', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L1263"></a><tt class="py-lineno">1263</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.represent"></a><div id="BaseAdapter.represent-def"><a name="L1264"></a><tt class="py-lineno">1264</tt> <a class="py-toggle" href="#" id="BaseAdapter.represent-toggle" onclick="return toggle('BaseAdapter.represent');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#represent">represent</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.represent-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.represent-expanded"><a name="L1265"></a><tt class="py-lineno">1265</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt><tt id="link-589" class="py-name"><a title="web2py.gluon.dal.CALLABLETYPES" class="py-name" href="#" onclick="return doclink('link-589', 'CALLABLETYPES', 'link-7');">CALLABLETYPES</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1266"></a><tt class="py-lineno">1266</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1267"></a><tt class="py-lineno">1267</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">fieldtype</tt><tt class="py-op">,</tt> <tt id="link-590" class="py-name"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-590', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1268"></a><tt class="py-lineno">1268</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt class="py-name">encoder</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1269"></a><tt class="py-lineno">1269</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-591" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-591', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">,</tt> <tt id="link-592" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-592', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1270"></a><tt class="py-lineno">1270</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1271"></a><tt class="py-lineno">1271</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-593" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-593', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1272"></a><tt class="py-lineno">1272</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">obj</tt><tt class="py-op">:</tt> </tt>
<a name="L1273"></a><tt class="py-lineno">1273</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L1274"></a><tt class="py-lineno">1274</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1275"></a><tt class="py-lineno">1275</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">obj</tt><tt class="py-op">]</tt> </tt>
<a name="L1276"></a><tt class="py-lineno">1276</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1277"></a><tt class="py-lineno">1277</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt id="link-594" class="py-name" targets="Function web2py.gluon.dal.bar_encode()=web2py.gluon.dal-module.html#bar_encode"><a title="web2py.gluon.dal.bar_encode" class="py-name" href="#" onclick="return doclink('link-594', 'bar_encode', 'link-594');">bar_encode</a></tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1278"></a><tt class="py-lineno">1278</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1279"></a><tt class="py-lineno">1279</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'NULL'</tt> </tt>
<a name="L1280"></a><tt class="py-lineno">1280</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-op">==</tt> <tt class="py-string">''</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-op">[</tt><tt class="py-string">'st'</tt><tt class="py-op">,</tt> <tt class="py-string">'te'</tt><tt class="py-op">,</tt> <tt class="py-string">'pa'</tt><tt class="py-op">,</tt> <tt class="py-string">'up'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L1281"></a><tt class="py-lineno">1281</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'NULL'</tt> </tt>
<a name="L1282"></a><tt class="py-lineno">1282</tt>  <tt class="py-line">        <tt class="py-name">r</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-595" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.represent_exceptions()=web2py.gluon.dal.BaseAdapter-class.html#represent_exceptions,Method web2py.gluon.dal.DB2Adapter.represent_exceptions()=web2py.gluon.dal.DB2Adapter-class.html#represent_exceptions,Method web2py.gluon.dal.InformixAdapter.represent_exceptions()=web2py.gluon.dal.InformixAdapter-class.html#represent_exceptions,Method web2py.gluon.dal.MSSQLAdapter.represent_exceptions()=web2py.gluon.dal.MSSQLAdapter-class.html#represent_exceptions,Method web2py.gluon.dal.NoSQLAdapter.represent_exceptions()=web2py.gluon.dal.NoSQLAdapter-class.html#represent_exceptions,Method web2py.gluon.dal.OracleAdapter.represent_exceptions()=web2py.gluon.dal.OracleAdapter-class.html#represent_exceptions"><a title="web2py.gluon.dal.BaseAdapter.represent_exceptions
web2py.gluon.dal.DB2Adapter.represent_exceptions
web2py.gluon.dal.InformixAdapter.represent_exceptions
web2py.gluon.dal.MSSQLAdapter.represent_exceptions
web2py.gluon.dal.NoSQLAdapter.represent_exceptions
web2py.gluon.dal.OracleAdapter.represent_exceptions" class="py-name" href="#" onclick="return doclink('link-595', 'represent_exceptions', 'link-595');">represent_exceptions</a></tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt><tt class="py-name">fieldtype</tt><tt class="py-op">)</tt> </tt>
<a name="L1283"></a><tt class="py-lineno">1283</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">r</tt> <tt class="py-op">!=</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1284"></a><tt class="py-lineno">1284</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">r</tt> </tt>
<a name="L1285"></a><tt class="py-lineno">1285</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> </tt>
<a name="L1286"></a><tt class="py-lineno">1286</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-596" class="py-name" targets="Method web2py.gluon.dal.Expression.upper()=web2py.gluon.dal.Expression-class.html#upper"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-596', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-op">[</tt><tt class="py-string">'F'</tt><tt class="py-op">,</tt> <tt class="py-string">'0'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L1287"></a><tt class="py-lineno">1287</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-string">"'T'"</tt> </tt>
<a name="L1288"></a><tt class="py-lineno">1288</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1289"></a><tt class="py-lineno">1289</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-string">"'F'"</tt> </tt>
<a name="L1290"></a><tt class="py-lineno">1290</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'id'</tt> <tt class="py-keyword">or</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> </tt>
<a name="L1291"></a><tt class="py-lineno">1291</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1292"></a><tt class="py-lineno">1292</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-597" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-597', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'decimal'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1293"></a><tt class="py-lineno">1293</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1294"></a><tt class="py-lineno">1294</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-598" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-598', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-comment"># reference</tt> </tt>
<a name="L1295"></a><tt class="py-lineno">1295</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-599" class="py-name" targets="Method web2py.gluon.dal.Rows.find()=web2py.gluon.dal.Rows-class.html#find"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-599', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt><tt class="py-op">&gt;</tt><tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L1296"></a><tt class="py-lineno">1296</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1297"></a><tt class="py-lineno">1297</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-600" class="py-name" targets="Class web2py.gluon.dal.Row=web2py.gluon.dal.Row-class.html"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-600', 'Row', 'link-600');">Row</a></tt><tt class="py-op">,</tt> <tt id="link-601" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-601', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1298"></a><tt class="py-lineno">1298</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">[</tt><tt class="py-string">'id'</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1299"></a><tt class="py-lineno">1299</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1300"></a><tt class="py-lineno">1300</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'double'</tt><tt class="py-op">:</tt> </tt>
<a name="L1301"></a><tt class="py-lineno">1301</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">float</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1302"></a><tt class="py-lineno">1302</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-name">unicode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1303"></a><tt class="py-lineno">1303</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-602" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-602', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt><tt class="py-op">)</tt> </tt>
<a name="L1304"></a><tt class="py-lineno">1304</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> </tt>
<a name="L1305"></a><tt class="py-lineno">1305</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b64encode</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1306"></a><tt class="py-lineno">1306</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'date'</tt><tt class="py-op">:</tt> </tt>
<a name="L1307"></a><tt class="py-lineno">1307</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-603" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-603', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-604" class="py-name" targets="Class datetime.date=datetime.date-class.html"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-604', 'date', 'link-604');">date</a></tt><tt class="py-op">,</tt> <tt id="link-605" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-605', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-606" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-606', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1308"></a><tt class="py-lineno">1308</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt> </tt>
<a name="L1309"></a><tt class="py-lineno">1309</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1310"></a><tt class="py-lineno">1310</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1311"></a><tt class="py-lineno">1311</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> </tt>
<a name="L1312"></a><tt class="py-lineno">1312</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-607" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-607', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-608" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-608', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1313"></a><tt class="py-lineno">1313</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'T'</tt><tt class="py-op">,</tt><tt class="py-string">' '</tt><tt class="py-op">)</tt> </tt>
<a name="L1314"></a><tt class="py-lineno">1314</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-609" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-609', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-610" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-610', 'date', 'link-604');">date</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1315"></a><tt class="py-lineno">1315</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">+</tt><tt class="py-string">' 00:00:00'</tt> </tt>
<a name="L1316"></a><tt class="py-lineno">1316</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1317"></a><tt class="py-lineno">1317</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1318"></a><tt class="py-lineno">1318</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'time'</tt><tt class="py-op">:</tt> </tt>
<a name="L1319"></a><tt class="py-lineno">1319</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-611" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-611', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-612" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-612', 'time', 'link-4');">time</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1320"></a><tt class="py-lineno">1320</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt> </tt>
<a name="L1321"></a><tt class="py-lineno">1321</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1322"></a><tt class="py-lineno">1322</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1323"></a><tt class="py-lineno">1323</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1324"></a><tt class="py-lineno">1324</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1325"></a><tt class="py-lineno">1325</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L1326"></a><tt class="py-lineno">1326</tt>  <tt class="py-line">            <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-613" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-613', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt><tt class="py-op">)</tt> </tt>
<a name="L1327"></a><tt class="py-lineno">1327</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L1328"></a><tt class="py-lineno">1328</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-614" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-614', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-string">'latin1'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-615" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-615', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt><tt class="py-op">)</tt> </tt>
<a name="L1329"></a><tt class="py-lineno">1329</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">"'%s'"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">"'"</tt><tt class="py-op">,</tt> <tt class="py-string">"''"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1330"></a><tt class="py-lineno">1330</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.represent_exceptions"></a><div id="BaseAdapter.represent_exceptions-def"><a name="L1331"></a><tt class="py-lineno">1331</tt> <a class="py-toggle" href="#" id="BaseAdapter.represent_exceptions-toggle" onclick="return toggle('BaseAdapter.represent_exceptions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#represent_exceptions">represent_exceptions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.represent_exceptions-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.represent_exceptions-expanded"><a name="L1332"></a><tt class="py-lineno">1332</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L1333"></a><tt class="py-lineno">1333</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.lastrowid"></a><div id="BaseAdapter.lastrowid-def"><a name="L1334"></a><tt class="py-lineno">1334</tt> <a class="py-toggle" href="#" id="BaseAdapter.lastrowid-toggle" onclick="return toggle('BaseAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.lastrowid-expanded"><a name="L1335"></a><tt class="py-lineno">1335</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L1336"></a><tt class="py-lineno">1336</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.integrity_error_class"></a><div id="BaseAdapter.integrity_error_class-def"><a name="L1337"></a><tt class="py-lineno">1337</tt> <a class="py-toggle" href="#" id="BaseAdapter.integrity_error_class-toggle" onclick="return toggle('BaseAdapter.integrity_error_class');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#integrity_error_class">integrity_error_class</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.integrity_error_class-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.integrity_error_class-expanded"><a name="L1338"></a><tt class="py-lineno">1338</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1339"></a><tt class="py-lineno">1339</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.rowslice"></a><div id="BaseAdapter.rowslice-def"><a name="L1340"></a><tt class="py-lineno">1340</tt> <a class="py-toggle" href="#" id="BaseAdapter.rowslice-toggle" onclick="return toggle('BaseAdapter.rowslice');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#rowslice">rowslice</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">rows</tt><tt class="py-op">,</tt><tt class="py-param">minimum</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">maximum</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.rowslice-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.rowslice-expanded"><a name="L1341"></a><tt class="py-lineno">1341</tt>  <tt class="py-line">        <tt class="py-docstring">""" by default this function does nothing, overload when db does not do slicing """</tt> </tt>
<a name="L1342"></a><tt class="py-lineno">1342</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-616" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-616', 'rows', 'link-539');">rows</a></tt> </tt>
</div><a name="L1343"></a><tt class="py-lineno">1343</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.parse"></a><div id="BaseAdapter.parse-def"><a name="L1344"></a><tt class="py-lineno">1344</tt> <a class="py-toggle" href="#" id="BaseAdapter.parse-toggle" onclick="return toggle('BaseAdapter.parse');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#parse">parse</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">rows</tt><tt class="py-op">,</tt> <tt class="py-param">colnames</tt><tt class="py-op">,</tt> <tt class="py-param">blob_decode</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.parse-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.parse-expanded"><a name="L1345"></a><tt class="py-lineno">1345</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> </tt>
<a name="L1346"></a><tt class="py-lineno">1346</tt>  <tt class="py-line">        <tt class="py-name">virtualtables</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L1347"></a><tt class="py-lineno">1347</tt>  <tt class="py-line">        <tt class="py-name">new_rows</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L1348"></a><tt class="py-lineno">1348</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-name">row</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">enumerate</tt><tt class="py-op">(</tt><tt id="link-617" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-617', 'rows', 'link-539');">rows</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1349"></a><tt class="py-lineno">1349</tt>  <tt class="py-line">            <tt class="py-name">new_row</tt> <tt class="py-op">=</tt> <tt id="link-618" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-618', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1350"></a><tt class="py-lineno">1350</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">j</tt><tt class="py-op">,</tt><tt class="py-name">colname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">enumerate</tt><tt class="py-op">(</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1351"></a><tt class="py-lineno">1351</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">row</tt><tt class="py-op">[</tt><tt class="py-name">j</tt><tt class="py-op">]</tt> </tt>
<a name="L1352"></a><tt class="py-lineno">1352</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-619" class="py-name"><a title="web2py.gluon.dal.table_field
web2py.gluon.sqlhtml.table_field" class="py-name" href="#" onclick="return doclink('link-619', 'table_field', 'link-29');">table_field</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">colnames</tt><tt class="py-op">[</tt><tt class="py-name">j</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1353"></a><tt class="py-lineno">1353</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-string">'_extra'</tt> <tt class="py-keyword">in</tt> <tt class="py-name">new_row</tt><tt class="py-op">:</tt> </tt>
<a name="L1354"></a><tt class="py-lineno">1354</tt>  <tt class="py-line">                        <tt class="py-name">new_row</tt><tt class="py-op">[</tt><tt class="py-string">'_extra'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-620" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-620', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1355"></a><tt class="py-lineno">1355</tt>  <tt class="py-line">                    <tt class="py-name">new_row</tt><tt class="py-op">[</tt><tt class="py-string">'_extra'</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">colnames</tt><tt class="py-op">[</tt><tt class="py-name">j</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1356"></a><tt class="py-lineno">1356</tt>  <tt class="py-line">                    <tt class="py-name">select_as_parser</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">"\s+AS\s+(\S+)"</tt><tt class="py-op">)</tt> </tt>
<a name="L1357"></a><tt class="py-lineno">1357</tt>  <tt class="py-line">                    <tt class="py-name">new_column_name</tt> <tt class="py-op">=</tt> <tt class="py-name">select_as_parser</tt><tt class="py-op">.</tt><tt id="link-621" class="py-name" targets="Method web2py.gluon.tools.Crud.search()=web2py.gluon.tools.Crud-class.html#search"><a title="web2py.gluon.tools.Crud.search" class="py-name" href="#" onclick="return doclink('link-621', 'search', 'link-621');">search</a></tt><tt class="py-op">(</tt><tt class="py-name">colnames</tt><tt class="py-op">[</tt><tt class="py-name">j</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1358"></a><tt class="py-lineno">1358</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">new_column_name</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1359"></a><tt class="py-lineno">1359</tt>  <tt class="py-line">                        <tt class="py-name">column_name</tt> <tt class="py-op">=</tt> <tt class="py-name">new_column_name</tt><tt class="py-op">.</tt><tt id="link-622" class="py-name" targets="Method web2py.gluon.tools.Auth.groups()=web2py.gluon.tools.Auth-class.html#groups"><a title="web2py.gluon.tools.Auth.groups" class="py-name" href="#" onclick="return doclink('link-622', 'groups', 'link-622');">groups</a></tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">)</tt> </tt>
<a name="L1360"></a><tt class="py-lineno">1360</tt>  <tt class="py-line">                        <tt class="py-name">setattr</tt><tt class="py-op">(</tt><tt class="py-name">new_row</tt><tt class="py-op">,</tt><tt class="py-name">column_name</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L1361"></a><tt class="py-lineno">1361</tt>  <tt class="py-line">                    <tt class="py-keyword">continue</tt> </tt>
<a name="L1362"></a><tt class="py-lineno">1362</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fieldname</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">colname</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L1363"></a><tt class="py-lineno">1363</tt>  <tt class="py-line">                <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L1364"></a><tt class="py-lineno">1364</tt>  <tt class="py-line">                <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> </tt>
<a name="L1365"></a><tt class="py-lineno">1365</tt>  <tt class="py-line">                <tt class="py-name">field_type</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L1366"></a><tt class="py-lineno">1366</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'blob'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1367"></a><tt class="py-lineno">1367</tt>  <tt class="py-line">                    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L1368"></a><tt class="py-lineno">1368</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt id="link-623" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-623', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_db_codec</tt><tt class="py-op">)</tt> </tt>
<a name="L1369"></a><tt class="py-lineno">1369</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt id="link-624" class="py-name"><a title="exceptions.Exception" class="py-name" href="#" onclick="return doclink('link-624', 'Exception', 'link-328');">Exception</a></tt><tt class="py-op">:</tt> </tt>
<a name="L1370"></a><tt class="py-lineno">1370</tt>  <tt class="py-line">                        <tt class="py-keyword">pass</tt> </tt>
<a name="L1371"></a><tt class="py-lineno">1371</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">unicode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1372"></a><tt class="py-lineno">1372</tt>  <tt class="py-line">                    <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt id="link-625" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-625', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf-8'</tt><tt class="py-op">)</tt> </tt>
<a name="L1373"></a><tt class="py-lineno">1373</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">new_row</tt><tt class="py-op">:</tt> </tt>
<a name="L1374"></a><tt class="py-lineno">1374</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt> <tt class="py-op">=</tt> <tt class="py-name">new_row</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-626" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-626', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1375"></a><tt class="py-lineno">1375</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">virtualtables</tt><tt class="py-op">:</tt> </tt>
<a name="L1376"></a><tt class="py-lineno">1376</tt>  <tt class="py-line">                        <tt class="py-name">virtualtables</tt><tt class="py-op">.</tt><tt id="link-627" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-627', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L1377"></a><tt class="py-lineno">1377</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1378"></a><tt class="py-lineno">1378</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt> <tt class="py-op">=</tt> <tt class="py-name">new_row</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L1379"></a><tt class="py-lineno">1379</tt>  <tt class="py-line"> </tt>
<a name="L1380"></a><tt class="py-lineno">1380</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">,</tt> <tt id="link-628" class="py-name"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-628', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1381"></a><tt class="py-lineno">1381</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-629" class="py-name" targets="Module web2py.gluon.decoder=web2py.gluon.decoder-module.html,Function web2py.gluon.decoder.decoder()=web2py.gluon.decoder-module.html#decoder"><a title="web2py.gluon.decoder
web2py.gluon.decoder.decoder" class="py-name" href="#" onclick="return doclink('link-629', 'decoder', 'link-629');">decoder</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L1382"></a><tt class="py-lineno">1382</tt>  <tt class="py-line">                    <tt class="py-comment"># field_type = field_type.type</tt> </tt>
<a name="L1383"></a><tt class="py-lineno">1383</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">value</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1384"></a><tt class="py-lineno">1384</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1385"></a><tt class="py-lineno">1385</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L1386"></a><tt class="py-lineno">1386</tt>  <tt class="py-line">                        <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-630" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-630', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1387"></a><tt class="py-lineno">1387</tt>  <tt class="py-line">                    <tt class="py-name">referee</tt> <tt class="py-op">=</tt> <tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-631" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-631', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1388"></a><tt class="py-lineno">1388</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-string">'.'</tt> <tt class="py-keyword">in</tt> <tt class="py-name">referee</tt><tt class="py-op">:</tt> </tt>
<a name="L1389"></a><tt class="py-lineno">1389</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">rid</tt> <tt class="py-op">=</tt> <tt id="link-632" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-632', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L1390"></a><tt class="py-lineno">1390</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">rid</tt><tt class="py-op">.</tt><tt class="py-name">_table</tt><tt class="py-op">,</tt> <tt class="py-name">rid</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">referee</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1391"></a><tt class="py-lineno">1391</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-comment">### reference not by id</tt> </tt>
<a name="L1392"></a><tt class="py-lineno">1392</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1393"></a><tt class="py-lineno">1393</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> </tt>
<a name="L1394"></a><tt class="py-lineno">1394</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">value</tt> <tt class="py-op">==</tt> <tt class="py-name">True</tt> <tt class="py-keyword">or</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-633" class="py-name"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-633', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-string">'t'</tt><tt class="py-op">:</tt> </tt>
<a name="L1395"></a><tt class="py-lineno">1395</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L1396"></a><tt class="py-lineno">1396</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1397"></a><tt class="py-lineno">1397</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L1398"></a><tt class="py-lineno">1398</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'date'</tt> \ </tt>
<a name="L1399"></a><tt class="py-lineno">1399</tt>  <tt class="py-line">                        <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt id="link-634" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-634', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-635" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-635', 'date', 'link-604');">date</a></tt><tt class="py-op">)</tt>\ </tt>
<a name="L1400"></a><tt class="py-lineno">1400</tt>  <tt class="py-line">                                 <tt class="py-keyword">or</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt id="link-636" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-636', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-637" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-637', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1401"></a><tt class="py-lineno">1401</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-638" class="py-name" targets="Variable web2py.gluon.languages.lazyT.m=web2py.gluon.languages.lazyT-class.html#m"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-638', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-639" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-639', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1402"></a><tt class="py-lineno">1402</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-640" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-640', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-641" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-641', 'date', 'link-604');">date</a></tt><tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-642" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-642', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> </tt>
<a name="L1403"></a><tt class="py-lineno">1403</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'time'</tt> \ </tt>
<a name="L1404"></a><tt class="py-lineno">1404</tt>  <tt class="py-line">                        <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt id="link-643" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-643', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-644" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-644', 'time', 'link-4');">time</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1405"></a><tt class="py-lineno">1405</tt>  <tt class="py-line">                    <tt class="py-name">time_items</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">8</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-645" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-645', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">3</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1406"></a><tt class="py-lineno">1406</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt id="link-646" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-646', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">time_items</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt>
<a name="L1407"></a><tt class="py-lineno">1407</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-647" class="py-name" targets="Variable web2py.gluon.languages.lazyT.s=web2py.gluon.languages.lazyT-class.html#s"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-647', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> </tt>
<a name="L1408"></a><tt class="py-lineno">1408</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1409"></a><tt class="py-lineno">1409</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-648" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-648', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> <tt class="py-op">+</tt> <tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L1410"></a><tt class="py-lineno">1410</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-649" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-649', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-650" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-650', 'time', 'link-4');">time</a></tt><tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-651" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-651', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1411"></a><tt class="py-lineno">1411</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt>\ </tt>
<a name="L1412"></a><tt class="py-lineno">1412</tt>  <tt class="py-line">                        <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt id="link-652" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-652', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-653" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-653', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1413"></a><tt class="py-lineno">1413</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-654" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-654', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-655" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-655', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1414"></a><tt class="py-lineno">1414</tt>  <tt class="py-line">                    <tt class="py-name">time_items</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">11</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-656" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-656', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">3</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1415"></a><tt class="py-lineno">1415</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt id="link-657" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-657', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">time_items</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt>
<a name="L1416"></a><tt class="py-lineno">1416</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-658" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-658', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> </tt>
<a name="L1417"></a><tt class="py-lineno">1417</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1418"></a><tt class="py-lineno">1418</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-659" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-659', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> <tt class="py-op">+</tt> <tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L1419"></a><tt class="py-lineno">1419</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-660" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-660', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-661" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-661', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-662" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-662', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">,</tt> <tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-663" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-663', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1420"></a><tt class="py-lineno">1420</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'blob'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">blob_decode</tt><tt class="py-op">:</tt> </tt>
<a name="L1421"></a><tt class="py-lineno">1421</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b64decode</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1422"></a><tt class="py-lineno">1422</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-664" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-664', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'decimal'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1423"></a><tt class="py-lineno">1423</tt>  <tt class="py-line">                    <tt class="py-name">decimals</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">8</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">','</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1424"></a><tt class="py-lineno">1424</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">==</tt> <tt class="py-string">'sqlite'</tt><tt class="py-op">:</tt> </tt>
<a name="L1425"></a><tt class="py-lineno">1425</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">'%.'</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">decimals</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">'f'</tt><tt class="py-op">)</tt> <tt class="py-op">%</tt> <tt class="py-name">value</tt> </tt>
<a name="L1426"></a><tt class="py-lineno">1426</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1427"></a><tt class="py-lineno">1427</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1428"></a><tt class="py-lineno">1428</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1429"></a><tt class="py-lineno">1429</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-665" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-665', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:integer'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1430"></a><tt class="py-lineno">1430</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'google:datastore'</tt><tt class="py-op">:</tt> </tt>
<a name="L1431"></a><tt class="py-lineno">1431</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-666" class="py-name" targets="Function web2py.gluon.dal.bar_decode_integer()=web2py.gluon.dal-module.html#bar_decode_integer"><a title="web2py.gluon.dal.bar_decode_integer" class="py-name" href="#" onclick="return doclink('link-666', 'bar_decode_integer', 'link-666');">bar_decode_integer</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L1432"></a><tt class="py-lineno">1432</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1433"></a><tt class="py-lineno">1433</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1434"></a><tt class="py-lineno">1434</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-667" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-667', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1435"></a><tt class="py-lineno">1435</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'google:datastore'</tt><tt class="py-op">:</tt> </tt>
<a name="L1436"></a><tt class="py-lineno">1436</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-668" class="py-name"><a title="web2py.gluon.dal.bar_decode_integer" class="py-name" href="#" onclick="return doclink('link-668', 'bar_decode_integer', 'link-666');">bar_decode_integer</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L1437"></a><tt class="py-lineno">1437</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1438"></a><tt class="py-lineno">1438</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1439"></a><tt class="py-lineno">1439</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-669" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-669', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:string'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1440"></a><tt class="py-lineno">1440</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'google:datastore'</tt><tt class="py-op">:</tt> </tt>
<a name="L1441"></a><tt class="py-lineno">1441</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-670" class="py-name" targets="Function web2py.gluon.dal.bar_decode_string()=web2py.gluon.dal-module.html#bar_decode_string"><a title="web2py.gluon.dal.bar_decode_string" class="py-name" href="#" onclick="return doclink('link-670', 'bar_decode_string', 'link-670');">bar_decode_string</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L1442"></a><tt class="py-lineno">1442</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1443"></a><tt class="py-lineno">1443</tt>  <tt class="py-line">                        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1444"></a><tt class="py-lineno">1444</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1445"></a><tt class="py-lineno">1445</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
<a name="L1446"></a><tt class="py-lineno">1446</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L1447"></a><tt class="py-lineno">1447</tt>  <tt class="py-line">                    <tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-671" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-671', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> </tt>
<a name="L1448"></a><tt class="py-lineno">1448</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">.</tt><tt id="link-672" class="py-name" targets="Function web2py.gluon.dal.update_record()=web2py.gluon.dal-module.html#update_record"><a title="web2py.gluon.dal.update_record" class="py-name" href="#" onclick="return doclink('link-672', 'update_record', 'link-672');">update_record</a></tt> <tt class="py-op">=</tt> <tt class="py-keyword">lambda</tt> <tt class="py-name">_</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">colset</tt><tt class="py-op">,</tt> <tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-name">a</tt><tt class="py-op">:</tt> <tt id="link-673" class="py-name"><a title="web2py.gluon.dal.update_record" class="py-name" href="#" onclick="return doclink('link-673', 'update_record', 'link-672');">update_record</a></tt><tt class="py-op">(</tt><tt class="py-name">_</tt><tt class="py-op">,</tt> <tt class="py-name">a</tt><tt class="py-op">)</tt> </tt>
<a name="L1449"></a><tt class="py-lineno">1449</tt>  <tt class="py-line">                    <tt class="py-name">colset</tt><tt class="py-op">.</tt><tt class="py-name">delete_record</tt> <tt class="py-op">=</tt> <tt class="py-keyword">lambda</tt> <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">id</tt><tt class="py-op">:</tt> <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">==</tt><tt class="py-name">i</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-674" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-674', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1450"></a><tt class="py-lineno">1450</tt>  <tt class="py-line">                    <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">referee_table</tt><tt class="py-op">,</tt> <tt class="py-name">referee_name</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> \ </tt>
<a name="L1451"></a><tt class="py-lineno">1451</tt>  <tt class="py-line">                            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt><tt class="py-op">:</tt> </tt>
<a name="L1452"></a><tt class="py-lineno">1452</tt>  <tt class="py-line">                        <tt id="link-675" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-675', 's', 'link-647');">s</a></tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">referee_table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">referee_name</tt><tt class="py-op">]</tt> </tt>
<a name="L1453"></a><tt class="py-lineno">1453</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">referee_table</tt> <tt class="py-keyword">in</tt> <tt class="py-name">colset</tt><tt class="py-op">:</tt> </tt>
<a name="L1454"></a><tt class="py-lineno">1454</tt>  <tt class="py-line">                            <tt class="py-comment"># for backward compatibility</tt> </tt>
<a name="L1455"></a><tt class="py-lineno">1455</tt>  <tt class="py-line"><tt class="py-comment"></tt>                            <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-name">referee_table</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-676" class="py-name" targets="Class web2py.gluon.dal.Set=web2py.gluon.dal.Set-class.html"><a title="web2py.gluon.dal.Set" class="py-name" href="#" onclick="return doclink('link-676', 'Set', 'link-676');">Set</a></tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt id="link-677" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-677', 's', 'link-647');">s</a></tt> <tt class="py-op">==</tt> <tt class="py-name">id</tt><tt class="py-op">)</tt> </tt>
<a name="L1456"></a><tt class="py-lineno">1456</tt>  <tt class="py-line">                        <tt class="py-comment">### add new feature?</tt> </tt>
<a name="L1457"></a><tt class="py-lineno">1457</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-comment">### colset[referee_table+'_by_'+refree_name] = Set(db, s == id)</tt> </tt>
<a name="L1458"></a><tt class="py-lineno">1458</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt class="py-string">'id'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">id</tt> </tt>
<a name="L1459"></a><tt class="py-lineno">1459</tt>  <tt class="py-line">            <tt class="py-name">new_rows</tt><tt class="py-op">.</tt><tt id="link-678" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-678', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">new_row</tt><tt class="py-op">)</tt> </tt>
<a name="L1460"></a><tt class="py-lineno">1460</tt>  <tt class="py-line">        <tt class="py-name">rowsobj</tt> <tt class="py-op">=</tt> <tt id="link-679" class="py-name" targets="Class web2py.gluon.dal.Rows=web2py.gluon.dal.Rows-class.html"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-679', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">new_rows</tt><tt class="py-op">,</tt> <tt class="py-name">colnames</tt><tt class="py-op">,</tt> <tt class="py-name">rawrows</tt><tt class="py-op">=</tt><tt id="link-680" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-680', 'rows', 'link-539');">rows</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1461"></a><tt class="py-lineno">1461</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">virtualtables</tt><tt class="py-op">:</tt> </tt>
<a name="L1462"></a><tt class="py-lineno">1462</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">virtualfields</tt><tt class="py-op">:</tt> </tt>
<a name="L1463"></a><tt class="py-lineno">1463</tt>  <tt class="py-line">                <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L1464"></a><tt class="py-lineno">1464</tt>  <tt class="py-line">                    <tt class="py-name">rowsobj</tt> <tt class="py-op">=</tt> <tt class="py-name">rowsobj</tt><tt class="py-op">.</tt><tt id="link-681" class="py-name" targets="Method web2py.gluon.dal.Rows.setvirtualfields()=web2py.gluon.dal.Rows-class.html#setvirtualfields"><a title="web2py.gluon.dal.Rows.setvirtualfields" class="py-name" href="#" onclick="return doclink('link-681', 'setvirtualfields', 'link-681');">setvirtualfields</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-op">{</tt><tt class="py-name">tablename</tt><tt class="py-op">:</tt><tt class="py-name">item</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L1465"></a><tt class="py-lineno">1465</tt>  <tt class="py-line">                <tt class="py-keyword">except</tt> <tt class="py-name">KeyError</tt><tt class="py-op">:</tt> </tt>
<a name="L1466"></a><tt class="py-lineno">1466</tt>  <tt class="py-line">                    <tt class="py-comment"># to avoid breaking virtualfields when partial select</tt> </tt>
<a name="L1467"></a><tt class="py-lineno">1467</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-keyword">pass</tt> </tt>
<a name="L1468"></a><tt class="py-lineno">1468</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">rowsobj</tt> </tt>
</div><a name="L1469"></a><tt class="py-lineno">1469</tt>  <tt class="py-line"> </tt>
<a name="BaseAdapter.filter_tenant"></a><div id="BaseAdapter.filter_tenant-def"><a name="L1470"></a><tt class="py-lineno">1470</tt> <a class="py-toggle" href="#" id="BaseAdapter.filter_tenant-toggle" onclick="return toggle('BaseAdapter.filter_tenant');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.BaseAdapter-class.html#filter_tenant">filter_tenant</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">tablenames</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="BaseAdapter.filter_tenant-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="BaseAdapter.filter_tenant-expanded"><a name="L1471"></a><tt class="py-lineno">1471</tt>  <tt class="py-line">        <tt class="py-name">fieldname</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_request_tenant</tt> </tt>
<a name="L1472"></a><tt class="py-lineno">1472</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">tablenames</tt><tt class="py-op">:</tt> </tt>
<a name="L1473"></a><tt class="py-lineno">1473</tt>  <tt class="py-line">            <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L1474"></a><tt class="py-lineno">1474</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">fieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">:</tt> </tt>
<a name="L1475"></a><tt class="py-lineno">1475</tt>  <tt class="py-line">                <tt class="py-name">default</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">default</tt> </tt>
<a name="L1476"></a><tt class="py-lineno">1476</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">default</tt><tt class="py-op">!=</tt><tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L1477"></a><tt class="py-lineno">1477</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">&amp;</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-name">default</tt><tt class="py-op">)</tt> </tt>
<a name="L1478"></a><tt class="py-lineno">1478</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">query</tt> </tt>
</div></div><a name="L1479"></a><tt class="py-lineno">1479</tt>  <tt class="py-line"> </tt>
<a name="L1480"></a><tt class="py-lineno">1480</tt>  <tt class="py-line"><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L1481"></a><tt class="py-lineno">1481</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># List of all the available adapters, they all extend BaseAdapter</tt> </tt>
<a name="L1482"></a><tt class="py-lineno">1482</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">###################################################################################</tt> </tt>
<a name="L1483"></a><tt class="py-lineno">1483</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="SQLiteAdapter"></a><div id="SQLiteAdapter-def"><a name="L1484"></a><tt class="py-lineno">1484</tt> <a class="py-toggle" href="#" id="SQLiteAdapter-toggle" onclick="return toggle('SQLiteAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLiteAdapter-class.html">SQLiteAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLiteAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="SQLiteAdapter-expanded"><a name="L1485"></a><tt class="py-lineno">1485</tt>  <tt class="py-line"> </tt>
<a name="L1486"></a><tt class="py-lineno">1486</tt>  <tt class="py-line">    <tt id="link-682" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-682', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-683" class="py-name" targets="Module web2py.gluon.globals=web2py.gluon.globals-module.html"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-683', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-684" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-684', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'sqlite3'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1487"></a><tt class="py-lineno">1487</tt>  <tt class="py-line"> </tt>
<a name="SQLiteAdapter.EXTRACT"></a><div id="SQLiteAdapter.EXTRACT-def"><a name="L1488"></a><tt class="py-lineno">1488</tt> <a class="py-toggle" href="#" id="SQLiteAdapter.EXTRACT-toggle" onclick="return toggle('SQLiteAdapter.EXTRACT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLiteAdapter-class.html#EXTRACT">EXTRACT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">what</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLiteAdapter.EXTRACT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLiteAdapter.EXTRACT-expanded"><a name="L1489"></a><tt class="py-lineno">1489</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">"web2py_extract('%s',%s)"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">what</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-685" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-685', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1490"></a><tt class="py-lineno">1490</tt>  <tt class="py-line"> </tt>
<a name="L1491"></a><tt class="py-lineno">1491</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="SQLiteAdapter.web2py_extract"></a><div id="SQLiteAdapter.web2py_extract-def"><a name="L1492"></a><tt class="py-lineno">1492</tt> <a class="py-toggle" href="#" id="SQLiteAdapter.web2py_extract-toggle" onclick="return toggle('SQLiteAdapter.web2py_extract');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLiteAdapter-class.html#web2py_extract">web2py_extract</a><tt class="py-op">(</tt><tt class="py-param">lookup</tt><tt class="py-op">,</tt> <tt class="py-param">s</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLiteAdapter.web2py_extract-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLiteAdapter.web2py_extract-expanded"><a name="L1493"></a><tt class="py-lineno">1493</tt>  <tt class="py-line">        <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L1494"></a><tt class="py-lineno">1494</tt>  <tt class="py-line">            <tt class="py-string">'year'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-number">4</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1495"></a><tt class="py-lineno">1495</tt>  <tt class="py-line">            <tt class="py-string">'month'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-number">5</tt><tt class="py-op">,</tt> <tt class="py-number">7</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1496"></a><tt class="py-lineno">1496</tt>  <tt class="py-line">            <tt class="py-string">'day'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-number">8</tt><tt class="py-op">,</tt> <tt class="py-number">10</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1497"></a><tt class="py-lineno">1497</tt>  <tt class="py-line">            <tt class="py-string">'hour'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-number">11</tt><tt class="py-op">,</tt> <tt class="py-number">13</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1498"></a><tt class="py-lineno">1498</tt>  <tt class="py-line">            <tt class="py-string">'minute'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-number">14</tt><tt class="py-op">,</tt> <tt class="py-number">16</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1499"></a><tt class="py-lineno">1499</tt>  <tt class="py-line">            <tt class="py-string">'second'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-number">17</tt><tt class="py-op">,</tt> <tt class="py-number">19</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1500"></a><tt class="py-lineno">1500</tt>  <tt class="py-line">            <tt class="py-op">}</tt> </tt>
<a name="L1501"></a><tt class="py-lineno">1501</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L1502"></a><tt class="py-lineno">1502</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">j</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">lookup</tt><tt class="py-op">]</tt> </tt>
<a name="L1503"></a><tt class="py-lineno">1503</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt id="link-686" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-686', 's', 'link-647');">s</a></tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">:</tt><tt class="py-name">j</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1504"></a><tt class="py-lineno">1504</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L1505"></a><tt class="py-lineno">1505</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L1506"></a><tt class="py-lineno">1506</tt>  <tt class="py-line"> </tt>
<a name="SQLiteAdapter.__init__"></a><div id="SQLiteAdapter.__init__-def"><a name="L1507"></a><tt class="py-lineno">1507</tt> <a class="py-toggle" href="#" id="SQLiteAdapter.__init__-toggle" onclick="return toggle('SQLiteAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLiteAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1508"></a><tt class="py-lineno">1508</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-687" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-687', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-688" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-688', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L1509"></a><tt class="py-lineno">1509</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLiteAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLiteAdapter.__init__-expanded"><a name="L1510"></a><tt class="py-lineno">1510</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L1511"></a><tt class="py-lineno">1511</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"sqlite"</tt> </tt>
<a name="L1512"></a><tt class="py-lineno">1512</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L1513"></a><tt class="py-lineno">1513</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L1514"></a><tt class="py-lineno">1514</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L1515"></a><tt class="py-lineno">1515</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L1516"></a><tt class="py-lineno">1516</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-689" class="py-name" targets="Method web2py.gluon.dal.ConnectionPool.find_or_make_work_folder()=web2py.gluon.dal.ConnectionPool-class.html#find_or_make_work_folder"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-689', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1517"></a><tt class="py-lineno">1517</tt>  <tt class="py-line">        <tt class="py-name">path_encoding</tt> <tt class="py-op">=</tt> <tt class="py-name">sys</tt><tt class="py-op">.</tt><tt class="py-name">getfilesystemencoding</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">locale</tt><tt class="py-op">.</tt><tt class="py-name">getdefaultlocale</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'utf8'</tt> </tt>
<a name="L1518"></a><tt class="py-lineno">1518</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt id="link-690" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-690', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'sqlite:memory'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1519"></a><tt class="py-lineno">1519</tt>  <tt class="py-line">            <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-string">':memory:'</tt> </tt>
<a name="L1520"></a><tt class="py-lineno">1520</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1521"></a><tt class="py-lineno">1521</tt>  <tt class="py-line">            <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L1522"></a><tt class="py-lineno">1522</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">dbpath</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-string">'/'</tt><tt class="py-op">:</tt> </tt>
<a name="L1523"></a><tt class="py-lineno">1523</tt>  <tt class="py-line">                <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-691" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-691', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">.</tt><tt id="link-692" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-692', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-name">path_encoding</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-693" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-693', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">dbpath</tt><tt class="py-op">)</tt> </tt>
<a name="L1524"></a><tt class="py-lineno">1524</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-string">'check_same_thread'</tt> <tt class="py-keyword">in</tt> <tt class="py-name">driver_args</tt><tt class="py-op">:</tt> </tt>
<a name="L1525"></a><tt class="py-lineno">1525</tt>  <tt class="py-line">            <tt class="py-name">driver_args</tt><tt class="py-op">[</tt><tt class="py-string">'check_same_thread'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L1526"></a><tt class="py-lineno">1526</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">dbpath</tt><tt class="py-op">=</tt><tt class="py-name">dbpath</tt><tt class="py-op">,</tt> <tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1527"></a><tt class="py-lineno">1527</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-694" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-694', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-695" class="py-name" targets="Class web2py.gluon.rocket.Connection=web2py.gluon.rocket.Connection-class.html"><a title="web2py.gluon.rocket.Connection" class="py-name" href="#" onclick="return doclink('link-695', 'Connection', 'link-695');">Connection</a></tt><tt class="py-op">(</tt><tt class="py-name">dbpath</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1528"></a><tt class="py-lineno">1528</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-696" class="py-name" targets="Method web2py.gluon.dal.ConnectionPool.pool_connection()=web2py.gluon.dal.ConnectionPool-class.html#pool_connection"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-696', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-697" class="py-name" targets="Method web2py.gluon.globals.Session.connect()=web2py.gluon.globals.Session-class.html#connect"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-697', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1529"></a><tt class="py-lineno">1529</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1530"></a><tt class="py-lineno">1530</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">create_function</tt><tt class="py-op">(</tt><tt class="py-string">'web2py_extract'</tt><tt class="py-op">,</tt> <tt class="py-number">2</tt><tt class="py-op">,</tt> <tt id="link-698" class="py-name" targets="Class web2py.gluon.dal.SQLiteAdapter=web2py.gluon.dal.SQLiteAdapter-class.html"><a title="web2py.gluon.dal.SQLiteAdapter" class="py-name" href="#" onclick="return doclink('link-698', 'SQLiteAdapter', 'link-698');">SQLiteAdapter</a></tt><tt class="py-op">.</tt><tt id="link-699" class="py-name" targets="Static Method web2py.gluon.dal.SQLiteAdapter.web2py_extract()=web2py.gluon.dal.SQLiteAdapter-class.html#web2py_extract"><a title="web2py.gluon.dal.SQLiteAdapter.web2py_extract" class="py-name" href="#" onclick="return doclink('link-699', 'web2py_extract', 'link-699');">web2py_extract</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L1531"></a><tt class="py-lineno">1531</tt>  <tt class="py-line"> </tt>
<a name="SQLiteAdapter._truncate"></a><div id="SQLiteAdapter._truncate-def"><a name="L1532"></a><tt class="py-lineno">1532</tt> <a class="py-toggle" href="#" id="SQLiteAdapter._truncate-toggle" onclick="return toggle('SQLiteAdapter._truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLiteAdapter-class.html#_truncate">_truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLiteAdapter._truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLiteAdapter._truncate-expanded"><a name="L1533"></a><tt class="py-lineno">1533</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L1534"></a><tt class="py-lineno">1534</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'DELETE FROM %s;'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L1535"></a><tt class="py-lineno">1535</tt>  <tt class="py-line">                <tt class="py-string">"DELETE FROM sqlite_sequence WHERE name='%s';"</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
</div><a name="L1536"></a><tt class="py-lineno">1536</tt>  <tt class="py-line"> </tt>
<a name="SQLiteAdapter.lastrowid"></a><div id="SQLiteAdapter.lastrowid-def"><a name="L1537"></a><tt class="py-lineno">1537</tt> <a class="py-toggle" href="#" id="SQLiteAdapter.lastrowid-toggle" onclick="return toggle('SQLiteAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLiteAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLiteAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLiteAdapter.lastrowid-expanded"><a name="L1538"></a><tt class="py-lineno">1538</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt id="link-700" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.lastrowid
web2py.gluon.dal.DB2Adapter.lastrowid
web2py.gluon.dal.FireBirdAdapter.lastrowid
web2py.gluon.dal.InformixAdapter.lastrowid
web2py.gluon.dal.IngresAdapter.lastrowid
web2py.gluon.dal.MSSQLAdapter.lastrowid
web2py.gluon.dal.MySQLAdapter.lastrowid
web2py.gluon.dal.NoSQLAdapter.lastrowid
web2py.gluon.dal.OracleAdapter.lastrowid
web2py.gluon.dal.PostgreSQLAdapter.lastrowid
web2py.gluon.dal.SAPDBAdapter.lastrowid
web2py.gluon.dal.SQLiteAdapter.lastrowid" class="py-name" href="#" onclick="return doclink('link-700', 'lastrowid', 'link-187');">lastrowid</a></tt> </tt>
</div></div><a name="L1539"></a><tt class="py-lineno">1539</tt>  <tt class="py-line"> </tt>
<a name="L1540"></a><tt class="py-lineno">1540</tt>  <tt class="py-line"> </tt>
<a name="JDBCSQLiteAdapter"></a><div id="JDBCSQLiteAdapter-def"><a name="L1541"></a><tt class="py-lineno">1541</tt> <a class="py-toggle" href="#" id="JDBCSQLiteAdapter-toggle" onclick="return toggle('JDBCSQLiteAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.JDBCSQLiteAdapter-class.html">JDBCSQLiteAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">SQLiteAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="JDBCSQLiteAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="JDBCSQLiteAdapter-expanded"><a name="L1542"></a><tt class="py-lineno">1542</tt>  <tt class="py-line"> </tt>
<a name="L1543"></a><tt class="py-lineno">1543</tt>  <tt class="py-line">    <tt id="link-701" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-701', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-702" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-702', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-703" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-703', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'zxJDBC'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1544"></a><tt class="py-lineno">1544</tt>  <tt class="py-line"> </tt>
<a name="JDBCSQLiteAdapter.__init__"></a><div id="JDBCSQLiteAdapter.__init__-def"><a name="L1545"></a><tt class="py-lineno">1545</tt> <a class="py-toggle" href="#" id="JDBCSQLiteAdapter.__init__-toggle" onclick="return toggle('JDBCSQLiteAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.JDBCSQLiteAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1546"></a><tt class="py-lineno">1546</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-704" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-704', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-705" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-705', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L1547"></a><tt class="py-lineno">1547</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="JDBCSQLiteAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="JDBCSQLiteAdapter.__init__-expanded"><a name="L1548"></a><tt class="py-lineno">1548</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L1549"></a><tt class="py-lineno">1549</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"sqlite"</tt> </tt>
<a name="L1550"></a><tt class="py-lineno">1550</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L1551"></a><tt class="py-lineno">1551</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L1552"></a><tt class="py-lineno">1552</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L1553"></a><tt class="py-lineno">1553</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L1554"></a><tt class="py-lineno">1554</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-706" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-706', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1555"></a><tt class="py-lineno">1555</tt>  <tt class="py-line">        <tt class="py-name">path_encoding</tt> <tt class="py-op">=</tt> <tt class="py-name">sys</tt><tt class="py-op">.</tt><tt class="py-name">getfilesystemencoding</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">locale</tt><tt class="py-op">.</tt><tt class="py-name">getdefaultlocale</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'utf8'</tt> </tt>
<a name="L1556"></a><tt class="py-lineno">1556</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt id="link-707" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-707', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'sqlite:memory'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1557"></a><tt class="py-lineno">1557</tt>  <tt class="py-line">            <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-string">':memory:'</tt> </tt>
<a name="L1558"></a><tt class="py-lineno">1558</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1559"></a><tt class="py-lineno">1559</tt>  <tt class="py-line">            <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L1560"></a><tt class="py-lineno">1560</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">dbpath</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-string">'/'</tt><tt class="py-op">:</tt> </tt>
<a name="L1561"></a><tt class="py-lineno">1561</tt>  <tt class="py-line">                <tt class="py-name">dbpath</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-708" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-708', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">.</tt><tt id="link-709" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-709', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-name">path_encoding</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-710" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-710', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">dbpath</tt><tt class="py-op">)</tt> </tt>
<a name="L1562"></a><tt class="py-lineno">1562</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">dbpath</tt><tt class="py-op">=</tt><tt class="py-name">dbpath</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1563"></a><tt class="py-lineno">1563</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-711" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-711', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-712" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-712', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">java</tt><tt class="py-op">.</tt><tt id="link-713" class="py-name"><a title="web2py.gluon.sql" class="py-name" href="#" onclick="return doclink('link-713', 'sql', 'link-88');">sql</a></tt><tt class="py-op">.</tt><tt class="py-name">DriverManager</tt><tt class="py-op">.</tt><tt class="py-name">getConnection</tt><tt class="py-op">(</tt><tt class="py-string">'jdbc:sqlite:'</tt><tt class="py-op">+</tt><tt class="py-name">dbpath</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1564"></a><tt class="py-lineno">1564</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-714" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-714', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-715" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-715', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1565"></a><tt class="py-lineno">1565</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1566"></a><tt class="py-lineno">1566</tt>  <tt class="py-line">        <tt class="py-comment"># FIXME http://www.zentus.com/sqlitejdbc/custom_functions.html for UDFs</tt> </tt>
<a name="L1567"></a><tt class="py-lineno">1567</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment"># self.connection.create_function('web2py_extract', 2, SQLiteAdapter.web2py_extract)</tt> </tt>
<a name="L1568"></a><tt class="py-lineno">1568</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="JDBCSQLiteAdapter.execute"></a><div id="JDBCSQLiteAdapter.execute-def"><a name="L1569"></a><tt class="py-lineno">1569</tt> <a class="py-toggle" href="#" id="JDBCSQLiteAdapter.execute-toggle" onclick="return toggle('JDBCSQLiteAdapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.JDBCSQLiteAdapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">a</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="JDBCSQLiteAdapter.execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="JDBCSQLiteAdapter.execute-expanded"><a name="L1570"></a><tt class="py-lineno">1570</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-716" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.log_execute
web2py.gluon.dal.NoSQLAdapter.log_execute" class="py-name" href="#" onclick="return doclink('link-716', 'log_execute', 'link-587');">log_execute</a></tt><tt class="py-op">(</tt><tt class="py-name">a</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L1571"></a><tt class="py-lineno">1571</tt>  <tt class="py-line"> </tt>
<a name="L1572"></a><tt class="py-lineno">1572</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter"></a><div id="MySQLAdapter-def"><a name="L1573"></a><tt class="py-lineno">1573</tt> <a class="py-toggle" href="#" id="MySQLAdapter-toggle" onclick="return toggle('MySQLAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html">MySQLAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="MySQLAdapter-expanded"><a name="L1574"></a><tt class="py-lineno">1574</tt>  <tt class="py-line"> </tt>
<a name="L1575"></a><tt class="py-lineno">1575</tt>  <tt class="py-line">    <tt id="link-717" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-717', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-718" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-718', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-719" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-719', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'pymysql'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1576"></a><tt class="py-lineno">1576</tt>  <tt class="py-line">    <tt id="link-720" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.maxcharlength
web2py.gluon.dal.MySQLAdapter.maxcharlength" class="py-name" href="#" onclick="return doclink('link-720', 'maxcharlength', 'link-160');">maxcharlength</a></tt> <tt class="py-op">=</tt> <tt class="py-number">255</tt> </tt>
<a name="L1577"></a><tt class="py-lineno">1577</tt>  <tt class="py-line">    <tt id="link-721" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit_on_alter_table
web2py.gluon.dal.FireBirdAdapter.commit_on_alter_table
web2py.gluon.dal.MySQLAdapter.commit_on_alter_table
web2py.gluon.dal.OracleAdapter.commit_on_alter_table" class="py-name" href="#" onclick="return doclink('link-721', 'commit_on_alter_table', 'link-162');">commit_on_alter_table</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L1578"></a><tt class="py-lineno">1578</tt>  <tt class="py-line">    <tt id="link-722" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-722', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L1579"></a><tt class="py-lineno">1579</tt>  <tt class="py-line">    <tt id="link-723" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-723', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L1580"></a><tt class="py-lineno">1580</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1581"></a><tt class="py-lineno">1581</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1582"></a><tt class="py-lineno">1582</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONGTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1583"></a><tt class="py-lineno">1583</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1584"></a><tt class="py-lineno">1584</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONGBLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L1585"></a><tt class="py-lineno">1585</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1586"></a><tt class="py-lineno">1586</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1587"></a><tt class="py-lineno">1587</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'DOUBLE'</tt><tt class="py-op">,</tt> </tt>
<a name="L1588"></a><tt class="py-lineno">1588</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1589"></a><tt class="py-lineno">1589</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L1590"></a><tt class="py-lineno">1590</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L1591"></a><tt class="py-lineno">1591</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATETIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L1592"></a><tt class="py-lineno">1592</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT AUTO_INCREMENT NOT NULL'</tt><tt class="py-op">,</tt> </tt>
<a name="L1593"></a><tt class="py-lineno">1593</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT, INDEX %(field_name)s__idx (%(field_name)s), FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L1594"></a><tt class="py-lineno">1594</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONGTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1595"></a><tt class="py-lineno">1595</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONGTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1596"></a><tt class="py-lineno">1596</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONGTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1597"></a><tt class="py-lineno">1597</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L1598"></a><tt class="py-lineno">1598</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.RANDOM"></a><div id="MySQLAdapter.RANDOM-def"><a name="L1599"></a><tt class="py-lineno">1599</tt> <a class="py-toggle" href="#" id="MySQLAdapter.RANDOM-toggle" onclick="return toggle('MySQLAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.RANDOM-expanded"><a name="L1600"></a><tt class="py-lineno">1600</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'RAND()'</tt> </tt>
</div><a name="L1601"></a><tt class="py-lineno">1601</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.SUBSTRING"></a><div id="MySQLAdapter.SUBSTRING-def"><a name="L1602"></a><tt class="py-lineno">1602</tt> <a class="py-toggle" href="#" id="MySQLAdapter.SUBSTRING-toggle" onclick="return toggle('MySQLAdapter.SUBSTRING');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#SUBSTRING">SUBSTRING</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">parameters</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.SUBSTRING-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.SUBSTRING-expanded"><a name="L1603"></a><tt class="py-lineno">1603</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SUBSTRING(%s,%s,%s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-724" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-724', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1604"></a><tt class="py-lineno">1604</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter._drop"></a><div id="MySQLAdapter._drop-def"><a name="L1605"></a><tt class="py-lineno">1605</tt> <a class="py-toggle" href="#" id="MySQLAdapter._drop-toggle" onclick="return toggle('MySQLAdapter._drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#_drop">_drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter._drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter._drop-expanded"><a name="L1606"></a><tt class="py-lineno">1606</tt>  <tt class="py-line">        <tt class="py-comment"># breaks db integrity but without this mysql does not drop table</tt> </tt>
<a name="L1607"></a><tt class="py-lineno">1607</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'SET FOREIGN_KEY_CHECKS=0;'</tt><tt class="py-op">,</tt><tt class="py-string">'DROP TABLE %s;'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-string">'SET FOREIGN_KEY_CHECKS=1;'</tt><tt class="py-op">]</tt> </tt>
</div><a name="L1608"></a><tt class="py-lineno">1608</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.distributed_transaction_begin"></a><div id="MySQLAdapter.distributed_transaction_begin-def"><a name="L1609"></a><tt class="py-lineno">1609</tt> <a class="py-toggle" href="#" id="MySQLAdapter.distributed_transaction_begin-toggle" onclick="return toggle('MySQLAdapter.distributed_transaction_begin');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#distributed_transaction_begin">distributed_transaction_begin</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.distributed_transaction_begin-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.distributed_transaction_begin-expanded"><a name="L1610"></a><tt class="py-lineno">1610</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-725" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-725', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'XA START;'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1611"></a><tt class="py-lineno">1611</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.prepare"></a><div id="MySQLAdapter.prepare-def"><a name="L1612"></a><tt class="py-lineno">1612</tt> <a class="py-toggle" href="#" id="MySQLAdapter.prepare-toggle" onclick="return toggle('MySQLAdapter.prepare');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#prepare">prepare</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.prepare-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.prepare-expanded"><a name="L1613"></a><tt class="py-lineno">1613</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-726" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-726', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"XA END;"</tt><tt class="py-op">)</tt> </tt>
<a name="L1614"></a><tt class="py-lineno">1614</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-727" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-727', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"XA PREPARE;"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1615"></a><tt class="py-lineno">1615</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.commit_prepared"></a><div id="MySQLAdapter.commit_prepared-def"><a name="L1616"></a><tt class="py-lineno">1616</tt> <a class="py-toggle" href="#" id="MySQLAdapter.commit_prepared-toggle" onclick="return toggle('MySQLAdapter.commit_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#commit_prepared">commit_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">ley</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.commit_prepared-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.commit_prepared-expanded"><a name="L1617"></a><tt class="py-lineno">1617</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-728" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-728', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"XA COMMIT;"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1618"></a><tt class="py-lineno">1618</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.rollback_prepared"></a><div id="MySQLAdapter.rollback_prepared-def"><a name="L1619"></a><tt class="py-lineno">1619</tt> <a class="py-toggle" href="#" id="MySQLAdapter.rollback_prepared-toggle" onclick="return toggle('MySQLAdapter.rollback_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#rollback_prepared">rollback_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.rollback_prepared-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.rollback_prepared-expanded"><a name="L1620"></a><tt class="py-lineno">1620</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-729" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-729', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"XA ROLLBACK;"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1621"></a><tt class="py-lineno">1621</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.concat_add"></a><div id="MySQLAdapter.concat_add-def"><a name="L1622"></a><tt class="py-lineno">1622</tt> <a class="py-toggle" href="#" id="MySQLAdapter.concat_add-toggle" onclick="return toggle('MySQLAdapter.concat_add');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#concat_add">concat_add</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.concat_add-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.concat_add-expanded"><a name="L1623"></a><tt class="py-lineno">1623</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'; ALTER TABLE %s ADD '</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt> </tt>
</div><a name="L1624"></a><tt class="py-lineno">1624</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.__init__"></a><div id="MySQLAdapter.__init__-def"><a name="L1625"></a><tt class="py-lineno">1625</tt> <a class="py-toggle" href="#" id="MySQLAdapter.__init__-toggle" onclick="return toggle('MySQLAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1626"></a><tt class="py-lineno">1626</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-730" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-730', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-731" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-731', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L1627"></a><tt class="py-lineno">1627</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.__init__-expanded"><a name="L1628"></a><tt class="py-lineno">1628</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L1629"></a><tt class="py-lineno">1629</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"mysql"</tt> </tt>
<a name="L1630"></a><tt class="py-lineno">1630</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L1631"></a><tt class="py-lineno">1631</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L1632"></a><tt class="py-lineno">1632</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L1633"></a><tt class="py-lineno">1633</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L1634"></a><tt class="py-lineno">1634</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-732" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-732', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1635"></a><tt class="py-lineno">1635</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L1636"></a><tt class="py-lineno">1636</tt>  <tt class="py-line">        <tt id="link-733" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-733', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;[^?]+)(\?set_encoding=(?P&lt;charset&gt;\w+))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L1637"></a><tt class="py-lineno">1637</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-734" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-734', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L1638"></a><tt class="py-lineno">1638</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L1639"></a><tt class="py-lineno">1639</tt>  <tt class="py-line">                <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> </tt>
<a name="L1640"></a><tt class="py-lineno">1640</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-735" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-735', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1641"></a><tt class="py-lineno">1641</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L1642"></a><tt class="py-lineno">1642</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L1643"></a><tt class="py-lineno">1643</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-736" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-736', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1644"></a><tt class="py-lineno">1644</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L1645"></a><tt class="py-lineno">1645</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1646"></a><tt class="py-lineno">1646</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-737" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-737', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L1647"></a><tt class="py-lineno">1647</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L1648"></a><tt class="py-lineno">1648</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L1649"></a><tt class="py-lineno">1649</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-738" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-738', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L1650"></a><tt class="py-lineno">1650</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L1651"></a><tt class="py-lineno">1651</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L1652"></a><tt class="py-lineno">1652</tt>  <tt class="py-line">        <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt id="link-739" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-739', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'3306'</tt><tt class="py-op">)</tt> </tt>
<a name="L1653"></a><tt class="py-lineno">1653</tt>  <tt class="py-line">        <tt class="py-name">charset</tt> <tt class="py-op">=</tt> <tt id="link-740" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-740', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'charset'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'utf8'</tt> </tt>
<a name="L1654"></a><tt class="py-lineno">1654</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">.</tt><tt id="link-741" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-741', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">=</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> </tt>
<a name="L1655"></a><tt class="py-lineno">1655</tt>  <tt class="py-line">                                <tt class="py-name">user</tt><tt class="py-op">=</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1656"></a><tt class="py-lineno">1656</tt>  <tt class="py-line">                                <tt class="py-name">passwd</tt><tt class="py-op">=</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">password</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L1657"></a><tt class="py-lineno">1657</tt>  <tt class="py-line">                                <tt class="py-name">host</tt><tt class="py-op">=</tt><tt class="py-name">host</tt><tt class="py-op">,</tt> </tt>
<a name="L1658"></a><tt class="py-lineno">1658</tt>  <tt class="py-line">                                <tt class="py-name">port</tt><tt class="py-op">=</tt><tt class="py-name">port</tt><tt class="py-op">,</tt> </tt>
<a name="L1659"></a><tt class="py-lineno">1659</tt>  <tt class="py-line">                                <tt class="py-name">charset</tt><tt class="py-op">=</tt><tt class="py-name">charset</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1660"></a><tt class="py-lineno">1660</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1661"></a><tt class="py-lineno">1661</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-742" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-742', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-743" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-743', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1662"></a><tt class="py-lineno">1662</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-744" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-744', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-745" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-745', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1663"></a><tt class="py-lineno">1663</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1664"></a><tt class="py-lineno">1664</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-746" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-746', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'SET FOREIGN_KEY_CHECKS=1;'</tt><tt class="py-op">)</tt> </tt>
<a name="L1665"></a><tt class="py-lineno">1665</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-747" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-747', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET sql_mode='NO_BACKSLASH_ESCAPES';"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1666"></a><tt class="py-lineno">1666</tt>  <tt class="py-line"> </tt>
<a name="MySQLAdapter.lastrowid"></a><div id="MySQLAdapter.lastrowid-def"><a name="L1667"></a><tt class="py-lineno">1667</tt> <a class="py-toggle" href="#" id="MySQLAdapter.lastrowid-toggle" onclick="return toggle('MySQLAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MySQLAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MySQLAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MySQLAdapter.lastrowid-expanded"><a name="L1668"></a><tt class="py-lineno">1668</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-748" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-748', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'select last_insert_id();'</tt><tt class="py-op">)</tt> </tt>
<a name="L1669"></a><tt class="py-lineno">1669</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L1670"></a><tt class="py-lineno">1670</tt>  <tt class="py-line"> </tt>
<a name="L1671"></a><tt class="py-lineno">1671</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter"></a><div id="PostgreSQLAdapter-def"><a name="L1672"></a><tt class="py-lineno">1672</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter-toggle" onclick="return toggle('PostgreSQLAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html">PostgreSQLAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="PostgreSQLAdapter-expanded"><a name="L1673"></a><tt class="py-lineno">1673</tt>  <tt class="py-line"> </tt>
<a name="L1674"></a><tt class="py-lineno">1674</tt>  <tt class="py-line">    <tt id="link-749" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-749', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-750" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-750', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-751" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-751', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'psycopg2'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1675"></a><tt class="py-lineno">1675</tt>  <tt class="py-line"> </tt>
<a name="L1676"></a><tt class="py-lineno">1676</tt>  <tt class="py-line">    <tt id="link-752" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-752', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L1677"></a><tt class="py-lineno">1677</tt>  <tt class="py-line">    <tt id="link-753" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-753', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L1678"></a><tt class="py-lineno">1678</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1679"></a><tt class="py-lineno">1679</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1680"></a><tt class="py-lineno">1680</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1681"></a><tt class="py-lineno">1681</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1682"></a><tt class="py-lineno">1682</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BYTEA'</tt><tt class="py-op">,</tt> </tt>
<a name="L1683"></a><tt class="py-lineno">1683</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1684"></a><tt class="py-lineno">1684</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER'</tt><tt class="py-op">,</tt> </tt>
<a name="L1685"></a><tt class="py-lineno">1685</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1686"></a><tt class="py-lineno">1686</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1687"></a><tt class="py-lineno">1687</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L1688"></a><tt class="py-lineno">1688</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L1689"></a><tt class="py-lineno">1689</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP'</tt><tt class="py-op">,</tt> </tt>
<a name="L1690"></a><tt class="py-lineno">1690</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'SERIAL PRIMARY KEY'</tt><tt class="py-op">,</tt> </tt>
<a name="L1691"></a><tt class="py-lineno">1691</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L1692"></a><tt class="py-lineno">1692</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1693"></a><tt class="py-lineno">1693</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1694"></a><tt class="py-lineno">1694</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1695"></a><tt class="py-lineno">1695</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L1696"></a><tt class="py-lineno">1696</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.sequence_name"></a><div id="PostgreSQLAdapter.sequence_name-def"><a name="L1697"></a><tt class="py-lineno">1697</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.sequence_name-toggle" onclick="return toggle('PostgreSQLAdapter.sequence_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#sequence_name">sequence_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.sequence_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.sequence_name-expanded"><a name="L1698"></a><tt class="py-lineno">1698</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_id_Seq'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt> </tt>
</div><a name="L1699"></a><tt class="py-lineno">1699</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.RANDOM"></a><div id="PostgreSQLAdapter.RANDOM-def"><a name="L1700"></a><tt class="py-lineno">1700</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.RANDOM-toggle" onclick="return toggle('PostgreSQLAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.RANDOM-expanded"><a name="L1701"></a><tt class="py-lineno">1701</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'RANDOM()'</tt> </tt>
</div><a name="L1702"></a><tt class="py-lineno">1702</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.distributed_transaction_begin"></a><div id="PostgreSQLAdapter.distributed_transaction_begin-def"><a name="L1703"></a><tt class="py-lineno">1703</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.distributed_transaction_begin-toggle" onclick="return toggle('PostgreSQLAdapter.distributed_transaction_begin');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#distributed_transaction_begin">distributed_transaction_begin</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.distributed_transaction_begin-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.distributed_transaction_begin-expanded"><a name="L1704"></a><tt class="py-lineno">1704</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> </tt>
</div><a name="L1705"></a><tt class="py-lineno">1705</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.prepare"></a><div id="PostgreSQLAdapter.prepare-def"><a name="L1706"></a><tt class="py-lineno">1706</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.prepare-toggle" onclick="return toggle('PostgreSQLAdapter.prepare');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#prepare">prepare</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.prepare-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.prepare-expanded"><a name="L1707"></a><tt class="py-lineno">1707</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-754" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-754', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"PREPARE TRANSACTION '%s';"</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1708"></a><tt class="py-lineno">1708</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.commit_prepared"></a><div id="PostgreSQLAdapter.commit_prepared-def"><a name="L1709"></a><tt class="py-lineno">1709</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.commit_prepared-toggle" onclick="return toggle('PostgreSQLAdapter.commit_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#commit_prepared">commit_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.commit_prepared-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.commit_prepared-expanded"><a name="L1710"></a><tt class="py-lineno">1710</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-755" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-755', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"COMMIT PREPARED '%s';"</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1711"></a><tt class="py-lineno">1711</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.rollback_prepared"></a><div id="PostgreSQLAdapter.rollback_prepared-def"><a name="L1712"></a><tt class="py-lineno">1712</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.rollback_prepared-toggle" onclick="return toggle('PostgreSQLAdapter.rollback_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#rollback_prepared">rollback_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.rollback_prepared-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.rollback_prepared-expanded"><a name="L1713"></a><tt class="py-lineno">1713</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-756" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-756', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"ROLLBACK PREPARED '%s';"</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1714"></a><tt class="py-lineno">1714</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.create_sequence_and_triggers"></a><div id="PostgreSQLAdapter.create_sequence_and_triggers-def"><a name="L1715"></a><tt class="py-lineno">1715</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('PostgreSQLAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.create_sequence_and_triggers-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.create_sequence_and_triggers-expanded"><a name="L1716"></a><tt class="py-lineno">1716</tt>  <tt class="py-line">        <tt class="py-comment"># following lines should only be executed if table._sequence_name does not exist</tt> </tt>
<a name="L1717"></a><tt class="py-lineno">1717</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment"># self.execute('CREATE SEQUENCE %s;' % table._sequence_name)</tt> </tt>
<a name="L1718"></a><tt class="py-lineno">1718</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment"># self.execute("ALTER TABLE %s ALTER COLUMN %s SET DEFAULT NEXTVAL('%s');" \</tt> </tt>
<a name="L1719"></a><tt class="py-lineno">1719</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment">#              % (table._tablename, table._fieldname, table._sequence_name))</tt> </tt>
<a name="L1720"></a><tt class="py-lineno">1720</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-757" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-757', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1721"></a><tt class="py-lineno">1721</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.__init__"></a><div id="PostgreSQLAdapter.__init__-def"><a name="L1722"></a><tt class="py-lineno">1722</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.__init__-toggle" onclick="return toggle('PostgreSQLAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1723"></a><tt class="py-lineno">1723</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-758" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-758', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-759" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-759', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L1724"></a><tt class="py-lineno">1724</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.__init__-expanded"><a name="L1725"></a><tt class="py-lineno">1725</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L1726"></a><tt class="py-lineno">1726</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"postgres"</tt> </tt>
<a name="L1727"></a><tt class="py-lineno">1727</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L1728"></a><tt class="py-lineno">1728</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L1729"></a><tt class="py-lineno">1729</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L1730"></a><tt class="py-lineno">1730</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L1731"></a><tt class="py-lineno">1731</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-760" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-760', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1732"></a><tt class="py-lineno">1732</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L1733"></a><tt class="py-lineno">1733</tt>  <tt class="py-line">        <tt id="link-761" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-761', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:@/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;[^\?]+)(\?sslmode=(?P&lt;sslmode&gt;.+))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L1734"></a><tt class="py-lineno">1734</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-762" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-762', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L1735"></a><tt class="py-lineno">1735</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Invalid URI string in DAL"</tt> </tt>
<a name="L1736"></a><tt class="py-lineno">1736</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-763" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-763', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1737"></a><tt class="py-lineno">1737</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L1738"></a><tt class="py-lineno">1738</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L1739"></a><tt class="py-lineno">1739</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-764" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-764', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1740"></a><tt class="py-lineno">1740</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L1741"></a><tt class="py-lineno">1741</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1742"></a><tt class="py-lineno">1742</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-765" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-765', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L1743"></a><tt class="py-lineno">1743</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L1744"></a><tt class="py-lineno">1744</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L1745"></a><tt class="py-lineno">1745</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-766" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-766', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L1746"></a><tt class="py-lineno">1746</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L1747"></a><tt class="py-lineno">1747</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L1748"></a><tt class="py-lineno">1748</tt>  <tt class="py-line">        <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt id="link-767" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-767', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'5432'</tt> </tt>
<a name="L1749"></a><tt class="py-lineno">1749</tt>  <tt class="py-line">        <tt class="py-name">sslmode</tt> <tt class="py-op">=</tt> <tt id="link-768" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-768', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'sslmode'</tt><tt class="py-op">)</tt> </tt>
<a name="L1750"></a><tt class="py-lineno">1750</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">sslmode</tt><tt class="py-op">:</tt> </tt>
<a name="L1751"></a><tt class="py-lineno">1751</tt>  <tt class="py-line">            <tt id="link-769" class="py-name" targets="Variable web2py.gluon.widget.msg=web2py.gluon.widget-module.html#msg"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-769', 'msg', 'link-769');">msg</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"dbname='%s' user='%s' host='%s'"</tt> </tt>
<a name="L1752"></a><tt class="py-lineno">1752</tt>  <tt class="py-line">                   <tt class="py-string">"port=%s password='%s' sslmode='%s'"</tt><tt class="py-op">)</tt> \ </tt>
<a name="L1753"></a><tt class="py-lineno">1753</tt>  <tt class="py-line">                   <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">user</tt><tt class="py-op">,</tt> <tt class="py-name">host</tt><tt class="py-op">,</tt> <tt class="py-name">port</tt><tt class="py-op">,</tt> <tt class="py-name">password</tt><tt class="py-op">,</tt> <tt class="py-name">sslmode</tt><tt class="py-op">)</tt> </tt>
<a name="L1754"></a><tt class="py-lineno">1754</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1755"></a><tt class="py-lineno">1755</tt>  <tt class="py-line">            <tt id="link-770" class="py-name"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-770', 'msg', 'link-769');">msg</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"dbname='%s' user='%s' host='%s'"</tt> </tt>
<a name="L1756"></a><tt class="py-lineno">1756</tt>  <tt class="py-line">                   <tt class="py-string">"port=%s password='%s'"</tt><tt class="py-op">)</tt> \ </tt>
<a name="L1757"></a><tt class="py-lineno">1757</tt>  <tt class="py-line">                   <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">user</tt><tt class="py-op">,</tt> <tt class="py-name">host</tt><tt class="py-op">,</tt> <tt class="py-name">port</tt><tt class="py-op">,</tt> <tt class="py-name">password</tt><tt class="py-op">)</tt> </tt>
<a name="L1758"></a><tt class="py-lineno">1758</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">msg</tt><tt class="py-op">=</tt><tt id="link-771" class="py-name"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-771', 'msg', 'link-769');">msg</a></tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1759"></a><tt class="py-lineno">1759</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-772" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-772', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-773" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-773', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt id="link-774" class="py-name"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-774', 'msg', 'link-769');">msg</a></tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1760"></a><tt class="py-lineno">1760</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-775" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-775', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-776" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-776', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1761"></a><tt class="py-lineno">1761</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">set_client_encoding</tt><tt class="py-op">(</tt><tt class="py-string">'UTF8'</tt><tt class="py-op">)</tt> </tt>
<a name="L1762"></a><tt class="py-lineno">1762</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1763"></a><tt class="py-lineno">1763</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-777" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-777', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'BEGIN;'</tt><tt class="py-op">)</tt> </tt>
<a name="L1764"></a><tt class="py-lineno">1764</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-778" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-778', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET CLIENT_ENCODING TO 'UNICODE';"</tt><tt class="py-op">)</tt> </tt>
<a name="L1765"></a><tt class="py-lineno">1765</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-779" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-779', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET standard_conforming_strings=on;"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1766"></a><tt class="py-lineno">1766</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.lastrowid"></a><div id="PostgreSQLAdapter.lastrowid-def"><a name="L1767"></a><tt class="py-lineno">1767</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.lastrowid-toggle" onclick="return toggle('PostgreSQLAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.lastrowid-expanded"><a name="L1768"></a><tt class="py-lineno">1768</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-780" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-780', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"select currval('%s')"</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt><tt class="py-op">)</tt> </tt>
<a name="L1769"></a><tt class="py-lineno">1769</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1770"></a><tt class="py-lineno">1770</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.LIKE"></a><div id="PostgreSQLAdapter.LIKE-def"><a name="L1771"></a><tt class="py-lineno">1771</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.LIKE-toggle" onclick="return toggle('PostgreSQLAdapter.LIKE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#LIKE">LIKE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.LIKE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.LIKE-expanded"><a name="L1772"></a><tt class="py-lineno">1772</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s ILIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-781" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-781', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-782" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-782', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-783" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-783', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1773"></a><tt class="py-lineno">1773</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.STARTSWITH"></a><div id="PostgreSQLAdapter.STARTSWITH-def"><a name="L1774"></a><tt class="py-lineno">1774</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.STARTSWITH-toggle" onclick="return toggle('PostgreSQLAdapter.STARTSWITH');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#STARTSWITH">STARTSWITH</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.STARTSWITH-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.STARTSWITH-expanded"><a name="L1775"></a><tt class="py-lineno">1775</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s ILIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-784" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-784', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-785" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-785', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-786" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-786', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">+</tt><tt class="py-string">'%'</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1776"></a><tt class="py-lineno">1776</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.ENDSWITH"></a><div id="PostgreSQLAdapter.ENDSWITH-def"><a name="L1777"></a><tt class="py-lineno">1777</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.ENDSWITH-toggle" onclick="return toggle('PostgreSQLAdapter.ENDSWITH');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#ENDSWITH">ENDSWITH</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.ENDSWITH-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.ENDSWITH-expanded"><a name="L1778"></a><tt class="py-lineno">1778</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s ILIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-787" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-787', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-788" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-788', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-789" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-789', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-string">'%'</tt><tt class="py-op">+</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1779"></a><tt class="py-lineno">1779</tt>  <tt class="py-line"> </tt>
<a name="PostgreSQLAdapter.CONTAINS"></a><div id="PostgreSQLAdapter.CONTAINS-def"><a name="L1780"></a><tt class="py-lineno">1780</tt> <a class="py-toggle" href="#" id="PostgreSQLAdapter.CONTAINS-toggle" onclick="return toggle('PostgreSQLAdapter.CONTAINS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.PostgreSQLAdapter-class.html#CONTAINS">CONTAINS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="PostgreSQLAdapter.CONTAINS-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="PostgreSQLAdapter.CONTAINS-expanded"><a name="L1781"></a><tt class="py-lineno">1781</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-790" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-790', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt><tt class="py-string">'text'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1782"></a><tt class="py-lineno">1782</tt>  <tt class="py-line">            <tt class="py-name">key</tt> <tt class="py-op">=</tt> <tt class="py-string">'%'</tt><tt class="py-op">+</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'%'</tt><tt class="py-op">,</tt><tt class="py-string">'%%'</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">'%'</tt> </tt>
<a name="L1783"></a><tt class="py-lineno">1783</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt id="link-791" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-791', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-792" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-792', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1784"></a><tt class="py-lineno">1784</tt>  <tt class="py-line">            <tt class="py-name">key</tt> <tt class="py-op">=</tt> <tt class="py-string">'%|'</tt><tt class="py-op">+</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'|'</tt><tt class="py-op">,</tt><tt class="py-string">'||'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'%'</tt><tt class="py-op">,</tt><tt class="py-string">'%%'</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">'|%'</tt> </tt>
<a name="L1785"></a><tt class="py-lineno">1785</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s ILIKE %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-793" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-793', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-794" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-794', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-795" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-795', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-string">'string'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L1786"></a><tt class="py-lineno">1786</tt>  <tt class="py-line"> </tt>
<a name="JDBCPostgreSQLAdapter"></a><div id="JDBCPostgreSQLAdapter-def"><a name="L1787"></a><tt class="py-lineno">1787</tt> <a class="py-toggle" href="#" id="JDBCPostgreSQLAdapter-toggle" onclick="return toggle('JDBCPostgreSQLAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.JDBCPostgreSQLAdapter-class.html">JDBCPostgreSQLAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">PostgreSQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="JDBCPostgreSQLAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="JDBCPostgreSQLAdapter-expanded"><a name="L1788"></a><tt class="py-lineno">1788</tt>  <tt class="py-line"> </tt>
<a name="JDBCPostgreSQLAdapter.__init__"></a><div id="JDBCPostgreSQLAdapter.__init__-def"><a name="L1789"></a><tt class="py-lineno">1789</tt> <a class="py-toggle" href="#" id="JDBCPostgreSQLAdapter.__init__-toggle" onclick="return toggle('JDBCPostgreSQLAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.JDBCPostgreSQLAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1790"></a><tt class="py-lineno">1790</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-796" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-796', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-797" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-797', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L1791"></a><tt class="py-lineno">1791</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="JDBCPostgreSQLAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="JDBCPostgreSQLAdapter.__init__-expanded"><a name="L1792"></a><tt class="py-lineno">1792</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L1793"></a><tt class="py-lineno">1793</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"postgres"</tt> </tt>
<a name="L1794"></a><tt class="py-lineno">1794</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L1795"></a><tt class="py-lineno">1795</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L1796"></a><tt class="py-lineno">1796</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L1797"></a><tt class="py-lineno">1797</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L1798"></a><tt class="py-lineno">1798</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-798" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-798', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1799"></a><tt class="py-lineno">1799</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L1800"></a><tt class="py-lineno">1800</tt>  <tt class="py-line">        <tt id="link-799" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-799', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;.+)$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L1801"></a><tt class="py-lineno">1801</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-800" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-800', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L1802"></a><tt class="py-lineno">1802</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Invalid URI string in DAL"</tt> </tt>
<a name="L1803"></a><tt class="py-lineno">1803</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-801" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-801', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1804"></a><tt class="py-lineno">1804</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L1805"></a><tt class="py-lineno">1805</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L1806"></a><tt class="py-lineno">1806</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-802" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-802', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1807"></a><tt class="py-lineno">1807</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L1808"></a><tt class="py-lineno">1808</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L1809"></a><tt class="py-lineno">1809</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-803" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-803', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L1810"></a><tt class="py-lineno">1810</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L1811"></a><tt class="py-lineno">1811</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L1812"></a><tt class="py-lineno">1812</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-804" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-804', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L1813"></a><tt class="py-lineno">1813</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L1814"></a><tt class="py-lineno">1814</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L1815"></a><tt class="py-lineno">1815</tt>  <tt class="py-line">        <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt id="link-805" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-805', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'5432'</tt> </tt>
<a name="L1816"></a><tt class="py-lineno">1816</tt>  <tt class="py-line">        <tt id="link-806" class="py-name"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-806', 'msg', 'link-769');">msg</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">'jdbc:postgresql://%s:%s/%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">host</tt><tt class="py-op">,</tt> <tt class="py-name">port</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">user</tt><tt class="py-op">,</tt> <tt class="py-name">password</tt><tt class="py-op">)</tt> </tt>
<a name="L1817"></a><tt class="py-lineno">1817</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">msg</tt><tt class="py-op">=</tt><tt id="link-807" class="py-name"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-807', 'msg', 'link-769');">msg</a></tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1818"></a><tt class="py-lineno">1818</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-808" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-808', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-809" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-809', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-op">*</tt><tt id="link-810" class="py-name"><a title="web2py.gluon.widget.msg" class="py-name" href="#" onclick="return doclink('link-810', 'msg', 'link-769');">msg</a></tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1819"></a><tt class="py-lineno">1819</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-811" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-811', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-812" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-812', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1820"></a><tt class="py-lineno">1820</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">set_client_encoding</tt><tt class="py-op">(</tt><tt class="py-string">'UTF8'</tt><tt class="py-op">)</tt> </tt>
<a name="L1821"></a><tt class="py-lineno">1821</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1822"></a><tt class="py-lineno">1822</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-813" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-813', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'BEGIN;'</tt><tt class="py-op">)</tt> </tt>
<a name="L1823"></a><tt class="py-lineno">1823</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-814" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-814', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET CLIENT_ENCODING TO 'UNICODE';"</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L1824"></a><tt class="py-lineno">1824</tt>  <tt class="py-line"> </tt>
<a name="L1825"></a><tt class="py-lineno">1825</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter"></a><div id="OracleAdapter-def"><a name="L1826"></a><tt class="py-lineno">1826</tt> <a class="py-toggle" href="#" id="OracleAdapter-toggle" onclick="return toggle('OracleAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html">OracleAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="OracleAdapter-expanded"><a name="L1827"></a><tt class="py-lineno">1827</tt>  <tt class="py-line"> </tt>
<a name="L1828"></a><tt class="py-lineno">1828</tt>  <tt class="py-line">    <tt id="link-815" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-815', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-816" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-816', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-817" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-817', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'cx_Oracle'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1829"></a><tt class="py-lineno">1829</tt>  <tt class="py-line"> </tt>
<a name="L1830"></a><tt class="py-lineno">1830</tt>  <tt class="py-line">    <tt id="link-818" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit_on_alter_table
web2py.gluon.dal.FireBirdAdapter.commit_on_alter_table
web2py.gluon.dal.MySQLAdapter.commit_on_alter_table
web2py.gluon.dal.OracleAdapter.commit_on_alter_table" class="py-name" href="#" onclick="return doclink('link-818', 'commit_on_alter_table', 'link-162');">commit_on_alter_table</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L1831"></a><tt class="py-lineno">1831</tt>  <tt class="py-line">    <tt id="link-819" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-819', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L1832"></a><tt class="py-lineno">1832</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1833"></a><tt class="py-lineno">1833</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR2(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1834"></a><tt class="py-lineno">1834</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L1835"></a><tt class="py-lineno">1835</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR2(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1836"></a><tt class="py-lineno">1836</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L1837"></a><tt class="py-lineno">1837</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR2(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1838"></a><tt class="py-lineno">1838</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1839"></a><tt class="py-lineno">1839</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1840"></a><tt class="py-lineno">1840</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1841"></a><tt class="py-lineno">1841</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L1842"></a><tt class="py-lineno">1842</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(8)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1843"></a><tt class="py-lineno">1843</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L1844"></a><tt class="py-lineno">1844</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMBER PRIMARY KEY'</tt><tt class="py-op">,</tt> </tt>
<a name="L1845"></a><tt class="py-lineno">1845</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMBER, CONSTRAINT %(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L1846"></a><tt class="py-lineno">1846</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L1847"></a><tt class="py-lineno">1847</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L1848"></a><tt class="py-lineno">1848</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L1849"></a><tt class="py-lineno">1849</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L1850"></a><tt class="py-lineno">1850</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.sequence_name"></a><div id="OracleAdapter.sequence_name-def"><a name="L1851"></a><tt class="py-lineno">1851</tt> <a class="py-toggle" href="#" id="OracleAdapter.sequence_name-toggle" onclick="return toggle('OracleAdapter.sequence_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#sequence_name">sequence_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.sequence_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.sequence_name-expanded"><a name="L1852"></a><tt class="py-lineno">1852</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_sequence'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
</div><a name="L1853"></a><tt class="py-lineno">1853</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.trigger_name"></a><div id="OracleAdapter.trigger_name-def"><a name="L1854"></a><tt class="py-lineno">1854</tt> <a class="py-toggle" href="#" id="OracleAdapter.trigger_name-toggle" onclick="return toggle('OracleAdapter.trigger_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#trigger_name">trigger_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.trigger_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.trigger_name-expanded"><a name="L1855"></a><tt class="py-lineno">1855</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_trigger'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
</div><a name="L1856"></a><tt class="py-lineno">1856</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.LEFT_JOIN"></a><div id="OracleAdapter.LEFT_JOIN-def"><a name="L1857"></a><tt class="py-lineno">1857</tt> <a class="py-toggle" href="#" id="OracleAdapter.LEFT_JOIN-toggle" onclick="return toggle('OracleAdapter.LEFT_JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#LEFT_JOIN">LEFT_JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.LEFT_JOIN-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.LEFT_JOIN-expanded"><a name="L1858"></a><tt class="py-lineno">1858</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'LEFT OUTER JOIN'</tt> </tt>
</div><a name="L1859"></a><tt class="py-lineno">1859</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.RANDOM"></a><div id="OracleAdapter.RANDOM-def"><a name="L1860"></a><tt class="py-lineno">1860</tt> <a class="py-toggle" href="#" id="OracleAdapter.RANDOM-toggle" onclick="return toggle('OracleAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.RANDOM-expanded"><a name="L1861"></a><tt class="py-lineno">1861</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'dbms_random.value'</tt> </tt>
</div><a name="L1862"></a><tt class="py-lineno">1862</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.NOT_NULL"></a><div id="OracleAdapter.NOT_NULL-def"><a name="L1863"></a><tt class="py-lineno">1863</tt> <a class="py-toggle" href="#" id="OracleAdapter.NOT_NULL-toggle" onclick="return toggle('OracleAdapter.NOT_NULL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#NOT_NULL">NOT_NULL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">default</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.NOT_NULL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.NOT_NULL-expanded"><a name="L1864"></a><tt class="py-lineno">1864</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'DEFAULT %s NOT NULL'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-820" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-820', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">default</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1865"></a><tt class="py-lineno">1865</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter._drop"></a><div id="OracleAdapter._drop-def"><a name="L1866"></a><tt class="py-lineno">1866</tt> <a class="py-toggle" href="#" id="OracleAdapter._drop-toggle" onclick="return toggle('OracleAdapter._drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#_drop">_drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter._drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter._drop-expanded"><a name="L1867"></a><tt class="py-lineno">1867</tt>  <tt class="py-line">        <tt id="link-821" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.sequence_name()=web2py.gluon.dal.BaseAdapter-class.html#sequence_name,Method web2py.gluon.dal.FireBirdAdapter.sequence_name()=web2py.gluon.dal.FireBirdAdapter-class.html#sequence_name,Method web2py.gluon.dal.OracleAdapter.sequence_name()=web2py.gluon.dal.OracleAdapter-class.html#sequence_name,Method web2py.gluon.dal.PostgreSQLAdapter.sequence_name()=web2py.gluon.dal.PostgreSQLAdapter-class.html#sequence_name,Method web2py.gluon.dal.SAPDBAdapter.sequence_name()=web2py.gluon.dal.SAPDBAdapter-class.html#sequence_name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-821', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> </tt>
<a name="L1868"></a><tt class="py-lineno">1868</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'DROP TABLE %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-string">'DROP SEQUENCE %s;'</tt> <tt class="py-op">%</tt> <tt id="link-822" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-822', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">]</tt> </tt>
</div><a name="L1869"></a><tt class="py-lineno">1869</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.select_limitby"></a><div id="OracleAdapter.select_limitby-def"><a name="L1870"></a><tt class="py-lineno">1870</tt> <a class="py-toggle" href="#" id="OracleAdapter.select_limitby-toggle" onclick="return toggle('OracleAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.select_limitby-expanded"><a name="L1871"></a><tt class="py-lineno">1871</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L1872"></a><tt class="py-lineno">1872</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L1873"></a><tt class="py-lineno">1873</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-823" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-823', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">sql_w</tt><tt class="py-op">)</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
<a name="L1874"></a><tt class="py-lineno">1874</tt>  <tt class="py-line">                <tt class="py-name">sql_w_row</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_w</tt> <tt class="py-op">+</tt> <tt class="py-string">' AND w_row &gt; %i'</tt> <tt class="py-op">%</tt> <tt class="py-name">lmin</tt> </tt>
<a name="L1875"></a><tt class="py-lineno">1875</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1876"></a><tt class="py-lineno">1876</tt>  <tt class="py-line">                <tt class="py-name">sql_w_row</tt> <tt class="py-op">=</tt> <tt class="py-string">'WHERE w_row &gt; %i'</tt> <tt class="py-op">%</tt> <tt class="py-name">lmin</tt> </tt>
<a name="L1877"></a><tt class="py-lineno">1877</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM (SELECT w_tmp.*, ROWNUM w_row FROM (SELECT %s FROM %s%s%s) w_tmp WHERE ROWNUM&lt;=%i) %s %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w_row</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
<a name="L1878"></a><tt class="py-lineno">1878</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1879"></a><tt class="py-lineno">1879</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.constraint_name"></a><div id="OracleAdapter.constraint_name-def"><a name="L1880"></a><tt class="py-lineno">1880</tt> <a class="py-toggle" href="#" id="OracleAdapter.constraint_name-toggle" onclick="return toggle('OracleAdapter.constraint_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#constraint_name">constraint_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">tablename</tt><tt class="py-op">,</tt> <tt class="py-param">fieldname</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.constraint_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.constraint_name-expanded"><a name="L1881"></a><tt class="py-lineno">1881</tt>  <tt class="py-line">        <tt id="link-824" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-824', 'constraint_name', 'link-194');">constraint_name</a></tt> <tt class="py-op">=</tt> <tt id="link-825" class="py-name" targets="Class web2py.gluon.dal.BaseAdapter=web2py.gluon.dal.BaseAdapter-class.html"><a title="web2py.gluon.dal.BaseAdapter" class="py-name" href="#" onclick="return doclink('link-825', 'BaseAdapter', 'link-825');">BaseAdapter</a></tt><tt class="py-op">.</tt><tt id="link-826" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-826', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fieldname</tt><tt class="py-op">)</tt> </tt>
<a name="L1882"></a><tt class="py-lineno">1882</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-827" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-827', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-828" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-828', 'constraint_name', 'link-194');">constraint_name</a></tt><tt class="py-op">)</tt><tt class="py-op">&gt;</tt><tt class="py-number">30</tt><tt class="py-op">:</tt> </tt>
<a name="L1883"></a><tt class="py-lineno">1883</tt>  <tt class="py-line">            <tt id="link-829" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-829', 'constraint_name', 'link-194');">constraint_name</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'%s_%s__constraint'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">fieldname</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">7</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L1884"></a><tt class="py-lineno">1884</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-830" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.constraint_name
web2py.gluon.dal.NoSQLAdapter.constraint_name
web2py.gluon.dal.OracleAdapter.constraint_name" class="py-name" href="#" onclick="return doclink('link-830', 'constraint_name', 'link-194');">constraint_name</a></tt> </tt>
</div><a name="L1885"></a><tt class="py-lineno">1885</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.represent_exceptions"></a><div id="OracleAdapter.represent_exceptions-def"><a name="L1886"></a><tt class="py-lineno">1886</tt> <a class="py-toggle" href="#" id="OracleAdapter.represent_exceptions-toggle" onclick="return toggle('OracleAdapter.represent_exceptions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#represent_exceptions">represent_exceptions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.represent_exceptions-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.represent_exceptions-expanded"><a name="L1887"></a><tt class="py-lineno">1887</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> </tt>
<a name="L1888"></a><tt class="py-lineno">1888</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b64encode</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1889"></a><tt class="py-lineno">1889</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">":CLOB('%s')"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L1890"></a><tt class="py-lineno">1890</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'date'</tt><tt class="py-op">:</tt> </tt>
<a name="L1891"></a><tt class="py-lineno">1891</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-831" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-831', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-832" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-832', 'date', 'link-604');">date</a></tt><tt class="py-op">,</tt> <tt id="link-833" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-833', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-834" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-834', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1892"></a><tt class="py-lineno">1892</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt> </tt>
<a name="L1893"></a><tt class="py-lineno">1893</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1894"></a><tt class="py-lineno">1894</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1895"></a><tt class="py-lineno">1895</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">"to_date('%s','yyyy-mm-dd')"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L1896"></a><tt class="py-lineno">1896</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> </tt>
<a name="L1897"></a><tt class="py-lineno">1897</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-835" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-835', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-836" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-836', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1898"></a><tt class="py-lineno">1898</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'T'</tt><tt class="py-op">,</tt><tt class="py-string">' '</tt><tt class="py-op">)</tt> </tt>
<a name="L1899"></a><tt class="py-lineno">1899</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-837" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-837', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-838" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-838', 'date', 'link-604');">date</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1900"></a><tt class="py-lineno">1900</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">+</tt><tt class="py-string">' 00:00:00'</tt> </tt>
<a name="L1901"></a><tt class="py-lineno">1901</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L1902"></a><tt class="py-lineno">1902</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L1903"></a><tt class="py-lineno">1903</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">"to_date('%s','yyyy-mm-dd hh24:mi:ss')"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L1904"></a><tt class="py-lineno">1904</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L1905"></a><tt class="py-lineno">1905</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.__init__"></a><div id="OracleAdapter.__init__-def"><a name="L1906"></a><tt class="py-lineno">1906</tt> <a class="py-toggle" href="#" id="OracleAdapter.__init__-toggle" onclick="return toggle('OracleAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L1907"></a><tt class="py-lineno">1907</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-839" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-839', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-840" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-840', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L1908"></a><tt class="py-lineno">1908</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.__init__-expanded"><a name="L1909"></a><tt class="py-lineno">1909</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L1910"></a><tt class="py-lineno">1910</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"oracle"</tt> </tt>
<a name="L1911"></a><tt class="py-lineno">1911</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L1912"></a><tt class="py-lineno">1912</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L1913"></a><tt class="py-lineno">1913</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L1914"></a><tt class="py-lineno">1914</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L1915"></a><tt class="py-lineno">1915</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-841" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-841', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1916"></a><tt class="py-lineno">1916</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L1917"></a><tt class="py-lineno">1917</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-string">'threaded'</tt> <tt class="py-keyword">in</tt> <tt class="py-name">driver_args</tt><tt class="py-op">:</tt> </tt>
<a name="L1918"></a><tt class="py-lineno">1918</tt>  <tt class="py-line">            <tt class="py-name">driver_args</tt><tt class="py-op">[</tt><tt class="py-string">'threaded'</tt><tt class="py-op">]</tt><tt class="py-op">=</tt><tt class="py-name">True</tt> </tt>
<a name="L1919"></a><tt class="py-lineno">1919</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">uri</tt><tt class="py-op">=</tt><tt class="py-name">uri</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L1920"></a><tt class="py-lineno">1920</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-842" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-842', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-843" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-843', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1921"></a><tt class="py-lineno">1921</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-844" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-844', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-845" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-845', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1922"></a><tt class="py-lineno">1922</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L1923"></a><tt class="py-lineno">1923</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-846" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-846', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY-MM-DD HH24:MI:SS';"</tt><tt class="py-op">)</tt> </tt>
<a name="L1924"></a><tt class="py-lineno">1924</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-847" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-847', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"ALTER SESSION SET NLS_TIMESTAMP_FORMAT = 'YYYY-MM-DD HH24:MI:SS';"</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1925"></a><tt class="py-lineno">1925</tt>  <tt class="py-line">    <tt id="link-848" class="py-name" targets="Variable web2py.gluon.dal.OracleAdapter.oracle_fix=web2py.gluon.dal.OracleAdapter-class.html#oracle_fix"><a title="web2py.gluon.dal.OracleAdapter.oracle_fix" class="py-name" href="#" onclick="return doclink('link-848', 'oracle_fix', 'link-848');">oracle_fix</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">"[^']*('[^']*'[^']*)*\:(?P&lt;clob&gt;CLOB\('([^']+|'')*'\))"</tt><tt class="py-op">)</tt> </tt>
<a name="L1926"></a><tt class="py-lineno">1926</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.execute"></a><div id="OracleAdapter.execute-def"><a name="L1927"></a><tt class="py-lineno">1927</tt> <a class="py-toggle" href="#" id="OracleAdapter.execute-toggle" onclick="return toggle('OracleAdapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">command</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.execute-expanded"><a name="L1928"></a><tt class="py-lineno">1928</tt>  <tt class="py-line">        <tt class="py-name">args</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L1929"></a><tt class="py-lineno">1929</tt>  <tt class="py-line">        <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-number">1</tt> </tt>
<a name="L1930"></a><tt class="py-lineno">1930</tt>  <tt class="py-line">        <tt class="py-keyword">while</tt> <tt class="py-name">True</tt><tt class="py-op">:</tt> </tt>
<a name="L1931"></a><tt class="py-lineno">1931</tt>  <tt class="py-line">            <tt id="link-849" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-849', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-850" class="py-name"><a title="web2py.gluon.dal.OracleAdapter.oracle_fix" class="py-name" href="#" onclick="return doclink('link-850', 'oracle_fix', 'link-848');">oracle_fix</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">)</tt> </tt>
<a name="L1932"></a><tt class="py-lineno">1932</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-851" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-851', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L1933"></a><tt class="py-lineno">1933</tt>  <tt class="py-line">                <tt class="py-keyword">break</tt> </tt>
<a name="L1934"></a><tt class="py-lineno">1934</tt>  <tt class="py-line">            <tt class="py-name">command</tt> <tt class="py-op">=</tt> <tt class="py-name">command</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt id="link-852" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-852', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt id="link-853" class="py-name" targets="Method web2py.gluon.main.HttpServer.start()=web2py.gluon.main.HttpServer-class.html#start,Method web2py.gluon.rocket.Rocket.start()=web2py.gluon.rocket.Rocket-class.html#start,Method web2py.gluon.rocket.ThreadPool.start()=web2py.gluon.rocket.ThreadPool-class.html#start,Function web2py.gluon.widget.start()=web2py.gluon.widget-module.html#start,Method web2py.gluon.widget.web2pyDialog.start()=web2py.gluon.widget.web2pyDialog-class.html#start,Method web2py.gluon.winservice.Service.start()=web2py.gluon.winservice.Service-class.html#start,Method web2py.gluon.winservice.Web2pyService.start()=web2py.gluon.winservice.Web2pyService-class.html#start"><a title="web2py.gluon.main.HttpServer.start
web2py.gluon.rocket.Rocket.start
web2py.gluon.rocket.ThreadPool.start
web2py.gluon.widget.start
web2py.gluon.widget.web2pyDialog.start
web2py.gluon.winservice.Service.start
web2py.gluon.winservice.Web2pyService.start" class="py-name" href="#" onclick="return doclink('link-853', 'start', 'link-853');">start</a></tt><tt class="py-op">(</tt><tt class="py-string">'clob'</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-name">command</tt><tt class="py-op">[</tt><tt id="link-854" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-854', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt id="link-855" class="py-name" targets="Method web2py.gluon.custom_import._BaseImporter.end()=web2py.gluon.custom_import._BaseImporter-class.html#end,Method web2py.gluon.custom_import._DateTrackerImporter.end()=web2py.gluon.custom_import._DateTrackerImporter-class.html#end"><a title="web2py.gluon.custom_import._BaseImporter.end
web2py.gluon.custom_import._DateTrackerImporter.end" class="py-name" href="#" onclick="return doclink('link-855', 'end', 'link-855');">end</a></tt><tt class="py-op">(</tt><tt class="py-string">'clob'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L1935"></a><tt class="py-lineno">1935</tt>  <tt class="py-line">            <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-856" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-856', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-857" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-857', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'clob'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">6</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">"''"</tt><tt class="py-op">,</tt> <tt class="py-string">"'"</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L1936"></a><tt class="py-lineno">1936</tt>  <tt class="py-line">            <tt class="py-name">i</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
<a name="L1937"></a><tt class="py-lineno">1937</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-858" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.log_execute
web2py.gluon.dal.NoSQLAdapter.log_execute" class="py-name" href="#" onclick="return doclink('link-858', 'log_execute', 'link-587');">log_execute</a></tt><tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1938"></a><tt class="py-lineno">1938</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.create_sequence_and_triggers"></a><div id="OracleAdapter.create_sequence_and_triggers-def"><a name="L1939"></a><tt class="py-lineno">1939</tt> <a class="py-toggle" href="#" id="OracleAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('OracleAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.create_sequence_and_triggers-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.create_sequence_and_triggers-expanded"><a name="L1940"></a><tt class="py-lineno">1940</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L1941"></a><tt class="py-lineno">1941</tt>  <tt class="py-line">        <tt id="link-859" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-859', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> </tt>
<a name="L1942"></a><tt class="py-lineno">1942</tt>  <tt class="py-line">        <tt id="link-860" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.trigger_name()=web2py.gluon.dal.BaseAdapter-class.html#trigger_name,Method web2py.gluon.dal.FireBirdAdapter.trigger_name()=web2py.gluon.dal.FireBirdAdapter-class.html#trigger_name,Method web2py.gluon.dal.OracleAdapter.trigger_name()=web2py.gluon.dal.OracleAdapter-class.html#trigger_name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-860', 'trigger_name', 'link-860');">trigger_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_trigger_name</tt> </tt>
<a name="L1943"></a><tt class="py-lineno">1943</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-861" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-861', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L1944"></a><tt class="py-lineno">1944</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-862" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-862', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'CREATE SEQUENCE %s START WITH 1 INCREMENT BY 1 NOMAXVALUE;'</tt> <tt class="py-op">%</tt> <tt id="link-863" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-863', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1945"></a><tt class="py-lineno">1945</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-864" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-864', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'CREATE OR REPLACE TRIGGER %s BEFORE INSERT ON %s FOR EACH ROW BEGIN SELECT %s.nextval INTO :NEW.id FROM DUAL; END;\n'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-865" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-865', 'trigger_name', 'link-860');">trigger_name</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt id="link-866" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-866', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1946"></a><tt class="py-lineno">1946</tt>  <tt class="py-line"> </tt>
<a name="OracleAdapter.lastrowid"></a><div id="OracleAdapter.lastrowid-def"><a name="L1947"></a><tt class="py-lineno">1947</tt> <a class="py-toggle" href="#" id="OracleAdapter.lastrowid-toggle" onclick="return toggle('OracleAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.OracleAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="OracleAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="OracleAdapter.lastrowid-expanded"><a name="L1948"></a><tt class="py-lineno">1948</tt>  <tt class="py-line">        <tt id="link-867" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-867', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> </tt>
<a name="L1949"></a><tt class="py-lineno">1949</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-868" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-868', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'SELECT %s.currval FROM dual;'</tt> <tt class="py-op">%</tt> <tt id="link-869" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-869', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L1950"></a><tt class="py-lineno">1950</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L1951"></a><tt class="py-lineno">1951</tt>  <tt class="py-line"> </tt>
<a name="L1952"></a><tt class="py-lineno">1952</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter"></a><div id="MSSQLAdapter-def"><a name="L1953"></a><tt class="py-lineno">1953</tt> <a class="py-toggle" href="#" id="MSSQLAdapter-toggle" onclick="return toggle('MSSQLAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html">MSSQLAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="MSSQLAdapter-expanded"><a name="L1954"></a><tt class="py-lineno">1954</tt>  <tt class="py-line"> </tt>
<a name="L1955"></a><tt class="py-lineno">1955</tt>  <tt class="py-line">    <tt id="link-870" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-870', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-871" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-871', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-872" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-872', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'pyodbc'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L1956"></a><tt class="py-lineno">1956</tt>  <tt class="py-line"> </tt>
<a name="L1957"></a><tt class="py-lineno">1957</tt>  <tt class="py-line">    <tt id="link-873" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-873', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L1958"></a><tt class="py-lineno">1958</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'BIT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1959"></a><tt class="py-lineno">1959</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1960"></a><tt class="py-lineno">1960</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1961"></a><tt class="py-lineno">1961</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1962"></a><tt class="py-lineno">1962</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'IMAGE'</tt><tt class="py-op">,</tt> </tt>
<a name="L1963"></a><tt class="py-lineno">1963</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1964"></a><tt class="py-lineno">1964</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1965"></a><tt class="py-lineno">1965</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1966"></a><tt class="py-lineno">1966</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1967"></a><tt class="py-lineno">1967</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATETIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L1968"></a><tt class="py-lineno">1968</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(8)'</tt><tt class="py-op">,</tt> </tt>
<a name="L1969"></a><tt class="py-lineno">1969</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATETIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L1970"></a><tt class="py-lineno">1970</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT IDENTITY PRIMARY KEY'</tt><tt class="py-op">,</tt> </tt>
<a name="L1971"></a><tt class="py-lineno">1971</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT NULL, CONSTRAINT %(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L1972"></a><tt class="py-lineno">1972</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">', CONSTRAINT FK_%(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L1973"></a><tt class="py-lineno">1973</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">' CONSTRAINT FK_%(foreign_table)s_PK FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L1974"></a><tt class="py-lineno">1974</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1975"></a><tt class="py-lineno">1975</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1976"></a><tt class="py-lineno">1976</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'TEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L1977"></a><tt class="py-lineno">1977</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L1978"></a><tt class="py-lineno">1978</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.EXTRACT"></a><div id="MSSQLAdapter.EXTRACT-def"><a name="L1979"></a><tt class="py-lineno">1979</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.EXTRACT-toggle" onclick="return toggle('MSSQLAdapter.EXTRACT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#EXTRACT">EXTRACT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">what</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.EXTRACT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.EXTRACT-expanded"><a name="L1980"></a><tt class="py-lineno">1980</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">"DATEPART(%s,%s)"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">what</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-874" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-874', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1981"></a><tt class="py-lineno">1981</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.LEFT_JOIN"></a><div id="MSSQLAdapter.LEFT_JOIN-def"><a name="L1982"></a><tt class="py-lineno">1982</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.LEFT_JOIN-toggle" onclick="return toggle('MSSQLAdapter.LEFT_JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#LEFT_JOIN">LEFT_JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.LEFT_JOIN-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.LEFT_JOIN-expanded"><a name="L1983"></a><tt class="py-lineno">1983</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'LEFT OUTER JOIN'</tt> </tt>
</div><a name="L1984"></a><tt class="py-lineno">1984</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.RANDOM"></a><div id="MSSQLAdapter.RANDOM-def"><a name="L1985"></a><tt class="py-lineno">1985</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.RANDOM-toggle" onclick="return toggle('MSSQLAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.RANDOM-expanded"><a name="L1986"></a><tt class="py-lineno">1986</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'NEWID()'</tt> </tt>
</div><a name="L1987"></a><tt class="py-lineno">1987</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.ALLOW_NULL"></a><div id="MSSQLAdapter.ALLOW_NULL-def"><a name="L1988"></a><tt class="py-lineno">1988</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.ALLOW_NULL-toggle" onclick="return toggle('MSSQLAdapter.ALLOW_NULL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#ALLOW_NULL">ALLOW_NULL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.ALLOW_NULL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.ALLOW_NULL-expanded"><a name="L1989"></a><tt class="py-lineno">1989</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">' NULL'</tt> </tt>
</div><a name="L1990"></a><tt class="py-lineno">1990</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.SUBSTRING"></a><div id="MSSQLAdapter.SUBSTRING-def"><a name="L1991"></a><tt class="py-lineno">1991</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.SUBSTRING-toggle" onclick="return toggle('MSSQLAdapter.SUBSTRING');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#SUBSTRING">SUBSTRING</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">parameters</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.SUBSTRING-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.SUBSTRING-expanded"><a name="L1992"></a><tt class="py-lineno">1992</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SUBSTRING(%s,%s,%s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-875" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-875', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L1993"></a><tt class="py-lineno">1993</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.PRIMARY_KEY"></a><div id="MSSQLAdapter.PRIMARY_KEY-def"><a name="L1994"></a><tt class="py-lineno">1994</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.PRIMARY_KEY-toggle" onclick="return toggle('MSSQLAdapter.PRIMARY_KEY');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#PRIMARY_KEY">PRIMARY_KEY</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.PRIMARY_KEY-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.PRIMARY_KEY-expanded"><a name="L1995"></a><tt class="py-lineno">1995</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'PRIMARY KEY CLUSTERED (%s)'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
</div><a name="L1996"></a><tt class="py-lineno">1996</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.select_limitby"></a><div id="MSSQLAdapter.select_limitby-def"><a name="L1997"></a><tt class="py-lineno">1997</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.select_limitby-toggle" onclick="return toggle('MSSQLAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.select_limitby-expanded"><a name="L1998"></a><tt class="py-lineno">1998</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L1999"></a><tt class="py-lineno">1999</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L2000"></a><tt class="py-lineno">2000</tt>  <tt class="py-line">            <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' TOP %i'</tt> <tt class="py-op">%</tt> <tt class="py-name">lmax</tt> </tt>
<a name="L2001"></a><tt class="py-lineno">2001</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2002"></a><tt class="py-lineno">2002</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.represent_exceptions"></a><div id="MSSQLAdapter.represent_exceptions-def"><a name="L2003"></a><tt class="py-lineno">2003</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.represent_exceptions-toggle" onclick="return toggle('MSSQLAdapter.represent_exceptions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#represent_exceptions">represent_exceptions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.represent_exceptions-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.represent_exceptions-expanded"><a name="L2004"></a><tt class="py-lineno">2004</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> </tt>
<a name="L2005"></a><tt class="py-lineno">2005</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-876" class="py-name"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-876', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-string">'F'</tt><tt class="py-op">:</tt> </tt>
<a name="L2006"></a><tt class="py-lineno">2006</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-string">'1'</tt> </tt>
<a name="L2007"></a><tt class="py-lineno">2007</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2008"></a><tt class="py-lineno">2008</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-string">'0'</tt> </tt>
<a name="L2009"></a><tt class="py-lineno">2009</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L2010"></a><tt class="py-lineno">2010</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.__init__"></a><div id="MSSQLAdapter.__init__-def"><a name="L2011"></a><tt class="py-lineno">2011</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.__init__-toggle" onclick="return toggle('MSSQLAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2012"></a><tt class="py-lineno">2012</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-877" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-877', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-878" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-878', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2013"></a><tt class="py-lineno">2013</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> <tt class="py-name">fake_connect</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.__init__-expanded"><a name="L2014"></a><tt class="py-lineno">2014</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2015"></a><tt class="py-lineno">2015</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"mssql"</tt> </tt>
<a name="L2016"></a><tt class="py-lineno">2016</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2017"></a><tt class="py-lineno">2017</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2018"></a><tt class="py-lineno">2018</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2019"></a><tt class="py-lineno">2019</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2020"></a><tt class="py-lineno">2020</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-879" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-879', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2021"></a><tt class="py-lineno">2021</tt>  <tt class="py-line">        <tt class="py-comment"># ## read: http://bytes.com/groups/python/460325-cx_oracle-utf8</tt> </tt>
<a name="L2022"></a><tt class="py-lineno">2022</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2023"></a><tt class="py-lineno">2023</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-string">'@'</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">uri</tt><tt class="py-op">:</tt> </tt>
<a name="L2024"></a><tt class="py-lineno">2024</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L2025"></a><tt class="py-lineno">2025</tt>  <tt class="py-line">                <tt id="link-880" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-880', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;dsn&gt;.+)$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2026"></a><tt class="py-lineno">2026</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-881" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-881', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2027"></a><tt class="py-lineno">2027</tt>  <tt class="py-line">                    <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L2028"></a><tt class="py-lineno">2028</tt>  <tt class="py-line">                        <tt class="py-string">'Parsing uri string(%s) has no result'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> </tt>
<a name="L2029"></a><tt class="py-lineno">2029</tt>  <tt class="py-line">                <tt class="py-name">dsn</tt> <tt class="py-op">=</tt> <tt id="link-882" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-882', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'dsn'</tt><tt class="py-op">)</tt> </tt>
<a name="L2030"></a><tt class="py-lineno">2030</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">dsn</tt><tt class="py-op">:</tt> </tt>
<a name="L2031"></a><tt class="py-lineno">2031</tt>  <tt class="py-line">                    <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'DSN required'</tt> </tt>
<a name="L2032"></a><tt class="py-lineno">2032</tt>  <tt class="py-line">            <tt class="py-keyword">except</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt>
<a name="L2033"></a><tt class="py-lineno">2033</tt>  <tt class="py-line">                <tt id="link-883" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-883', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt id="link-884" class="py-name" targets="Method web2py.gluon.tools.Service.error()=web2py.gluon.tools.Service-class.html#error,Method web2py.gluon.widget.web2pyDialog.error()=web2py.gluon.widget.web2pyDialog-class.html#error"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-884', 'error', 'link-884');">error</a></tt><tt class="py-op">(</tt><tt class="py-string">'NdGpatch error'</tt><tt class="py-op">)</tt> </tt>
<a name="L2034"></a><tt class="py-lineno">2034</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">e</tt> </tt>
<a name="L2035"></a><tt class="py-lineno">2035</tt>  <tt class="py-line">            <tt class="py-name">cnxn</tt> <tt class="py-op">=</tt> <tt class="py-string">'DSN=%s'</tt> <tt class="py-op">%</tt> <tt class="py-name">dsn</tt> </tt>
<a name="L2036"></a><tt class="py-lineno">2036</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2037"></a><tt class="py-lineno">2037</tt>  <tt class="py-line">            <tt id="link-885" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-885', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;[^\?]+)(\?(?P&lt;urlargs&gt;.*))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2038"></a><tt class="py-lineno">2038</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-886" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-886', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2039"></a><tt class="py-lineno">2039</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L2040"></a><tt class="py-lineno">2040</tt>  <tt class="py-line">                    <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2041"></a><tt class="py-lineno">2041</tt>  <tt class="py-line">            <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-887" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-887', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2042"></a><tt class="py-lineno">2042</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L2043"></a><tt class="py-lineno">2043</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L2044"></a><tt class="py-lineno">2044</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-888" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-888', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2045"></a><tt class="py-lineno">2045</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L2046"></a><tt class="py-lineno">2046</tt>  <tt class="py-line">                <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2047"></a><tt class="py-lineno">2047</tt>  <tt class="py-line">            <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-889" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-889', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L2048"></a><tt class="py-lineno">2048</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L2049"></a><tt class="py-lineno">2049</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L2050"></a><tt class="py-lineno">2050</tt>  <tt class="py-line">            <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-890" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-890', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L2051"></a><tt class="py-lineno">2051</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L2052"></a><tt class="py-lineno">2052</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L2053"></a><tt class="py-lineno">2053</tt>  <tt class="py-line">            <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt id="link-891" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-891', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'1433'</tt> </tt>
<a name="L2054"></a><tt class="py-lineno">2054</tt>  <tt class="py-line">            <tt class="py-comment"># Parse the optional url name-value arg pairs after the '?'</tt> </tt>
<a name="L2055"></a><tt class="py-lineno">2055</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-comment"># (in the form of arg1=value1&amp;arg2=value2&amp;...)</tt> </tt>
<a name="L2056"></a><tt class="py-lineno">2056</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-comment"># Default values (drivers like FreeTDS insist on uppercase parameter keys)</tt> </tt>
<a name="L2057"></a><tt class="py-lineno">2057</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">argsdict</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> <tt class="py-string">'DRIVER'</tt><tt class="py-op">:</tt><tt class="py-string">'{SQL Server}'</tt> <tt class="py-op">}</tt> </tt>
<a name="L2058"></a><tt class="py-lineno">2058</tt>  <tt class="py-line">            <tt class="py-name">urlargs</tt> <tt class="py-op">=</tt> <tt id="link-892" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-892', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'urlargs'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">''</tt> </tt>
<a name="L2059"></a><tt class="py-lineno">2059</tt>  <tt class="py-line">            <tt class="py-name">argpattern</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'(?P&lt;argkey&gt;[^=]+)=(?P&lt;argvalue&gt;[^&amp;]*)'</tt><tt class="py-op">)</tt> </tt>
<a name="L2060"></a><tt class="py-lineno">2060</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">argmatch</tt> <tt class="py-keyword">in</tt> <tt class="py-name">argpattern</tt><tt class="py-op">.</tt><tt class="py-name">finditer</tt><tt class="py-op">(</tt><tt class="py-name">urlargs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2061"></a><tt class="py-lineno">2061</tt>  <tt class="py-line">                <tt class="py-name">argsdict</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">argmatch</tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'argkey'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-893" class="py-name"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-893', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">argmatch</tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'argvalue'</tt><tt class="py-op">)</tt> </tt>
<a name="L2062"></a><tt class="py-lineno">2062</tt>  <tt class="py-line">            <tt class="py-name">urlargs</tt> <tt class="py-op">=</tt> <tt class="py-string">';'</tt><tt class="py-op">.</tt><tt id="link-894" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-894', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">'%s=%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">ak</tt><tt class="py-op">,</tt> <tt class="py-name">av</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">ak</tt><tt class="py-op">,</tt> <tt class="py-name">av</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">argsdict</tt><tt class="py-op">.</tt><tt id="link-895" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-895', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L2063"></a><tt class="py-lineno">2063</tt>  <tt class="py-line">            <tt class="py-name">cnxn</tt> <tt class="py-op">=</tt> <tt class="py-string">'SERVER=%s;PORT=%s;DATABASE=%s;UID=%s;PWD=%s;%s'</tt> \ </tt>
<a name="L2064"></a><tt class="py-lineno">2064</tt>  <tt class="py-line">                <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">host</tt><tt class="py-op">,</tt> <tt class="py-name">port</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">user</tt><tt class="py-op">,</tt> <tt class="py-name">password</tt><tt class="py-op">,</tt> <tt class="py-name">urlargs</tt><tt class="py-op">)</tt> </tt>
<a name="L2065"></a><tt class="py-lineno">2065</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">cnxn</tt><tt class="py-op">=</tt><tt class="py-name">cnxn</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2066"></a><tt class="py-lineno">2066</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-896" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-896', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-897" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-897', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">cnxn</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2067"></a><tt class="py-lineno">2067</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fake_connect</tt><tt class="py-op">:</tt> </tt>
<a name="L2068"></a><tt class="py-lineno">2068</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-898" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-898', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-899" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-899', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2069"></a><tt class="py-lineno">2069</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2070"></a><tt class="py-lineno">2070</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.lastrowid"></a><div id="MSSQLAdapter.lastrowid-def"><a name="L2071"></a><tt class="py-lineno">2071</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.lastrowid-toggle" onclick="return toggle('MSSQLAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.lastrowid-expanded"><a name="L2072"></a><tt class="py-lineno">2072</tt>  <tt class="py-line">        <tt class="py-comment">#self.execute('SELECT @@IDENTITY;')</tt> </tt>
<a name="L2073"></a><tt class="py-lineno">2073</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-900" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-900', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'SELECT SCOPE_IDENTITY();'</tt><tt class="py-op">)</tt> </tt>
<a name="L2074"></a><tt class="py-lineno">2074</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2075"></a><tt class="py-lineno">2075</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.integrity_error_class"></a><div id="MSSQLAdapter.integrity_error_class-def"><a name="L2076"></a><tt class="py-lineno">2076</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.integrity_error_class-toggle" onclick="return toggle('MSSQLAdapter.integrity_error_class');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#integrity_error_class">integrity_error_class</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.integrity_error_class-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.integrity_error_class-expanded"><a name="L2077"></a><tt class="py-lineno">2077</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">pyodbc</tt><tt class="py-op">.</tt><tt id="link-901" class="py-name"><a title="psycopg2.IntegrityError
web2py.gluon.contrib.pymysql.err.IntegrityError" class="py-name" href="#" onclick="return doclink('link-901', 'IntegrityError', 'link-167');">IntegrityError</a></tt> </tt>
</div><a name="L2078"></a><tt class="py-lineno">2078</tt>  <tt class="py-line"> </tt>
<a name="MSSQLAdapter.rowslice"></a><div id="MSSQLAdapter.rowslice-def"><a name="L2079"></a><tt class="py-lineno">2079</tt> <a class="py-toggle" href="#" id="MSSQLAdapter.rowslice-toggle" onclick="return toggle('MSSQLAdapter.rowslice');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQLAdapter-class.html#rowslice">rowslice</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">rows</tt><tt class="py-op">,</tt><tt class="py-param">minimum</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">maximum</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQLAdapter.rowslice-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQLAdapter.rowslice-expanded"><a name="L2080"></a><tt class="py-lineno">2080</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">maximum</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L2081"></a><tt class="py-lineno">2081</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-902" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-902', 'rows', 'link-539');">rows</a></tt><tt class="py-op">[</tt><tt class="py-name">minimum</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L2082"></a><tt class="py-lineno">2082</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-903" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-903', 'rows', 'link-539');">rows</a></tt><tt class="py-op">[</tt><tt class="py-name">minimum</tt><tt class="py-op">:</tt><tt class="py-name">maximum</tt><tt class="py-op">]</tt> </tt>
</div></div><a name="L2083"></a><tt class="py-lineno">2083</tt>  <tt class="py-line"> </tt>
<a name="L2084"></a><tt class="py-lineno">2084</tt>  <tt class="py-line"> </tt>
<a name="MSSQL2Adapter"></a><div id="MSSQL2Adapter-def"><a name="L2085"></a><tt class="py-lineno">2085</tt> <a class="py-toggle" href="#" id="MSSQL2Adapter-toggle" onclick="return toggle('MSSQL2Adapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQL2Adapter-class.html">MSSQL2Adapter</a><tt class="py-op">(</tt><tt class="py-base-class">MSSQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQL2Adapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="MSSQL2Adapter-expanded"><a name="L2086"></a><tt class="py-lineno">2086</tt>  <tt class="py-line">    <tt id="link-904" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-904', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2087"></a><tt class="py-lineno">2087</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2088"></a><tt class="py-lineno">2088</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'NVARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2089"></a><tt class="py-lineno">2089</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'NTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2090"></a><tt class="py-lineno">2090</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'NVARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2091"></a><tt class="py-lineno">2091</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'IMAGE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2092"></a><tt class="py-lineno">2092</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'NVARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2093"></a><tt class="py-lineno">2093</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2094"></a><tt class="py-lineno">2094</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2095"></a><tt class="py-lineno">2095</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2096"></a><tt class="py-lineno">2096</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATETIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2097"></a><tt class="py-lineno">2097</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(8)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2098"></a><tt class="py-lineno">2098</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATETIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2099"></a><tt class="py-lineno">2099</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT IDENTITY PRIMARY KEY'</tt><tt class="py-op">,</tt> </tt>
<a name="L2100"></a><tt class="py-lineno">2100</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT, CONSTRAINT %(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2101"></a><tt class="py-lineno">2101</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">', CONSTRAINT FK_%(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2102"></a><tt class="py-lineno">2102</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">' CONSTRAINT FK_%(foreign_table)s_PK FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2103"></a><tt class="py-lineno">2103</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'NTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2104"></a><tt class="py-lineno">2104</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'NTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2105"></a><tt class="py-lineno">2105</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'NTEXT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2106"></a><tt class="py-lineno">2106</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2107"></a><tt class="py-lineno">2107</tt>  <tt class="py-line"> </tt>
<a name="MSSQL2Adapter.represent"></a><div id="MSSQL2Adapter.represent-def"><a name="L2108"></a><tt class="py-lineno">2108</tt> <a class="py-toggle" href="#" id="MSSQL2Adapter.represent-toggle" onclick="return toggle('MSSQL2Adapter.represent');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQL2Adapter-class.html#represent">represent</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQL2Adapter.represent-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQL2Adapter.represent-expanded"><a name="L2109"></a><tt class="py-lineno">2109</tt>  <tt class="py-line">        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt id="link-905" class="py-name"><a title="web2py.gluon.dal.BaseAdapter" class="py-name" href="#" onclick="return doclink('link-905', 'BaseAdapter', 'link-825');">BaseAdapter</a></tt><tt class="py-op">.</tt><tt id="link-906" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-906', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">)</tt> </tt>
<a name="L2110"></a><tt class="py-lineno">2110</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'string'</tt> <tt class="py-keyword">or</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'text'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">value</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">"'"</tt><tt class="py-op">:</tt> </tt>
<a name="L2111"></a><tt class="py-lineno">2111</tt>  <tt class="py-line">            <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-string">'N'</tt><tt class="py-op">+</tt><tt class="py-name">value</tt> </tt>
<a name="L2112"></a><tt class="py-lineno">2112</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">value</tt> </tt>
</div><a name="L2113"></a><tt class="py-lineno">2113</tt>  <tt class="py-line"> </tt>
<a name="MSSQL2Adapter.execute"></a><div id="MSSQL2Adapter.execute-def"><a name="L2114"></a><tt class="py-lineno">2114</tt> <a class="py-toggle" href="#" id="MSSQL2Adapter.execute-toggle" onclick="return toggle('MSSQL2Adapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MSSQL2Adapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">a</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MSSQL2Adapter.execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MSSQL2Adapter.execute-expanded"><a name="L2115"></a><tt class="py-lineno">2115</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-907" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.log_execute
web2py.gluon.dal.NoSQLAdapter.log_execute" class="py-name" href="#" onclick="return doclink('link-907', 'log_execute', 'link-587');">log_execute</a></tt><tt class="py-op">(</tt><tt class="py-name">a</tt><tt class="py-op">.</tt><tt id="link-908" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-908', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2116"></a><tt class="py-lineno">2116</tt>  <tt class="py-line"> </tt>
<a name="L2117"></a><tt class="py-lineno">2117</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter"></a><div id="FireBirdAdapter-def"><a name="L2118"></a><tt class="py-lineno">2118</tt> <a class="py-toggle" href="#" id="FireBirdAdapter-toggle" onclick="return toggle('FireBirdAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html">FireBirdAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="FireBirdAdapter-expanded"><a name="L2119"></a><tt class="py-lineno">2119</tt>  <tt class="py-line"> </tt>
<a name="L2120"></a><tt class="py-lineno">2120</tt>  <tt class="py-line">    <tt id="link-909" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-909', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-910" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-910', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-911" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-911', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'pyodbc'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2121"></a><tt class="py-lineno">2121</tt>  <tt class="py-line"> </tt>
<a name="L2122"></a><tt class="py-lineno">2122</tt>  <tt class="py-line">    <tt id="link-912" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit_on_alter_table
web2py.gluon.dal.FireBirdAdapter.commit_on_alter_table
web2py.gluon.dal.MySQLAdapter.commit_on_alter_table
web2py.gluon.dal.OracleAdapter.commit_on_alter_table" class="py-name" href="#" onclick="return doclink('link-912', 'commit_on_alter_table', 'link-162');">commit_on_alter_table</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L2123"></a><tt class="py-lineno">2123</tt>  <tt class="py-line">    <tt id="link-913" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-913', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L2124"></a><tt class="py-lineno">2124</tt>  <tt class="py-line">    <tt id="link-914" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-914', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2125"></a><tt class="py-lineno">2125</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2126"></a><tt class="py-lineno">2126</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2127"></a><tt class="py-lineno">2127</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2128"></a><tt class="py-lineno">2128</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2129"></a><tt class="py-lineno">2129</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 0'</tt><tt class="py-op">,</tt> </tt>
<a name="L2130"></a><tt class="py-lineno">2130</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2131"></a><tt class="py-lineno">2131</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER'</tt><tt class="py-op">,</tt> </tt>
<a name="L2132"></a><tt class="py-lineno">2132</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'DOUBLE PRECISION'</tt><tt class="py-op">,</tt> </tt>
<a name="L2133"></a><tt class="py-lineno">2133</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'DECIMAL(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2134"></a><tt class="py-lineno">2134</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2135"></a><tt class="py-lineno">2135</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2136"></a><tt class="py-lineno">2136</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP'</tt><tt class="py-op">,</tt> </tt>
<a name="L2137"></a><tt class="py-lineno">2137</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER PRIMARY KEY'</tt><tt class="py-op">,</tt> </tt>
<a name="L2138"></a><tt class="py-lineno">2138</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2139"></a><tt class="py-lineno">2139</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2140"></a><tt class="py-lineno">2140</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2141"></a><tt class="py-lineno">2141</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2142"></a><tt class="py-lineno">2142</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2143"></a><tt class="py-lineno">2143</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.sequence_name"></a><div id="FireBirdAdapter.sequence_name-def"><a name="L2144"></a><tt class="py-lineno">2144</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.sequence_name-toggle" onclick="return toggle('FireBirdAdapter.sequence_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#sequence_name">sequence_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.sequence_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.sequence_name-expanded"><a name="L2145"></a><tt class="py-lineno">2145</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'genid_%s'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
</div><a name="L2146"></a><tt class="py-lineno">2146</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.trigger_name"></a><div id="FireBirdAdapter.trigger_name-def"><a name="L2147"></a><tt class="py-lineno">2147</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.trigger_name-toggle" onclick="return toggle('FireBirdAdapter.trigger_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#trigger_name">trigger_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.trigger_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.trigger_name-expanded"><a name="L2148"></a><tt class="py-lineno">2148</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'trg_id_%s'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
</div><a name="L2149"></a><tt class="py-lineno">2149</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.RANDOM"></a><div id="FireBirdAdapter.RANDOM-def"><a name="L2150"></a><tt class="py-lineno">2150</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.RANDOM-toggle" onclick="return toggle('FireBirdAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.RANDOM-expanded"><a name="L2151"></a><tt class="py-lineno">2151</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'RAND()'</tt> </tt>
</div><a name="L2152"></a><tt class="py-lineno">2152</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.NOT_NULL"></a><div id="FireBirdAdapter.NOT_NULL-def"><a name="L2153"></a><tt class="py-lineno">2153</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.NOT_NULL-toggle" onclick="return toggle('FireBirdAdapter.NOT_NULL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#NOT_NULL">NOT_NULL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">default</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.NOT_NULL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.NOT_NULL-expanded"><a name="L2154"></a><tt class="py-lineno">2154</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'DEFAULT %s NOT NULL'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-915" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-915', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">default</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2155"></a><tt class="py-lineno">2155</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.SUBSTRING"></a><div id="FireBirdAdapter.SUBSTRING-def"><a name="L2156"></a><tt class="py-lineno">2156</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.SUBSTRING-toggle" onclick="return toggle('FireBirdAdapter.SUBSTRING');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#SUBSTRING">SUBSTRING</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">parameters</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.SUBSTRING-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.SUBSTRING-expanded"><a name="L2157"></a><tt class="py-lineno">2157</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SUBSTRING(%s from %s for %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-916" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-916', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">parameters</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2158"></a><tt class="py-lineno">2158</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter._drop"></a><div id="FireBirdAdapter._drop-def"><a name="L2159"></a><tt class="py-lineno">2159</tt> <a class="py-toggle" href="#" id="FireBirdAdapter._drop-toggle" onclick="return toggle('FireBirdAdapter._drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#_drop">_drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter._drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter._drop-expanded"><a name="L2160"></a><tt class="py-lineno">2160</tt>  <tt class="py-line">        <tt id="link-917" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-917', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> </tt>
<a name="L2161"></a><tt class="py-lineno">2161</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'DROP TABLE %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-string">'DROP GENERATOR %s;'</tt> <tt class="py-op">%</tt> <tt id="link-918" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-918', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">]</tt> </tt>
</div><a name="L2162"></a><tt class="py-lineno">2162</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.select_limitby"></a><div id="FireBirdAdapter.select_limitby-def"><a name="L2163"></a><tt class="py-lineno">2163</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.select_limitby-toggle" onclick="return toggle('FireBirdAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.select_limitby-expanded"><a name="L2164"></a><tt class="py-lineno">2164</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L2165"></a><tt class="py-lineno">2165</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L2166"></a><tt class="py-lineno">2166</tt>  <tt class="py-line">            <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' FIRST %i SKIP %i'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">lmax</tt> <tt class="py-op">-</tt> <tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmin</tt><tt class="py-op">)</tt> </tt>
<a name="L2167"></a><tt class="py-lineno">2167</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2168"></a><tt class="py-lineno">2168</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter._truncate"></a><div id="FireBirdAdapter._truncate-def"><a name="L2169"></a><tt class="py-lineno">2169</tt> <a class="py-toggle" href="#" id="FireBirdAdapter._truncate-toggle" onclick="return toggle('FireBirdAdapter._truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#_truncate">_truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter._truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter._truncate-expanded"><a name="L2170"></a><tt class="py-lineno">2170</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-string">'DELETE FROM %s;'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L2171"></a><tt class="py-lineno">2171</tt>  <tt class="py-line">                <tt class="py-string">'SET GENERATOR %s TO 0;'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt><tt class="py-op">]</tt> </tt>
</div><a name="L2172"></a><tt class="py-lineno">2172</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.__init__"></a><div id="FireBirdAdapter.__init__-def"><a name="L2173"></a><tt class="py-lineno">2173</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.__init__-toggle" onclick="return toggle('FireBirdAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2174"></a><tt class="py-lineno">2174</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-919" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-919', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-920" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-920', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2175"></a><tt class="py-lineno">2175</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.__init__-expanded"><a name="L2176"></a><tt class="py-lineno">2176</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2177"></a><tt class="py-lineno">2177</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"firebird"</tt> </tt>
<a name="L2178"></a><tt class="py-lineno">2178</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2179"></a><tt class="py-lineno">2179</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2180"></a><tt class="py-lineno">2180</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2181"></a><tt class="py-lineno">2181</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2182"></a><tt class="py-lineno">2182</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-921" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-921', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2183"></a><tt class="py-lineno">2183</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2184"></a><tt class="py-lineno">2184</tt>  <tt class="py-line">        <tt id="link-922" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-922', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;.+?)(\?set_encoding=(?P&lt;charset&gt;\w+))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2185"></a><tt class="py-lineno">2185</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-923" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-923', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2186"></a><tt class="py-lineno">2186</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2187"></a><tt class="py-lineno">2187</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-924" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-924', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2188"></a><tt class="py-lineno">2188</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L2189"></a><tt class="py-lineno">2189</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L2190"></a><tt class="py-lineno">2190</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-925" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-925', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2191"></a><tt class="py-lineno">2191</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L2192"></a><tt class="py-lineno">2192</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2193"></a><tt class="py-lineno">2193</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-926" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-926', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L2194"></a><tt class="py-lineno">2194</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L2195"></a><tt class="py-lineno">2195</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L2196"></a><tt class="py-lineno">2196</tt>  <tt class="py-line">        <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt id="link-927" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-927', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-number">3050</tt><tt class="py-op">)</tt> </tt>
<a name="L2197"></a><tt class="py-lineno">2197</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-928" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-928', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L2198"></a><tt class="py-lineno">2198</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L2199"></a><tt class="py-lineno">2199</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L2200"></a><tt class="py-lineno">2200</tt>  <tt class="py-line">        <tt class="py-name">charset</tt> <tt class="py-op">=</tt> <tt id="link-929" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-929', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'charset'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'UTF8'</tt> </tt>
<a name="L2201"></a><tt class="py-lineno">2201</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">.</tt><tt id="link-930" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-930', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">dsn</tt><tt class="py-op">=</tt><tt class="py-string">'%s/%s:%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">host</tt><tt class="py-op">,</tt><tt class="py-name">port</tt><tt class="py-op">,</tt><tt class="py-name">db</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2202"></a><tt class="py-lineno">2202</tt>  <tt class="py-line">                                   <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2203"></a><tt class="py-lineno">2203</tt>  <tt class="py-line">                                   <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">password</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2204"></a><tt class="py-lineno">2204</tt>  <tt class="py-line">                                   <tt class="py-name">charset</tt> <tt class="py-op">=</tt> <tt class="py-name">charset</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2205"></a><tt class="py-lineno">2205</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">.</tt><tt id="link-931" class="py-name" targets="Method web2py.gluon.rocket.Headers.has_key()=web2py.gluon.rocket.Headers-class.html#has_key"><a title="web2py.gluon.rocket.Headers.has_key" class="py-name" href="#" onclick="return doclink('link-931', 'has_key', 'link-931');">has_key</a></tt><tt class="py-op">(</tt><tt class="py-string">'driver_name'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2206"></a><tt class="py-lineno">2206</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">[</tt><tt class="py-string">'driver_name'</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'kinterbasdb'</tt><tt class="py-op">:</tt> </tt>
<a name="L2207"></a><tt class="py-lineno">2207</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-932" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-932', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">kinterbasdb</tt> </tt>
<a name="L2208"></a><tt class="py-lineno">2208</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">[</tt><tt class="py-string">'driver_name'</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'firebirdsql'</tt><tt class="py-op">:</tt> </tt>
<a name="L2209"></a><tt class="py-lineno">2209</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-933" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-933', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">firebirdsql</tt> </tt>
<a name="L2210"></a><tt class="py-lineno">2210</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2211"></a><tt class="py-lineno">2211</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-934" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-934', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">kinterbasdb</tt>         </tt>
<a name="L2212"></a><tt class="py-lineno">2212</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2213"></a><tt class="py-lineno">2213</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-935" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-935', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-936" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-936', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2214"></a><tt class="py-lineno">2214</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-937" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-937', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-938" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-938', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2215"></a><tt class="py-lineno">2215</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2216"></a><tt class="py-lineno">2216</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.create_sequence_and_triggers"></a><div id="FireBirdAdapter.create_sequence_and_triggers-def"><a name="L2217"></a><tt class="py-lineno">2217</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('FireBirdAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.create_sequence_and_triggers-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.create_sequence_and_triggers-expanded"><a name="L2218"></a><tt class="py-lineno">2218</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L2219"></a><tt class="py-lineno">2219</tt>  <tt class="py-line">        <tt id="link-939" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-939', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> </tt>
<a name="L2220"></a><tt class="py-lineno">2220</tt>  <tt class="py-line">        <tt id="link-940" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-940', 'trigger_name', 'link-860');">trigger_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_trigger_name</tt> </tt>
<a name="L2221"></a><tt class="py-lineno">2221</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-941" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-941', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L2222"></a><tt class="py-lineno">2222</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-942" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-942', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'create generator %s;'</tt> <tt class="py-op">%</tt> <tt id="link-943" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-943', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2223"></a><tt class="py-lineno">2223</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-944" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-944', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'set generator %s to 0;'</tt> <tt class="py-op">%</tt> <tt id="link-945" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-945', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2224"></a><tt class="py-lineno">2224</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-946" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-946', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'create trigger %s for %s active before insert position 0 as\nbegin\nif(new.id is null) then\nbegin\nnew.id = gen_id(%s, 1);\nend\nend;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-947" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-947', 'trigger_name', 'link-860');">trigger_name</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt id="link-948" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-948', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2225"></a><tt class="py-lineno">2225</tt>  <tt class="py-line"> </tt>
<a name="FireBirdAdapter.lastrowid"></a><div id="FireBirdAdapter.lastrowid-def"><a name="L2226"></a><tt class="py-lineno">2226</tt> <a class="py-toggle" href="#" id="FireBirdAdapter.lastrowid-toggle" onclick="return toggle('FireBirdAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdAdapter.lastrowid-expanded"><a name="L2227"></a><tt class="py-lineno">2227</tt>  <tt class="py-line">        <tt id="link-949" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-949', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> </tt>
<a name="L2228"></a><tt class="py-lineno">2228</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-950" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-950', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'SELECT gen_id(%s, 0) FROM rdb$database'</tt> <tt class="py-op">%</tt> <tt id="link-951" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-951', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2229"></a><tt class="py-lineno">2229</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2230"></a><tt class="py-lineno">2230</tt>  <tt class="py-line"> </tt>
<a name="L2231"></a><tt class="py-lineno">2231</tt>  <tt class="py-line"> </tt>
<a name="FireBirdEmbeddedAdapter"></a><div id="FireBirdEmbeddedAdapter-def"><a name="L2232"></a><tt class="py-lineno">2232</tt> <a class="py-toggle" href="#" id="FireBirdEmbeddedAdapter-toggle" onclick="return toggle('FireBirdEmbeddedAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdEmbeddedAdapter-class.html">FireBirdEmbeddedAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">FireBirdAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdEmbeddedAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="FireBirdEmbeddedAdapter-expanded"><a name="L2233"></a><tt class="py-lineno">2233</tt>  <tt class="py-line"> </tt>
<a name="FireBirdEmbeddedAdapter.__init__"></a><div id="FireBirdEmbeddedAdapter.__init__-def"><a name="L2234"></a><tt class="py-lineno">2234</tt> <a class="py-toggle" href="#" id="FireBirdEmbeddedAdapter.__init__-toggle" onclick="return toggle('FireBirdEmbeddedAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.FireBirdEmbeddedAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2235"></a><tt class="py-lineno">2235</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-952" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-952', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-953" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-953', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2236"></a><tt class="py-lineno">2236</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="FireBirdEmbeddedAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="FireBirdEmbeddedAdapter.__init__-expanded"><a name="L2237"></a><tt class="py-lineno">2237</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2238"></a><tt class="py-lineno">2238</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"firebird"</tt> </tt>
<a name="L2239"></a><tt class="py-lineno">2239</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2240"></a><tt class="py-lineno">2240</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2241"></a><tt class="py-lineno">2241</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2242"></a><tt class="py-lineno">2242</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2243"></a><tt class="py-lineno">2243</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-954" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-954', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2244"></a><tt class="py-lineno">2244</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2245"></a><tt class="py-lineno">2245</tt>  <tt class="py-line">        <tt id="link-955" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-955', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;path&gt;[^\?]+)(\?set_encoding=(?P&lt;charset&gt;\w+))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2246"></a><tt class="py-lineno">2246</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-956" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-956', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2247"></a><tt class="py-lineno">2247</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L2248"></a><tt class="py-lineno">2248</tt>  <tt class="py-line">                <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> </tt>
<a name="L2249"></a><tt class="py-lineno">2249</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-957" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-957', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2250"></a><tt class="py-lineno">2250</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L2251"></a><tt class="py-lineno">2251</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L2252"></a><tt class="py-lineno">2252</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-958" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-958', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2253"></a><tt class="py-lineno">2253</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L2254"></a><tt class="py-lineno">2254</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2255"></a><tt class="py-lineno">2255</tt>  <tt class="py-line">        <tt class="py-name">pathdb</tt> <tt class="py-op">=</tt> <tt id="link-959" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-959', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'path'</tt><tt class="py-op">)</tt> </tt>
<a name="L2256"></a><tt class="py-lineno">2256</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">pathdb</tt><tt class="py-op">:</tt> </tt>
<a name="L2257"></a><tt class="py-lineno">2257</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Path required'</tt> </tt>
<a name="L2258"></a><tt class="py-lineno">2258</tt>  <tt class="py-line">        <tt class="py-name">charset</tt> <tt class="py-op">=</tt> <tt id="link-960" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-960', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'charset'</tt><tt class="py-op">)</tt> </tt>
<a name="L2259"></a><tt class="py-lineno">2259</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">charset</tt><tt class="py-op">:</tt> </tt>
<a name="L2260"></a><tt class="py-lineno">2260</tt>  <tt class="py-line">            <tt class="py-name">charset</tt> <tt class="py-op">=</tt> <tt class="py-string">'UTF8'</tt> </tt>
<a name="L2261"></a><tt class="py-lineno">2261</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2262"></a><tt class="py-lineno">2262</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">.</tt><tt id="link-961" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-961', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">host</tt><tt class="py-op">=</tt><tt class="py-name">host</tt><tt class="py-op">,</tt> </tt>
<a name="L2263"></a><tt class="py-lineno">2263</tt>  <tt class="py-line">                                   <tt class="py-name">database</tt><tt class="py-op">=</tt><tt class="py-name">pathdb</tt><tt class="py-op">,</tt> </tt>
<a name="L2264"></a><tt class="py-lineno">2264</tt>  <tt class="py-line">                                   <tt class="py-name">user</tt><tt class="py-op">=</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2265"></a><tt class="py-lineno">2265</tt>  <tt class="py-line">                                   <tt class="py-name">password</tt><tt class="py-op">=</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">password</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2266"></a><tt class="py-lineno">2266</tt>  <tt class="py-line">                                   <tt class="py-name">charset</tt><tt class="py-op">=</tt><tt class="py-name">charset</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2267"></a><tt class="py-lineno">2267</tt>  <tt class="py-line">        <tt class="py-comment">#def connect(driver_args=driver_args):</tt> </tt>
<a name="L2268"></a><tt class="py-lineno">2268</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment">#    return kinterbasdb.connect(**driver_args)</tt> </tt>
<a name="L2269"></a><tt class="py-lineno">2269</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">.</tt><tt id="link-962" class="py-name"><a title="web2py.gluon.rocket.Headers.has_key" class="py-name" href="#" onclick="return doclink('link-962', 'has_key', 'link-931');">has_key</a></tt><tt class="py-op">(</tt><tt class="py-string">'driver_name'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2270"></a><tt class="py-lineno">2270</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">[</tt><tt class="py-string">'driver_name'</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'kinterbasdb'</tt><tt class="py-op">:</tt> </tt>
<a name="L2271"></a><tt class="py-lineno">2271</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-963" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-963', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">kinterbasdb</tt> </tt>
<a name="L2272"></a><tt class="py-lineno">2272</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">[</tt><tt class="py-string">'driver_name'</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'firebirdsql'</tt><tt class="py-op">:</tt> </tt>
<a name="L2273"></a><tt class="py-lineno">2273</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-964" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-964', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">firebirdsql</tt> </tt>
<a name="L2274"></a><tt class="py-lineno">2274</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2275"></a><tt class="py-lineno">2275</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-965" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-965', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt class="py-name">kinterbasdb</tt>         </tt>
<a name="L2276"></a><tt class="py-lineno">2276</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2277"></a><tt class="py-lineno">2277</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-966" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-966', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-967" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-967', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2278"></a><tt class="py-lineno">2278</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-968" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-968', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-969" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-969', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2279"></a><tt class="py-lineno">2279</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2280"></a><tt class="py-lineno">2280</tt>  <tt class="py-line"> </tt>
<a name="L2281"></a><tt class="py-lineno">2281</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter"></a><div id="InformixAdapter-def"><a name="L2282"></a><tt class="py-lineno">2282</tt> <a class="py-toggle" href="#" id="InformixAdapter-toggle" onclick="return toggle('InformixAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html">InformixAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="InformixAdapter-expanded"><a name="L2283"></a><tt class="py-lineno">2283</tt>  <tt class="py-line"> </tt>
<a name="L2284"></a><tt class="py-lineno">2284</tt>  <tt class="py-line">    <tt id="link-970" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-970', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-971" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-971', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-972" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-972', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'informixdb'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2285"></a><tt class="py-lineno">2285</tt>  <tt class="py-line"> </tt>
<a name="L2286"></a><tt class="py-lineno">2286</tt>  <tt class="py-line">    <tt id="link-973" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-973', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2287"></a><tt class="py-lineno">2287</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2288"></a><tt class="py-lineno">2288</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2289"></a><tt class="py-lineno">2289</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2290"></a><tt class="py-lineno">2290</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2291"></a><tt class="py-lineno">2291</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 0'</tt><tt class="py-op">,</tt> </tt>
<a name="L2292"></a><tt class="py-lineno">2292</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2293"></a><tt class="py-lineno">2293</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER'</tt><tt class="py-op">,</tt> </tt>
<a name="L2294"></a><tt class="py-lineno">2294</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2295"></a><tt class="py-lineno">2295</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2296"></a><tt class="py-lineno">2296</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2297"></a><tt class="py-lineno">2297</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(8)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2298"></a><tt class="py-lineno">2298</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATETIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2299"></a><tt class="py-lineno">2299</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'SERIAL'</tt><tt class="py-op">,</tt> </tt>
<a name="L2300"></a><tt class="py-lineno">2300</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2301"></a><tt class="py-lineno">2301</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">'REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s CONSTRAINT FK_%(table_name)s_%(field_name)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2302"></a><tt class="py-lineno">2302</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">'FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s CONSTRAINT TFK_%(table_name)s_%(field_name)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2303"></a><tt class="py-lineno">2303</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2304"></a><tt class="py-lineno">2304</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2305"></a><tt class="py-lineno">2305</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB SUB_TYPE 1'</tt><tt class="py-op">,</tt> </tt>
<a name="L2306"></a><tt class="py-lineno">2306</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2307"></a><tt class="py-lineno">2307</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.RANDOM"></a><div id="InformixAdapter.RANDOM-def"><a name="L2308"></a><tt class="py-lineno">2308</tt> <a class="py-toggle" href="#" id="InformixAdapter.RANDOM-toggle" onclick="return toggle('InformixAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.RANDOM-expanded"><a name="L2309"></a><tt class="py-lineno">2309</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'Random()'</tt> </tt>
</div><a name="L2310"></a><tt class="py-lineno">2310</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.NOT_NULL"></a><div id="InformixAdapter.NOT_NULL-def"><a name="L2311"></a><tt class="py-lineno">2311</tt> <a class="py-toggle" href="#" id="InformixAdapter.NOT_NULL-toggle" onclick="return toggle('InformixAdapter.NOT_NULL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#NOT_NULL">NOT_NULL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">default</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.NOT_NULL-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.NOT_NULL-expanded"><a name="L2312"></a><tt class="py-lineno">2312</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'DEFAULT %s NOT NULL'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-974" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-974', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">default</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2313"></a><tt class="py-lineno">2313</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.select_limitby"></a><div id="InformixAdapter.select_limitby-def"><a name="L2314"></a><tt class="py-lineno">2314</tt> <a class="py-toggle" href="#" id="InformixAdapter.select_limitby-toggle" onclick="return toggle('InformixAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.select_limitby-expanded"><a name="L2315"></a><tt class="py-lineno">2315</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L2316"></a><tt class="py-lineno">2316</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L2317"></a><tt class="py-lineno">2317</tt>  <tt class="py-line">            <tt class="py-name">fetch_amt</tt> <tt class="py-op">=</tt> <tt class="py-name">lmax</tt> <tt class="py-op">-</tt> <tt class="py-name">lmin</tt> </tt>
<a name="L2318"></a><tt class="py-lineno">2318</tt>  <tt class="py-line">            <tt class="py-name">dbms_version</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">dbms_version</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L2319"></a><tt class="py-lineno">2319</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">lmin</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-name">dbms_version</tt> <tt class="py-op">&gt;=</tt> <tt class="py-number">10</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2320"></a><tt class="py-lineno">2320</tt>  <tt class="py-line">                <tt class="py-comment"># Requires Informix 10.0+</tt> </tt>
<a name="L2321"></a><tt class="py-lineno">2321</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' SKIP %d'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt> </tt>
<a name="L2322"></a><tt class="py-lineno">2322</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">fetch_amt</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-name">dbms_version</tt> <tt class="py-op">&gt;=</tt> <tt class="py-number">9</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2323"></a><tt class="py-lineno">2323</tt>  <tt class="py-line">                <tt class="py-comment"># Requires Informix 9.0+</tt> </tt>
<a name="L2324"></a><tt class="py-lineno">2324</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' FIRST %d'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">fetch_amt</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt> </tt>
<a name="L2325"></a><tt class="py-lineno">2325</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2326"></a><tt class="py-lineno">2326</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.represent_exceptions"></a><div id="InformixAdapter.represent_exceptions-def"><a name="L2327"></a><tt class="py-lineno">2327</tt> <a class="py-toggle" href="#" id="InformixAdapter.represent_exceptions-toggle" onclick="return toggle('InformixAdapter.represent_exceptions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#represent_exceptions">represent_exceptions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.represent_exceptions-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.represent_exceptions-expanded"><a name="L2328"></a><tt class="py-lineno">2328</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'date'</tt><tt class="py-op">:</tt> </tt>
<a name="L2329"></a><tt class="py-lineno">2329</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-975" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-975', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-976" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-976', 'date', 'link-604');">date</a></tt><tt class="py-op">,</tt> <tt id="link-977" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-977', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-978" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-978', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2330"></a><tt class="py-lineno">2330</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt> </tt>
<a name="L2331"></a><tt class="py-lineno">2331</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2332"></a><tt class="py-lineno">2332</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2333"></a><tt class="py-lineno">2333</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">"to_date('%s','yyyy-mm-dd')"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L2334"></a><tt class="py-lineno">2334</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> </tt>
<a name="L2335"></a><tt class="py-lineno">2335</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-979" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-979', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-980" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-980', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2336"></a><tt class="py-lineno">2336</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'T'</tt><tt class="py-op">,</tt><tt class="py-string">' '</tt><tt class="py-op">)</tt> </tt>
<a name="L2337"></a><tt class="py-lineno">2337</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-981" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-981', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-982" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-982', 'date', 'link-604');">date</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2338"></a><tt class="py-lineno">2338</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">+</tt><tt class="py-string">' 00:00:00'</tt> </tt>
<a name="L2339"></a><tt class="py-lineno">2339</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2340"></a><tt class="py-lineno">2340</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2341"></a><tt class="py-lineno">2341</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">"to_date('%s','yyyy-mm-dd hh24:mi:ss')"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L2342"></a><tt class="py-lineno">2342</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L2343"></a><tt class="py-lineno">2343</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.__init__"></a><div id="InformixAdapter.__init__-def"><a name="L2344"></a><tt class="py-lineno">2344</tt> <a class="py-toggle" href="#" id="InformixAdapter.__init__-toggle" onclick="return toggle('InformixAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2345"></a><tt class="py-lineno">2345</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-983" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-983', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-984" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-984', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2346"></a><tt class="py-lineno">2346</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.__init__-expanded"><a name="L2347"></a><tt class="py-lineno">2347</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2348"></a><tt class="py-lineno">2348</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"informix"</tt> </tt>
<a name="L2349"></a><tt class="py-lineno">2349</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2350"></a><tt class="py-lineno">2350</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2351"></a><tt class="py-lineno">2351</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2352"></a><tt class="py-lineno">2352</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2353"></a><tt class="py-lineno">2353</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-985" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-985', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2354"></a><tt class="py-lineno">2354</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2355"></a><tt class="py-lineno">2355</tt>  <tt class="py-line">        <tt id="link-986" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-986', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;.+)$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2356"></a><tt class="py-lineno">2356</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-987" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-987', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2357"></a><tt class="py-lineno">2357</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L2358"></a><tt class="py-lineno">2358</tt>  <tt class="py-line">                <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> </tt>
<a name="L2359"></a><tt class="py-lineno">2359</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-988" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-988', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2360"></a><tt class="py-lineno">2360</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L2361"></a><tt class="py-lineno">2361</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L2362"></a><tt class="py-lineno">2362</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-989" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-989', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2363"></a><tt class="py-lineno">2363</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L2364"></a><tt class="py-lineno">2364</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2365"></a><tt class="py-lineno">2365</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-990" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-990', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L2366"></a><tt class="py-lineno">2366</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L2367"></a><tt class="py-lineno">2367</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L2368"></a><tt class="py-lineno">2368</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-991" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-991', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L2369"></a><tt class="py-lineno">2369</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L2370"></a><tt class="py-lineno">2370</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L2371"></a><tt class="py-lineno">2371</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">)</tt> </tt>
<a name="L2372"></a><tt class="py-lineno">2372</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">password</tt><tt class="py-op">)</tt> </tt>
<a name="L2373"></a><tt class="py-lineno">2373</tt>  <tt class="py-line">        <tt class="py-name">dsn</tt> <tt class="py-op">=</tt> <tt class="py-string">'%s@%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">host</tt><tt class="py-op">)</tt> </tt>
<a name="L2374"></a><tt class="py-lineno">2374</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">.</tt><tt id="link-992" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-992', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">=</tt><tt class="py-name">user</tt><tt class="py-op">,</tt><tt class="py-name">password</tt><tt class="py-op">=</tt><tt class="py-name">password</tt><tt class="py-op">,</tt><tt class="py-name">autocommit</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2375"></a><tt class="py-lineno">2375</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">dsn</tt><tt class="py-op">=</tt><tt class="py-name">dsn</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2376"></a><tt class="py-lineno">2376</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-993" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-993', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-994" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-994', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">dsn</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2377"></a><tt class="py-lineno">2377</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-995" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-995', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-996" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-996', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2378"></a><tt class="py-lineno">2378</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2379"></a><tt class="py-lineno">2379</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.execute"></a><div id="InformixAdapter.execute-def"><a name="L2380"></a><tt class="py-lineno">2380</tt> <a class="py-toggle" href="#" id="InformixAdapter.execute-toggle" onclick="return toggle('InformixAdapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">command</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.execute-expanded"><a name="L2381"></a><tt class="py-lineno">2381</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">command</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">';'</tt><tt class="py-op">:</tt> </tt>
<a name="L2382"></a><tt class="py-lineno">2382</tt>  <tt class="py-line">            <tt class="py-name">command</tt> <tt class="py-op">=</tt> <tt class="py-name">command</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2383"></a><tt class="py-lineno">2383</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-997" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.log_execute
web2py.gluon.dal.NoSQLAdapter.log_execute" class="py-name" href="#" onclick="return doclink('link-997', 'log_execute', 'link-587');">log_execute</a></tt><tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2384"></a><tt class="py-lineno">2384</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.lastrowid"></a><div id="InformixAdapter.lastrowid-def"><a name="L2385"></a><tt class="py-lineno">2385</tt> <a class="py-toggle" href="#" id="InformixAdapter.lastrowid-toggle" onclick="return toggle('InformixAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.lastrowid-expanded"><a name="L2386"></a><tt class="py-lineno">2386</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">sqlerrd</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
</div><a name="L2387"></a><tt class="py-lineno">2387</tt>  <tt class="py-line"> </tt>
<a name="InformixAdapter.integrity_error_class"></a><div id="InformixAdapter.integrity_error_class-def"><a name="L2388"></a><tt class="py-lineno">2388</tt> <a class="py-toggle" href="#" id="InformixAdapter.integrity_error_class-toggle" onclick="return toggle('InformixAdapter.integrity_error_class');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.InformixAdapter-class.html#integrity_error_class">integrity_error_class</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="InformixAdapter.integrity_error_class-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="InformixAdapter.integrity_error_class-expanded"><a name="L2389"></a><tt class="py-lineno">2389</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">informixdb</tt><tt class="py-op">.</tt><tt id="link-998" class="py-name"><a title="psycopg2.IntegrityError
web2py.gluon.contrib.pymysql.err.IntegrityError" class="py-name" href="#" onclick="return doclink('link-998', 'IntegrityError', 'link-167');">IntegrityError</a></tt> </tt>
</div></div><a name="L2390"></a><tt class="py-lineno">2390</tt>  <tt class="py-line"> </tt>
<a name="L2391"></a><tt class="py-lineno">2391</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter"></a><div id="DB2Adapter-def"><a name="L2392"></a><tt class="py-lineno">2392</tt> <a class="py-toggle" href="#" id="DB2Adapter-toggle" onclick="return toggle('DB2Adapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html">DB2Adapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="DB2Adapter-expanded"><a name="L2393"></a><tt class="py-lineno">2393</tt>  <tt class="py-line"> </tt>
<a name="L2394"></a><tt class="py-lineno">2394</tt>  <tt class="py-line">    <tt id="link-999" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-999', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-1000" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-1000', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1001" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1001', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'pyodbc'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2395"></a><tt class="py-lineno">2395</tt>  <tt class="py-line"> </tt>
<a name="L2396"></a><tt class="py-lineno">2396</tt>  <tt class="py-line">    <tt id="link-1002" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1002', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2397"></a><tt class="py-lineno">2397</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2398"></a><tt class="py-lineno">2398</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2399"></a><tt class="py-lineno">2399</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2400"></a><tt class="py-lineno">2400</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2401"></a><tt class="py-lineno">2401</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2402"></a><tt class="py-lineno">2402</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2403"></a><tt class="py-lineno">2403</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2404"></a><tt class="py-lineno">2404</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'DOUBLE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2405"></a><tt class="py-lineno">2405</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2406"></a><tt class="py-lineno">2406</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2407"></a><tt class="py-lineno">2407</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2408"></a><tt class="py-lineno">2408</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP'</tt><tt class="py-op">,</tt> </tt>
<a name="L2409"></a><tt class="py-lineno">2409</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER GENERATED ALWAYS AS IDENTITY PRIMARY KEY NOT NULL'</tt><tt class="py-op">,</tt> </tt>
<a name="L2410"></a><tt class="py-lineno">2410</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT, FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2411"></a><tt class="py-lineno">2411</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">', CONSTRAINT FK_%(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2412"></a><tt class="py-lineno">2412</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">' CONSTRAINT FK_%(foreign_table)s_PK FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2413"></a><tt class="py-lineno">2413</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2414"></a><tt class="py-lineno">2414</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2415"></a><tt class="py-lineno">2415</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2416"></a><tt class="py-lineno">2416</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2417"></a><tt class="py-lineno">2417</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.LEFT_JOIN"></a><div id="DB2Adapter.LEFT_JOIN-def"><a name="L2418"></a><tt class="py-lineno">2418</tt> <a class="py-toggle" href="#" id="DB2Adapter.LEFT_JOIN-toggle" onclick="return toggle('DB2Adapter.LEFT_JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#LEFT_JOIN">LEFT_JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.LEFT_JOIN-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.LEFT_JOIN-expanded"><a name="L2419"></a><tt class="py-lineno">2419</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'LEFT OUTER JOIN'</tt> </tt>
</div><a name="L2420"></a><tt class="py-lineno">2420</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.RANDOM"></a><div id="DB2Adapter.RANDOM-def"><a name="L2421"></a><tt class="py-lineno">2421</tt> <a class="py-toggle" href="#" id="DB2Adapter.RANDOM-toggle" onclick="return toggle('DB2Adapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.RANDOM-expanded"><a name="L2422"></a><tt class="py-lineno">2422</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'RAND()'</tt> </tt>
</div><a name="L2423"></a><tt class="py-lineno">2423</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.select_limitby"></a><div id="DB2Adapter.select_limitby-def"><a name="L2424"></a><tt class="py-lineno">2424</tt> <a class="py-toggle" href="#" id="DB2Adapter.select_limitby-toggle" onclick="return toggle('DB2Adapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.select_limitby-expanded"><a name="L2425"></a><tt class="py-lineno">2425</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L2426"></a><tt class="py-lineno">2426</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L2427"></a><tt class="py-lineno">2427</tt>  <tt class="py-line">            <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' FETCH FIRST %i ROWS ONLY'</tt> <tt class="py-op">%</tt> <tt class="py-name">lmax</tt> </tt>
<a name="L2428"></a><tt class="py-lineno">2428</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2429"></a><tt class="py-lineno">2429</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.represent_exceptions"></a><div id="DB2Adapter.represent_exceptions-def"><a name="L2430"></a><tt class="py-lineno">2430</tt> <a class="py-toggle" href="#" id="DB2Adapter.represent_exceptions-toggle" onclick="return toggle('DB2Adapter.represent_exceptions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#represent_exceptions">represent_exceptions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.represent_exceptions-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.represent_exceptions-expanded"><a name="L2431"></a><tt class="py-lineno">2431</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> </tt>
<a name="L2432"></a><tt class="py-lineno">2432</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b64encode</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2433"></a><tt class="py-lineno">2433</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">"BLOB('%s')"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L2434"></a><tt class="py-lineno">2434</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> </tt>
<a name="L2435"></a><tt class="py-lineno">2435</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-1003" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1003', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1004" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1004', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2436"></a><tt class="py-lineno">2436</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'T'</tt><tt class="py-op">,</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">,</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L2437"></a><tt class="py-lineno">2437</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-1005" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1005', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1006" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1006', 'date', 'link-604');">date</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2438"></a><tt class="py-lineno">2438</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">+</tt><tt class="py-string">'-00.00.00'</tt> </tt>
<a name="L2439"></a><tt class="py-lineno">2439</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">"'%s'"</tt> <tt class="py-op">%</tt> <tt class="py-name">obj</tt> </tt>
<a name="L2440"></a><tt class="py-lineno">2440</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L2441"></a><tt class="py-lineno">2441</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.__init__"></a><div id="DB2Adapter.__init__-def"><a name="L2442"></a><tt class="py-lineno">2442</tt> <a class="py-toggle" href="#" id="DB2Adapter.__init__-toggle" onclick="return toggle('DB2Adapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2443"></a><tt class="py-lineno">2443</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1007" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1007', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1008" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1008', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2444"></a><tt class="py-lineno">2444</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.__init__-expanded"><a name="L2445"></a><tt class="py-lineno">2445</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2446"></a><tt class="py-lineno">2446</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"db2"</tt> </tt>
<a name="L2447"></a><tt class="py-lineno">2447</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2448"></a><tt class="py-lineno">2448</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2449"></a><tt class="py-lineno">2449</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2450"></a><tt class="py-lineno">2450</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2451"></a><tt class="py-lineno">2451</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1009" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-1009', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2452"></a><tt class="py-lineno">2452</tt>  <tt class="py-line">        <tt class="py-name">cnxn</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">,</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2453"></a><tt class="py-lineno">2453</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">cnxn</tt><tt class="py-op">=</tt><tt class="py-name">cnxn</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2454"></a><tt class="py-lineno">2454</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1010" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1010', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-1011" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1011', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">cnxn</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2455"></a><tt class="py-lineno">2455</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1012" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1012', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1013" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1013', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2456"></a><tt class="py-lineno">2456</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2457"></a><tt class="py-lineno">2457</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.execute"></a><div id="DB2Adapter.execute-def"><a name="L2458"></a><tt class="py-lineno">2458</tt> <a class="py-toggle" href="#" id="DB2Adapter.execute-toggle" onclick="return toggle('DB2Adapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">command</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.execute-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.execute-expanded"><a name="L2459"></a><tt class="py-lineno">2459</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">command</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">';'</tt><tt class="py-op">:</tt> </tt>
<a name="L2460"></a><tt class="py-lineno">2460</tt>  <tt class="py-line">            <tt class="py-name">command</tt> <tt class="py-op">=</tt> <tt class="py-name">command</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2461"></a><tt class="py-lineno">2461</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1014" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.log_execute
web2py.gluon.dal.NoSQLAdapter.log_execute" class="py-name" href="#" onclick="return doclink('link-1014', 'log_execute', 'link-587');">log_execute</a></tt><tt class="py-op">(</tt><tt class="py-name">command</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2462"></a><tt class="py-lineno">2462</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.lastrowid"></a><div id="DB2Adapter.lastrowid-def"><a name="L2463"></a><tt class="py-lineno">2463</tt> <a class="py-toggle" href="#" id="DB2Adapter.lastrowid-toggle" onclick="return toggle('DB2Adapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.lastrowid-expanded"><a name="L2464"></a><tt class="py-lineno">2464</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1015" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1015', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'SELECT DISTINCT IDENTITY_VAL_LOCAL() FROM %s;'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">)</tt> </tt>
<a name="L2465"></a><tt class="py-lineno">2465</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2466"></a><tt class="py-lineno">2466</tt>  <tt class="py-line"> </tt>
<a name="DB2Adapter.rowslice"></a><div id="DB2Adapter.rowslice-def"><a name="L2467"></a><tt class="py-lineno">2467</tt> <a class="py-toggle" href="#" id="DB2Adapter.rowslice-toggle" onclick="return toggle('DB2Adapter.rowslice');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DB2Adapter-class.html#rowslice">rowslice</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">rows</tt><tt class="py-op">,</tt><tt class="py-param">minimum</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">maximum</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DB2Adapter.rowslice-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DB2Adapter.rowslice-expanded"><a name="L2468"></a><tt class="py-lineno">2468</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">maximum</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L2469"></a><tt class="py-lineno">2469</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1016" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1016', 'rows', 'link-539');">rows</a></tt><tt class="py-op">[</tt><tt class="py-name">minimum</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L2470"></a><tt class="py-lineno">2470</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1017" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1017', 'rows', 'link-539');">rows</a></tt><tt class="py-op">[</tt><tt class="py-name">minimum</tt><tt class="py-op">:</tt><tt class="py-name">maximum</tt><tt class="py-op">]</tt> </tt>
</div></div><a name="L2471"></a><tt class="py-lineno">2471</tt>  <tt class="py-line"> </tt>
<a name="L2472"></a><tt class="py-lineno">2472</tt>  <tt class="py-line"> </tt>
<a name="TeradataAdapter"></a><div id="TeradataAdapter-def"><a name="L2473"></a><tt class="py-lineno">2473</tt> <a class="py-toggle" href="#" id="TeradataAdapter-toggle" onclick="return toggle('TeradataAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.TeradataAdapter-class.html">TeradataAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">DB2Adapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="TeradataAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="TeradataAdapter-expanded"><a name="L2474"></a><tt class="py-lineno">2474</tt>  <tt class="py-line"> </tt>
<a name="L2475"></a><tt class="py-lineno">2475</tt>  <tt class="py-line">    <tt id="link-1018" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1018', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-1019" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-1019', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1020" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1020', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'pyodbc'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2476"></a><tt class="py-lineno">2476</tt>  <tt class="py-line"> </tt>
<a name="L2477"></a><tt class="py-lineno">2477</tt>  <tt class="py-line">    <tt id="link-1021" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1021', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2478"></a><tt class="py-lineno">2478</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2479"></a><tt class="py-lineno">2479</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2480"></a><tt class="py-lineno">2480</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2481"></a><tt class="py-lineno">2481</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2482"></a><tt class="py-lineno">2482</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2483"></a><tt class="py-lineno">2483</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2484"></a><tt class="py-lineno">2484</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2485"></a><tt class="py-lineno">2485</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'DOUBLE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2486"></a><tt class="py-lineno">2486</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2487"></a><tt class="py-lineno">2487</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2488"></a><tt class="py-lineno">2488</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2489"></a><tt class="py-lineno">2489</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP'</tt><tt class="py-op">,</tt> </tt>
<a name="L2490"></a><tt class="py-lineno">2490</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER GENERATED ALWAYS AS IDENTITY PRIMARY KEY NOT NULL'</tt><tt class="py-op">,</tt> </tt>
<a name="L2491"></a><tt class="py-lineno">2491</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT, FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2492"></a><tt class="py-lineno">2492</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">', CONSTRAINT FK_%(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2493"></a><tt class="py-lineno">2493</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">' CONSTRAINT FK_%(foreign_table)s_PK FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2494"></a><tt class="py-lineno">2494</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2495"></a><tt class="py-lineno">2495</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2496"></a><tt class="py-lineno">2496</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2497"></a><tt class="py-lineno">2497</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2498"></a><tt class="py-lineno">2498</tt>  <tt class="py-line"> </tt>
<a name="L2499"></a><tt class="py-lineno">2499</tt>  <tt class="py-line"> </tt>
<a name="TeradataAdapter.__init__"></a><div id="TeradataAdapter.__init__-def"><a name="L2500"></a><tt class="py-lineno">2500</tt> <a class="py-toggle" href="#" id="TeradataAdapter.__init__-toggle" onclick="return toggle('TeradataAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.TeradataAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2501"></a><tt class="py-lineno">2501</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1022" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1022', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1023" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1023', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2502"></a><tt class="py-lineno">2502</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="TeradataAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="TeradataAdapter.__init__-expanded"><a name="L2503"></a><tt class="py-lineno">2503</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2504"></a><tt class="py-lineno">2504</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"teradata"</tt> </tt>
<a name="L2505"></a><tt class="py-lineno">2505</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2506"></a><tt class="py-lineno">2506</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2507"></a><tt class="py-lineno">2507</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2508"></a><tt class="py-lineno">2508</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2509"></a><tt class="py-lineno">2509</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1024" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-1024', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2510"></a><tt class="py-lineno">2510</tt>  <tt class="py-line">        <tt class="py-name">cnxn</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">,</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2511"></a><tt class="py-lineno">2511</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">cnxn</tt><tt class="py-op">=</tt><tt class="py-name">cnxn</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2512"></a><tt class="py-lineno">2512</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1025" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1025', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-1026" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1026', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">cnxn</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2513"></a><tt class="py-lineno">2513</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1027" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1027', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1028" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1028', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2514"></a><tt class="py-lineno">2514</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2515"></a><tt class="py-lineno">2515</tt>  <tt class="py-line"> </tt>
<a name="L2516"></a><tt class="py-lineno">2516</tt>  <tt class="py-line"> </tt>
<a name="L2517"></a><tt class="py-lineno">2517</tt>  <tt class="py-line"><tt id="link-1029" class="py-name" targets="Variable web2py.gluon.dal.INGRES_SEQNAME=web2py.gluon.dal-module.html#INGRES_SEQNAME"><a title="web2py.gluon.dal.INGRES_SEQNAME" class="py-name" href="#" onclick="return doclink('link-1029', 'INGRES_SEQNAME', 'link-1029');">INGRES_SEQNAME</a></tt><tt class="py-op">=</tt><tt class="py-string">'ii***lineitemsequence'</tt> <tt class="py-comment"># NOTE invalid database object name</tt> </tt>
<a name="L2518"></a><tt class="py-lineno">2518</tt>  <tt class="py-line">                                       <tt class="py-comment"># (ANSI-SQL wants this form of name</tt> </tt>
<a name="L2519"></a><tt class="py-lineno">2519</tt>  <tt class="py-line"><tt class="py-comment"></tt>                                       <tt class="py-comment"># to be a delimited identifier)</tt> </tt>
<a name="L2520"></a><tt class="py-lineno">2520</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="IngresAdapter"></a><div id="IngresAdapter-def"><a name="L2521"></a><tt class="py-lineno">2521</tt> <a class="py-toggle" href="#" id="IngresAdapter-toggle" onclick="return toggle('IngresAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html">IngresAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="IngresAdapter-expanded"><a name="L2522"></a><tt class="py-lineno">2522</tt>  <tt class="py-line"> </tt>
<a name="L2523"></a><tt class="py-lineno">2523</tt>  <tt class="py-line">    <tt id="link-1030" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1030', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-1031" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-1031', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1032" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1032', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'ingresdbi'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2524"></a><tt class="py-lineno">2524</tt>  <tt class="py-line"> </tt>
<a name="L2525"></a><tt class="py-lineno">2525</tt>  <tt class="py-line">    <tt id="link-1033" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1033', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2526"></a><tt class="py-lineno">2526</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2527"></a><tt class="py-lineno">2527</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2528"></a><tt class="py-lineno">2528</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2529"></a><tt class="py-lineno">2529</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt>  <tt class="py-comment">## Not sure what this contains utf8 or nvarchar. Or even bytes?</tt> </tt>
<a name="L2530"></a><tt class="py-lineno">2530</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2531"></a><tt class="py-lineno">2531</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt>  <tt class="py-comment">## FIXME utf8 or nvarchar... or blob? what is this type?</tt> </tt>
<a name="L2532"></a><tt class="py-lineno">2532</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER4'</tt><tt class="py-op">,</tt> <tt class="py-comment"># or int8...</tt> </tt>
<a name="L2533"></a><tt class="py-lineno">2533</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2534"></a><tt class="py-lineno">2534</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2535"></a><tt class="py-lineno">2535</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'ANSIDATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2536"></a><tt class="py-lineno">2536</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME WITHOUT TIME ZONE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2537"></a><tt class="py-lineno">2537</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP WITHOUT TIME ZONE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2538"></a><tt class="py-lineno">2538</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'integer4 not null unique with default next value for %s'</tt> <tt class="py-op">%</tt> <tt id="link-1034" class="py-name"><a title="web2py.gluon.dal.INGRES_SEQNAME" class="py-name" href="#" onclick="return doclink('link-1034', 'INGRES_SEQNAME', 'link-1029');">INGRES_SEQNAME</a></tt><tt class="py-op">,</tt> </tt>
<a name="L2539"></a><tt class="py-lineno">2539</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'integer4, FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2540"></a><tt class="py-lineno">2540</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">', CONSTRAINT FK_%(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2541"></a><tt class="py-lineno">2541</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">' CONSTRAINT FK_%(foreign_table)s_PK FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> <tt class="py-comment">## FIXME TODO</tt> </tt>
<a name="L2542"></a><tt class="py-lineno">2542</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2543"></a><tt class="py-lineno">2543</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2544"></a><tt class="py-lineno">2544</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'CLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2545"></a><tt class="py-lineno">2545</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2546"></a><tt class="py-lineno">2546</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.LEFT_JOIN"></a><div id="IngresAdapter.LEFT_JOIN-def"><a name="L2547"></a><tt class="py-lineno">2547</tt> <a class="py-toggle" href="#" id="IngresAdapter.LEFT_JOIN-toggle" onclick="return toggle('IngresAdapter.LEFT_JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#LEFT_JOIN">LEFT_JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.LEFT_JOIN-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.LEFT_JOIN-expanded"><a name="L2548"></a><tt class="py-lineno">2548</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'LEFT OUTER JOIN'</tt> </tt>
</div><a name="L2549"></a><tt class="py-lineno">2549</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.RANDOM"></a><div id="IngresAdapter.RANDOM-def"><a name="L2550"></a><tt class="py-lineno">2550</tt> <a class="py-toggle" href="#" id="IngresAdapter.RANDOM-toggle" onclick="return toggle('IngresAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.RANDOM-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.RANDOM-expanded"><a name="L2551"></a><tt class="py-lineno">2551</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'RANDOM()'</tt> </tt>
</div><a name="L2552"></a><tt class="py-lineno">2552</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.select_limitby"></a><div id="IngresAdapter.select_limitby-def"><a name="L2553"></a><tt class="py-lineno">2553</tt> <a class="py-toggle" href="#" id="IngresAdapter.select_limitby-toggle" onclick="return toggle('IngresAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.select_limitby-expanded"><a name="L2554"></a><tt class="py-lineno">2554</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L2555"></a><tt class="py-lineno">2555</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L2556"></a><tt class="py-lineno">2556</tt>  <tt class="py-line">            <tt class="py-name">fetch_amt</tt> <tt class="py-op">=</tt> <tt class="py-name">lmax</tt> <tt class="py-op">-</tt> <tt class="py-name">lmin</tt> </tt>
<a name="L2557"></a><tt class="py-lineno">2557</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">fetch_amt</tt><tt class="py-op">:</tt> </tt>
<a name="L2558"></a><tt class="py-lineno">2558</tt>  <tt class="py-line">                <tt class="py-name">sql_s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' FIRST %d '</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">fetch_amt</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt> </tt>
<a name="L2559"></a><tt class="py-lineno">2559</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">lmin</tt><tt class="py-op">:</tt> </tt>
<a name="L2560"></a><tt class="py-lineno">2560</tt>  <tt class="py-line">                <tt class="py-comment"># Requires Ingres 9.2+</tt> </tt>
<a name="L2561"></a><tt class="py-lineno">2561</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-name">sql_o</tt> <tt class="py-op">+=</tt> <tt class="py-string">' OFFSET %d'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt> </tt>
<a name="L2562"></a><tt class="py-lineno">2562</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2563"></a><tt class="py-lineno">2563</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.__init__"></a><div id="IngresAdapter.__init__-def"><a name="L2564"></a><tt class="py-lineno">2564</tt> <a class="py-toggle" href="#" id="IngresAdapter.__init__-toggle" onclick="return toggle('IngresAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2565"></a><tt class="py-lineno">2565</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1035" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1035', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1036" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1036', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2566"></a><tt class="py-lineno">2566</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.__init__-expanded"><a name="L2567"></a><tt class="py-lineno">2567</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2568"></a><tt class="py-lineno">2568</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"ingres"</tt> </tt>
<a name="L2569"></a><tt class="py-lineno">2569</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2570"></a><tt class="py-lineno">2570</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2571"></a><tt class="py-lineno">2571</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2572"></a><tt class="py-lineno">2572</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2573"></a><tt class="py-lineno">2573</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1037" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-1037', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2574"></a><tt class="py-lineno">2574</tt>  <tt class="py-line">        <tt class="py-name">connstr</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">,</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2575"></a><tt class="py-lineno">2575</tt>  <tt class="py-line">        <tt class="py-comment"># Simple URI processing</tt> </tt>
<a name="L2576"></a><tt class="py-lineno">2576</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">connstr</tt> <tt class="py-op">=</tt> <tt class="py-name">connstr</tt><tt class="py-op">.</tt><tt class="py-name">lstrip</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2577"></a><tt class="py-lineno">2577</tt>  <tt class="py-line">        <tt class="py-keyword">while</tt> <tt class="py-name">connstr</tt><tt class="py-op">.</tt><tt id="link-1038" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1038', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'/'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2578"></a><tt class="py-lineno">2578</tt>  <tt class="py-line">            <tt class="py-name">connstr</tt> <tt class="py-op">=</tt> <tt class="py-name">connstr</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L2579"></a><tt class="py-lineno">2579</tt>  <tt class="py-line">        <tt class="py-name">database_name</tt><tt class="py-op">=</tt><tt class="py-name">connstr</tt> <tt class="py-comment"># Assume only (local) dbname is passed in</tt> </tt>
<a name="L2580"></a><tt class="py-lineno">2580</tt>  <tt class="py-line">        <tt class="py-name">vnode</tt> <tt class="py-op">=</tt> <tt class="py-string">'(local)'</tt> </tt>
<a name="L2581"></a><tt class="py-lineno">2581</tt>  <tt class="py-line">        <tt class="py-name">servertype</tt> <tt class="py-op">=</tt> <tt class="py-string">'ingres'</tt> </tt>
<a name="L2582"></a><tt class="py-lineno">2582</tt>  <tt class="py-line">        <tt class="py-name">trace</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> <tt class="py-comment"># No tracing</tt> </tt>
<a name="L2583"></a><tt class="py-lineno">2583</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">.</tt><tt id="link-1039" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-1039', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">database</tt><tt class="py-op">=</tt><tt class="py-name">database_name</tt><tt class="py-op">,</tt> </tt>
<a name="L2584"></a><tt class="py-lineno">2584</tt>  <tt class="py-line">                                   <tt class="py-name">vnode</tt><tt class="py-op">=</tt><tt class="py-name">vnode</tt><tt class="py-op">,</tt> </tt>
<a name="L2585"></a><tt class="py-lineno">2585</tt>  <tt class="py-line">                                   <tt class="py-name">servertype</tt><tt class="py-op">=</tt><tt class="py-name">servertype</tt><tt class="py-op">,</tt> </tt>
<a name="L2586"></a><tt class="py-lineno">2586</tt>  <tt class="py-line">                                   <tt class="py-name">trace</tt><tt class="py-op">=</tt><tt class="py-name">trace</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2587"></a><tt class="py-lineno">2587</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2588"></a><tt class="py-lineno">2588</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1040" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1040', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-1041" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1041', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2589"></a><tt class="py-lineno">2589</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1042" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1042', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1043" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1043', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2590"></a><tt class="py-lineno">2590</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2591"></a><tt class="py-lineno">2591</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.create_sequence_and_triggers"></a><div id="IngresAdapter.create_sequence_and_triggers-def"><a name="L2592"></a><tt class="py-lineno">2592</tt> <a class="py-toggle" href="#" id="IngresAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('IngresAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.create_sequence_and_triggers-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.create_sequence_and_triggers-expanded"><a name="L2593"></a><tt class="py-lineno">2593</tt>  <tt class="py-line">        <tt class="py-comment"># post create table auto inc code (if needed)</tt> </tt>
<a name="L2594"></a><tt class="py-lineno">2594</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment"># modify table to btree for performance....</tt> </tt>
<a name="L2595"></a><tt class="py-lineno">2595</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-comment"># Older Ingres releases could use rule/trigger like Oracle above.</tt> </tt>
<a name="L2596"></a><tt class="py-lineno">2596</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2597"></a><tt class="py-lineno">2597</tt>  <tt class="py-line">            <tt class="py-name">modify_tbl_sql</tt> <tt class="py-op">=</tt> <tt class="py-string">'modify %s to btree unique on %s'</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L2598"></a><tt class="py-lineno">2598</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L2599"></a><tt class="py-lineno">2599</tt>  <tt class="py-line">                 <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-1044" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1044', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">"'%s'"</tt> <tt class="py-op">%</tt> <tt id="link-1045" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1045', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">for</tt> <tt id="link-1046" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1046', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">primarykey</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2600"></a><tt class="py-lineno">2600</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1047" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1047', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">modify_tbl_sql</tt><tt class="py-op">)</tt> </tt>
<a name="L2601"></a><tt class="py-lineno">2601</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2602"></a><tt class="py-lineno">2602</tt>  <tt class="py-line">            <tt class="py-name">tmp_seqname</tt><tt class="py-op">=</tt><tt class="py-string">'%s_iisq'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L2603"></a><tt class="py-lineno">2603</tt>  <tt class="py-line">            <tt class="py-name">query</tt><tt class="py-op">=</tt><tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt id="link-1048" class="py-name"><a title="web2py.gluon.dal.INGRES_SEQNAME" class="py-name" href="#" onclick="return doclink('link-1048', 'INGRES_SEQNAME', 'link-1029');">INGRES_SEQNAME</a></tt><tt class="py-op">,</tt> <tt class="py-name">tmp_seqname</tt><tt class="py-op">)</tt> </tt>
<a name="L2604"></a><tt class="py-lineno">2604</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1049" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1049', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'create sequence %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">tmp_seqname</tt><tt class="py-op">)</tt> </tt>
<a name="L2605"></a><tt class="py-lineno">2605</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1050" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1050', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L2606"></a><tt class="py-lineno">2606</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1051" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1051', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'modify %s to btree unique on %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-string">'id'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2607"></a><tt class="py-lineno">2607</tt>  <tt class="py-line"> </tt>
<a name="L2608"></a><tt class="py-lineno">2608</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.lastrowid"></a><div id="IngresAdapter.lastrowid-def"><a name="L2609"></a><tt class="py-lineno">2609</tt> <a class="py-toggle" href="#" id="IngresAdapter.lastrowid-toggle" onclick="return toggle('IngresAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.lastrowid-expanded"><a name="L2610"></a><tt class="py-lineno">2610</tt>  <tt class="py-line">        <tt class="py-name">tmp_seqname</tt><tt class="py-op">=</tt><tt class="py-string">'%s_iisq'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt> </tt>
<a name="L2611"></a><tt class="py-lineno">2611</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1052" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1052', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'select current value for %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">tmp_seqname</tt><tt class="py-op">)</tt> </tt>
<a name="L2612"></a><tt class="py-lineno">2612</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-comment"># don't really need int type cast here...</tt> </tt>
</div><a name="L2613"></a><tt class="py-lineno">2613</tt>  <tt class="py-line"> </tt>
<a name="IngresAdapter.integrity_error_class"></a><div id="IngresAdapter.integrity_error_class-def"><a name="L2614"></a><tt class="py-lineno">2614</tt> <a class="py-toggle" href="#" id="IngresAdapter.integrity_error_class-toggle" onclick="return toggle('IngresAdapter.integrity_error_class');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresAdapter-class.html#integrity_error_class">integrity_error_class</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresAdapter.integrity_error_class-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="IngresAdapter.integrity_error_class-expanded"><a name="L2615"></a><tt class="py-lineno">2615</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">ingresdbi</tt><tt class="py-op">.</tt><tt id="link-1053" class="py-name"><a title="psycopg2.IntegrityError
web2py.gluon.contrib.pymysql.err.IntegrityError" class="py-name" href="#" onclick="return doclink('link-1053', 'IntegrityError', 'link-167');">IntegrityError</a></tt> </tt>
</div></div><a name="L2616"></a><tt class="py-lineno">2616</tt>  <tt class="py-line"> </tt>
<a name="L2617"></a><tt class="py-lineno">2617</tt>  <tt class="py-line"> </tt>
<a name="IngresUnicodeAdapter"></a><div id="IngresUnicodeAdapter-def"><a name="L2618"></a><tt class="py-lineno">2618</tt> <a class="py-toggle" href="#" id="IngresUnicodeAdapter-toggle" onclick="return toggle('IngresUnicodeAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.IngresUnicodeAdapter-class.html">IngresUnicodeAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">IngresAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="IngresUnicodeAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="IngresUnicodeAdapter-expanded"><a name="L2619"></a><tt class="py-lineno">2619</tt>  <tt class="py-line">    <tt id="link-1054" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1054', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2620"></a><tt class="py-lineno">2620</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2621"></a><tt class="py-lineno">2621</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'NVARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2622"></a><tt class="py-lineno">2622</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'NCLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2623"></a><tt class="py-lineno">2623</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'NVARCHAR(%(length)s)'</tt><tt class="py-op">,</tt>  <tt class="py-comment">## Not sure what this contains utf8 or nvarchar. Or even bytes?</tt> </tt>
<a name="L2624"></a><tt class="py-lineno">2624</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'BLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2625"></a><tt class="py-lineno">2625</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt>  <tt class="py-comment">## FIXME utf8 or nvarchar... or blob? what is this type?</tt> </tt>
<a name="L2626"></a><tt class="py-lineno">2626</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INTEGER4'</tt><tt class="py-op">,</tt> <tt class="py-comment"># or int8...</tt> </tt>
<a name="L2627"></a><tt class="py-lineno">2627</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2628"></a><tt class="py-lineno">2628</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'NUMERIC(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2629"></a><tt class="py-lineno">2629</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'ANSIDATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2630"></a><tt class="py-lineno">2630</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME WITHOUT TIME ZONE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2631"></a><tt class="py-lineno">2631</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP WITHOUT TIME ZONE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2632"></a><tt class="py-lineno">2632</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'integer4 not null unique with default next value for %s'</tt><tt class="py-op">%</tt> <tt id="link-1055" class="py-name"><a title="web2py.gluon.dal.INGRES_SEQNAME" class="py-name" href="#" onclick="return doclink('link-1055', 'INGRES_SEQNAME', 'link-1029');">INGRES_SEQNAME</a></tt><tt class="py-op">,</tt> </tt>
<a name="L2633"></a><tt class="py-lineno">2633</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'integer4, FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2634"></a><tt class="py-lineno">2634</tt>  <tt class="py-line">        <tt class="py-string">'reference FK'</tt><tt class="py-op">:</tt> <tt class="py-string">', CONSTRAINT FK_%(constraint_name)s FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2635"></a><tt class="py-lineno">2635</tt>  <tt class="py-line">        <tt class="py-string">'reference TFK'</tt><tt class="py-op">:</tt> <tt class="py-string">' CONSTRAINT FK_%(foreign_table)s_PK FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_table)s (%(foreign_key)s) ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> <tt class="py-comment">## FIXME TODO</tt> </tt>
<a name="L2636"></a><tt class="py-lineno">2636</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'NCLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2637"></a><tt class="py-lineno">2637</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'NCLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2638"></a><tt class="py-lineno">2638</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'NCLOB'</tt><tt class="py-op">,</tt> </tt>
<a name="L2639"></a><tt class="py-lineno">2639</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
</div><a name="L2640"></a><tt class="py-lineno">2640</tt>  <tt class="py-line"> </tt>
<a name="SAPDBAdapter"></a><div id="SAPDBAdapter-def"><a name="L2641"></a><tt class="py-lineno">2641</tt> <a class="py-toggle" href="#" id="SAPDBAdapter-toggle" onclick="return toggle('SAPDBAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.SAPDBAdapter-class.html">SAPDBAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SAPDBAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="SAPDBAdapter-expanded"><a name="L2642"></a><tt class="py-lineno">2642</tt>  <tt class="py-line"> </tt>
<a name="L2643"></a><tt class="py-lineno">2643</tt>  <tt class="py-line">    <tt id="link-1056" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1056', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-1057" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-1057', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1058" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1058', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'sapdb'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2644"></a><tt class="py-lineno">2644</tt>  <tt class="py-line">    <tt id="link-1059" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-1059', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L2645"></a><tt class="py-lineno">2645</tt>  <tt class="py-line">    <tt id="link-1060" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1060', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L2646"></a><tt class="py-lineno">2646</tt>  <tt class="py-line">        <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-string">'CHAR(1)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2647"></a><tt class="py-lineno">2647</tt>  <tt class="py-line">        <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2648"></a><tt class="py-lineno">2648</tt>  <tt class="py-line">        <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONG'</tt><tt class="py-op">,</tt> </tt>
<a name="L2649"></a><tt class="py-lineno">2649</tt>  <tt class="py-line">        <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2650"></a><tt class="py-lineno">2650</tt>  <tt class="py-line">        <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONG'</tt><tt class="py-op">,</tt> </tt>
<a name="L2651"></a><tt class="py-lineno">2651</tt>  <tt class="py-line">        <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-string">'VARCHAR(%(length)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2652"></a><tt class="py-lineno">2652</tt>  <tt class="py-line">        <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2653"></a><tt class="py-lineno">2653</tt>  <tt class="py-line">        <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-string">'FLOAT'</tt><tt class="py-op">,</tt> </tt>
<a name="L2654"></a><tt class="py-lineno">2654</tt>  <tt class="py-line">        <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt class="py-string">'FIXED(%(precision)s,%(scale)s)'</tt><tt class="py-op">,</tt> </tt>
<a name="L2655"></a><tt class="py-lineno">2655</tt>  <tt class="py-line">        <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-string">'DATE'</tt><tt class="py-op">,</tt> </tt>
<a name="L2656"></a><tt class="py-lineno">2656</tt>  <tt class="py-line">        <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIME'</tt><tt class="py-op">,</tt> </tt>
<a name="L2657"></a><tt class="py-lineno">2657</tt>  <tt class="py-line">        <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-string">'TIMESTAMP'</tt><tt class="py-op">,</tt> </tt>
<a name="L2658"></a><tt class="py-lineno">2658</tt>  <tt class="py-line">        <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT PRIMARY KEY'</tt><tt class="py-op">,</tt> </tt>
<a name="L2659"></a><tt class="py-lineno">2659</tt>  <tt class="py-line">        <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'INT, FOREIGN KEY (%(field_name)s) REFERENCES %(foreign_key)s ON DELETE %(on_delete_action)s'</tt><tt class="py-op">,</tt> </tt>
<a name="L2660"></a><tt class="py-lineno">2660</tt>  <tt class="py-line">        <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONG'</tt><tt class="py-op">,</tt> </tt>
<a name="L2661"></a><tt class="py-lineno">2661</tt>  <tt class="py-line">        <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONG'</tt><tt class="py-op">,</tt> </tt>
<a name="L2662"></a><tt class="py-lineno">2662</tt>  <tt class="py-line">        <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-string">'LONG'</tt><tt class="py-op">,</tt> </tt>
<a name="L2663"></a><tt class="py-lineno">2663</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L2664"></a><tt class="py-lineno">2664</tt>  <tt class="py-line"> </tt>
<a name="SAPDBAdapter.sequence_name"></a><div id="SAPDBAdapter.sequence_name-def"><a name="L2665"></a><tt class="py-lineno">2665</tt> <a class="py-toggle" href="#" id="SAPDBAdapter.sequence_name-toggle" onclick="return toggle('SAPDBAdapter.sequence_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SAPDBAdapter-class.html#sequence_name">sequence_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SAPDBAdapter.sequence_name-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SAPDBAdapter.sequence_name-expanded"><a name="L2666"></a><tt class="py-lineno">2666</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s_id_Seq'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt> </tt>
</div><a name="L2667"></a><tt class="py-lineno">2667</tt>  <tt class="py-line"> </tt>
<a name="SAPDBAdapter.select_limitby"></a><div id="SAPDBAdapter.select_limitby-def"><a name="L2668"></a><tt class="py-lineno">2668</tt> <a class="py-toggle" href="#" id="SAPDBAdapter.select_limitby-toggle" onclick="return toggle('SAPDBAdapter.select_limitby');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SAPDBAdapter-class.html#select_limitby">select_limitby</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">sql_s</tt><tt class="py-op">,</tt> <tt class="py-param">sql_f</tt><tt class="py-op">,</tt> <tt class="py-param">sql_t</tt><tt class="py-op">,</tt> <tt class="py-param">sql_w</tt><tt class="py-op">,</tt> <tt class="py-param">sql_o</tt><tt class="py-op">,</tt> <tt class="py-param">limitby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SAPDBAdapter.select_limitby-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SAPDBAdapter.select_limitby-expanded"><a name="L2669"></a><tt class="py-lineno">2669</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">limitby</tt><tt class="py-op">:</tt> </tt>
<a name="L2670"></a><tt class="py-lineno">2670</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">limitby</tt> </tt>
<a name="L2671"></a><tt class="py-lineno">2671</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-1061" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1061', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">sql_w</tt><tt class="py-op">)</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
<a name="L2672"></a><tt class="py-lineno">2672</tt>  <tt class="py-line">                <tt class="py-name">sql_w_row</tt> <tt class="py-op">=</tt> <tt class="py-name">sql_w</tt> <tt class="py-op">+</tt> <tt class="py-string">' AND w_row &gt; %i'</tt> <tt class="py-op">%</tt> <tt class="py-name">lmin</tt> </tt>
<a name="L2673"></a><tt class="py-lineno">2673</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2674"></a><tt class="py-lineno">2674</tt>  <tt class="py-line">                <tt class="py-name">sql_w_row</tt> <tt class="py-op">=</tt> <tt class="py-string">'WHERE w_row &gt; %i'</tt> <tt class="py-op">%</tt> <tt class="py-name">lmin</tt> </tt>
<a name="L2675"></a><tt class="py-lineno">2675</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'%s %s FROM (SELECT w_tmp.*, ROWNO w_row FROM (SELECT %s FROM %s%s%s) w_tmp WHERE ROWNO=%i) %s %s %s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w_row</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
<a name="L2676"></a><tt class="py-lineno">2676</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'SELECT %s %s FROM %s%s%s;'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">sql_s</tt><tt class="py-op">,</tt> <tt class="py-name">sql_f</tt><tt class="py-op">,</tt> <tt class="py-name">sql_t</tt><tt class="py-op">,</tt> <tt class="py-name">sql_w</tt><tt class="py-op">,</tt> <tt class="py-name">sql_o</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2677"></a><tt class="py-lineno">2677</tt>  <tt class="py-line"> </tt>
<a name="SAPDBAdapter.create_sequence_and_triggers"></a><div id="SAPDBAdapter.create_sequence_and_triggers-def"><a name="L2678"></a><tt class="py-lineno">2678</tt> <a class="py-toggle" href="#" id="SAPDBAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('SAPDBAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SAPDBAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SAPDBAdapter.create_sequence_and_triggers-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SAPDBAdapter.create_sequence_and_triggers-expanded"><a name="L2679"></a><tt class="py-lineno">2679</tt>  <tt class="py-line">        <tt class="py-comment"># following lines should only be executed if table._sequence_name does not exist</tt> </tt>
<a name="L2680"></a><tt class="py-lineno">2680</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1062" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1062', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'CREATE SEQUENCE %s;'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt><tt class="py-op">)</tt> </tt>
<a name="L2681"></a><tt class="py-lineno">2681</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1063" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1063', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"ALTER TABLE %s ALTER COLUMN %s SET DEFAULT NEXTVAL('%s');"</tt> \ </tt>
<a name="L2682"></a><tt class="py-lineno">2682</tt>  <tt class="py-line">                         <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-1064" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1064', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2683"></a><tt class="py-lineno">2683</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1065" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1065', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2684"></a><tt class="py-lineno">2684</tt>  <tt class="py-line"> </tt>
<a name="SAPDBAdapter.__init__"></a><div id="SAPDBAdapter.__init__-def"><a name="L2685"></a><tt class="py-lineno">2685</tt> <a class="py-toggle" href="#" id="SAPDBAdapter.__init__-toggle" onclick="return toggle('SAPDBAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SAPDBAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2686"></a><tt class="py-lineno">2686</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1066" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1066', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1067" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1067', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2687"></a><tt class="py-lineno">2687</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SAPDBAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SAPDBAdapter.__init__-expanded"><a name="L2688"></a><tt class="py-lineno">2688</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2689"></a><tt class="py-lineno">2689</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"sapdb"</tt> </tt>
<a name="L2690"></a><tt class="py-lineno">2690</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2691"></a><tt class="py-lineno">2691</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2692"></a><tt class="py-lineno">2692</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2693"></a><tt class="py-lineno">2693</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2694"></a><tt class="py-lineno">2694</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1068" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-1068', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2695"></a><tt class="py-lineno">2695</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2696"></a><tt class="py-lineno">2696</tt>  <tt class="py-line">        <tt id="link-1069" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1069', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:@/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;[^\?]+)(\?sslmode=(?P&lt;sslmode&gt;.+))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2697"></a><tt class="py-lineno">2697</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1070" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1070', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2698"></a><tt class="py-lineno">2698</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Invalid URI string in DAL"</tt> </tt>
<a name="L2699"></a><tt class="py-lineno">2699</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-1071" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1071', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2700"></a><tt class="py-lineno">2700</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L2701"></a><tt class="py-lineno">2701</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L2702"></a><tt class="py-lineno">2702</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-1072" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1072', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2703"></a><tt class="py-lineno">2703</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L2704"></a><tt class="py-lineno">2704</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2705"></a><tt class="py-lineno">2705</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-1073" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1073', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L2706"></a><tt class="py-lineno">2706</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L2707"></a><tt class="py-lineno">2707</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L2708"></a><tt class="py-lineno">2708</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-1074" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1074', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L2709"></a><tt class="py-lineno">2709</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L2710"></a><tt class="py-lineno">2710</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L2711"></a><tt class="py-lineno">2711</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">user</tt><tt class="py-op">=</tt><tt class="py-name">user</tt><tt class="py-op">,</tt><tt class="py-param">password</tt><tt class="py-op">=</tt><tt class="py-name">password</tt><tt class="py-op">,</tt><tt class="py-param">database</tt><tt class="py-op">=</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> </tt>
<a name="L2712"></a><tt class="py-lineno">2712</tt>  <tt class="py-line">                    <tt class="py-param">host</tt><tt class="py-op">=</tt><tt class="py-name">host</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2713"></a><tt class="py-lineno">2713</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1075" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1075', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-1076" class="py-name"><a title="web2py.gluon.rocket.Connection" class="py-name" href="#" onclick="return doclink('link-1076', 'Connection', 'link-695');">Connection</a></tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">,</tt><tt class="py-name">password</tt><tt class="py-op">,</tt><tt class="py-name">database</tt><tt class="py-op">,</tt> </tt>
<a name="L2714"></a><tt class="py-lineno">2714</tt>  <tt class="py-line">                                          <tt class="py-name">host</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2715"></a><tt class="py-lineno">2715</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1077" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1077', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1078" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1078', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2716"></a><tt class="py-lineno">2716</tt>  <tt class="py-line">        <tt class="py-comment"># self.connection.set_client_encoding('UTF8')</tt> </tt>
<a name="L2717"></a><tt class="py-lineno">2717</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2718"></a><tt class="py-lineno">2718</tt>  <tt class="py-line"> </tt>
<a name="SAPDBAdapter.lastrowid"></a><div id="SAPDBAdapter.lastrowid-def"><a name="L2719"></a><tt class="py-lineno">2719</tt> <a class="py-toggle" href="#" id="SAPDBAdapter.lastrowid-toggle" onclick="return toggle('SAPDBAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SAPDBAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SAPDBAdapter.lastrowid-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SAPDBAdapter.lastrowid-expanded"><a name="L2720"></a><tt class="py-lineno">2720</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1079" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1079', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"select %s.NEXTVAL from dual"</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt><tt class="py-op">)</tt> </tt>
<a name="L2721"></a><tt class="py-lineno">2721</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchone</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2722"></a><tt class="py-lineno">2722</tt>  <tt class="py-line"> </tt>
<a name="CubridAdapter"></a><div id="CubridAdapter-def"><a name="L2723"></a><tt class="py-lineno">2723</tt> <a class="py-toggle" href="#" id="CubridAdapter-toggle" onclick="return toggle('CubridAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.CubridAdapter-class.html">CubridAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">MySQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CubridAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="CubridAdapter-expanded"><a name="L2724"></a><tt class="py-lineno">2724</tt>  <tt class="py-line"> </tt>
<a name="L2725"></a><tt class="py-lineno">2725</tt>  <tt class="py-line">    <tt id="link-1080" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1080', 'driver', 'link-159');">driver</a></tt> <tt class="py-op">=</tt> <tt id="link-1081" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-1081', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1082" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1082', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'cubriddb'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L2726"></a><tt class="py-lineno">2726</tt>  <tt class="py-line"> </tt>
<a name="CubridAdapter.__init__"></a><div id="CubridAdapter.__init__-def"><a name="L2727"></a><tt class="py-lineno">2727</tt> <a class="py-toggle" href="#" id="CubridAdapter.__init__-toggle" onclick="return toggle('CubridAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CubridAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L2728"></a><tt class="py-lineno">2728</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1083" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1083', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1084" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1084', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2729"></a><tt class="py-lineno">2729</tt>  <tt class="py-line">                 <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CubridAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CubridAdapter.__init__-expanded"><a name="L2730"></a><tt class="py-lineno">2730</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2731"></a><tt class="py-lineno">2731</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"cubrid"</tt> </tt>
<a name="L2732"></a><tt class="py-lineno">2732</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2733"></a><tt class="py-lineno">2733</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2734"></a><tt class="py-lineno">2734</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2735"></a><tt class="py-lineno">2735</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2736"></a><tt class="py-lineno">2736</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1085" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.find_or_make_work_folder" class="py-name" href="#" onclick="return doclink('link-1085', 'find_or_make_work_folder', 'link-689');">find_or_make_work_folder</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2737"></a><tt class="py-lineno">2737</tt>  <tt class="py-line">        <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'://'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2738"></a><tt class="py-lineno">2738</tt>  <tt class="py-line">        <tt id="link-1086" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1086', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;user&gt;[^:@]+)(\:(?P&lt;password&gt;[^@]*))?@(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;[^?]+)(\?set_encoding=(?P&lt;charset&gt;\w+))?$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L2739"></a><tt class="py-lineno">2739</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1087" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1087', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2740"></a><tt class="py-lineno">2740</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L2741"></a><tt class="py-lineno">2741</tt>  <tt class="py-line">                <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> </tt>
<a name="L2742"></a><tt class="py-lineno">2742</tt>  <tt class="py-line">        <tt class="py-name">user</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-1088" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1088', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'user'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2743"></a><tt class="py-lineno">2743</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">user</tt><tt class="py-op">:</tt> </tt>
<a name="L2744"></a><tt class="py-lineno">2744</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'User required'</tt> </tt>
<a name="L2745"></a><tt class="py-lineno">2745</tt>  <tt class="py-line">        <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-1089" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1089', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'password'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2746"></a><tt class="py-lineno">2746</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">password</tt><tt class="py-op">:</tt> </tt>
<a name="L2747"></a><tt class="py-lineno">2747</tt>  <tt class="py-line">            <tt class="py-name">password</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2748"></a><tt class="py-lineno">2748</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-1090" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1090', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L2749"></a><tt class="py-lineno">2749</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L2750"></a><tt class="py-lineno">2750</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Host name required'</tt> </tt>
<a name="L2751"></a><tt class="py-lineno">2751</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt id="link-1091" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1091', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L2752"></a><tt class="py-lineno">2752</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">:</tt> </tt>
<a name="L2753"></a><tt class="py-lineno">2753</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Database name required'</tt> </tt>
<a name="L2754"></a><tt class="py-lineno">2754</tt>  <tt class="py-line">        <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt id="link-1092" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1092', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'30000'</tt><tt class="py-op">)</tt> </tt>
<a name="L2755"></a><tt class="py-lineno">2755</tt>  <tt class="py-line">        <tt class="py-name">charset</tt> <tt class="py-op">=</tt> <tt id="link-1093" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1093', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'charset'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'utf8'</tt> </tt>
<a name="L2756"></a><tt class="py-lineno">2756</tt>  <tt class="py-line">        <tt class="py-name">user</tt><tt class="py-op">=</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">user</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2757"></a><tt class="py-lineno">2757</tt>  <tt class="py-line">        <tt class="py-name">passwd</tt><tt class="py-op">=</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt class="py-name">password</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2758"></a><tt class="py-lineno">2758</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">host</tt><tt class="py-op">,</tt><tt class="py-param">port</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">user</tt><tt class="py-op">,</tt><tt class="py-param">passwd</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2759"></a><tt class="py-lineno">2759</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1094" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.driver
web2py.gluon.dal.CubridAdapter.driver
web2py.gluon.dal.DB2Adapter.driver
web2py.gluon.dal.FireBirdAdapter.driver
web2py.gluon.dal.InformixAdapter.driver
web2py.gluon.dal.IngresAdapter.driver
web2py.gluon.dal.JDBCSQLiteAdapter.driver
web2py.gluon.dal.MSSQLAdapter.driver
web2py.gluon.dal.OracleAdapter.driver
web2py.gluon.dal.SAPDBAdapter.driver
web2py.gluon.dal.TeradataAdapter.driver" class="py-name" href="#" onclick="return doclink('link-1094', 'driver', 'link-159');">driver</a></tt><tt class="py-op">.</tt><tt id="link-1095" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1095', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-name">host</tt><tt class="py-op">,</tt><tt class="py-name">port</tt><tt class="py-op">,</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">user</tt><tt class="py-op">,</tt><tt class="py-name">passwd</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2760"></a><tt class="py-lineno">2760</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1096" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1096', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1097" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1097', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2761"></a><tt class="py-lineno">2761</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2762"></a><tt class="py-lineno">2762</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1098" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1098', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'SET FOREIGN_KEY_CHECKS=1;'</tt><tt class="py-op">)</tt> </tt>
<a name="L2763"></a><tt class="py-lineno">2763</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1099" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1099', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET sql_mode='NO_BACKSLASH_ESCAPES';"</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2764"></a><tt class="py-lineno">2764</tt>  <tt class="py-line"> </tt>
<a name="L2765"></a><tt class="py-lineno">2765</tt>  <tt class="py-line"> </tt>
<a name="L2766"></a><tt class="py-lineno">2766</tt>  <tt class="py-line"><tt class="py-comment">######## GAE MySQL ##########</tt> </tt>
<a name="L2767"></a><tt class="py-lineno">2767</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="DatabaseStoredFile"></a><div id="DatabaseStoredFile-def"><a name="L2768"></a><tt class="py-lineno">2768</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile-toggle" onclick="return toggle('DatabaseStoredFile');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html">DatabaseStoredFile</a><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="DatabaseStoredFile-expanded"><a name="L2769"></a><tt class="py-lineno">2769</tt>  <tt class="py-line"> </tt>
<a name="L2770"></a><tt class="py-lineno">2770</tt>  <tt class="py-line">    <tt id="link-1100" class="py-name" targets="Variable web2py.gluon.dal.DatabaseStoredFile.web2py_filesystem=web2py.gluon.dal.DatabaseStoredFile-class.html#web2py_filesystem"><a title="web2py.gluon.dal.DatabaseStoredFile.web2py_filesystem" class="py-name" href="#" onclick="return doclink('link-1100', 'web2py_filesystem', 'link-1100');">web2py_filesystem</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L2771"></a><tt class="py-lineno">2771</tt>  <tt class="py-line"> </tt>
<a name="DatabaseStoredFile.__init__"></a><div id="DatabaseStoredFile.__init__-def"><a name="L2772"></a><tt class="py-lineno">2772</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile.__init__-toggle" onclick="return toggle('DatabaseStoredFile.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">filename</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DatabaseStoredFile.__init__-expanded"><a name="L2773"></a><tt class="py-lineno">2773</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">!=</tt> <tt class="py-string">'mysql'</tt><tt class="py-op">:</tt> </tt>
<a name="L2774"></a><tt class="py-lineno">2774</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"only MySQL can store metadata .table files in database for now"</tt> </tt>
<a name="L2775"></a><tt class="py-lineno">2775</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2776"></a><tt class="py-lineno">2776</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt class="py-name">filename</tt> </tt>
<a name="L2777"></a><tt class="py-lineno">2777</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">mode</tt> <tt class="py-op">=</tt> <tt class="py-name">mode</tt> </tt>
<a name="L2778"></a><tt class="py-lineno">2778</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1101" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.web2py_filesystem" class="py-name" href="#" onclick="return doclink('link-1101', 'web2py_filesystem', 'link-1100');">web2py_filesystem</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2779"></a><tt class="py-lineno">2779</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1102" class="py-name" targets="Method web2py.gluon.dal.DAL.executesql()=web2py.gluon.dal.DAL-class.html#executesql"><a title="web2py.gluon.dal.DAL.executesql" class="py-name" href="#" onclick="return doclink('link-1102', 'executesql', 'link-1102');">executesql</a></tt><tt class="py-op">(</tt><tt class="py-string">"CREATE TABLE IF NOT EXISTS web2py_filesystem (path VARCHAR(512), content LONGTEXT, PRIMARY KEY(path) ) ENGINE=InnoDB;"</tt><tt class="py-op">)</tt> </tt>
<a name="L2780"></a><tt class="py-lineno">2780</tt>  <tt class="py-line">            <tt id="link-1103" class="py-name" targets="Class web2py.gluon.dal.DatabaseStoredFile=web2py.gluon.dal.DatabaseStoredFile-class.html"><a title="web2py.gluon.dal.DatabaseStoredFile" class="py-name" href="#" onclick="return doclink('link-1103', 'DatabaseStoredFile', 'link-1103');">DatabaseStoredFile</a></tt><tt class="py-op">.</tt><tt id="link-1104" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.web2py_filesystem" class="py-name" href="#" onclick="return doclink('link-1104', 'web2py_filesystem', 'link-1100');">web2py_filesystem</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L2781"></a><tt class="py-lineno">2781</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt><tt class="py-op">=</tt><tt class="py-number">0</tt> </tt>
<a name="L2782"></a><tt class="py-lineno">2782</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L2783"></a><tt class="py-lineno">2783</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">mode</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'r'</tt><tt class="py-op">,</tt><tt class="py-string">'rw'</tt><tt class="py-op">,</tt><tt class="py-string">'a'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2784"></a><tt class="py-lineno">2784</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-string">"SELECT content FROM web2py_filesystem WHERE path='%s'"</tt> <tt class="py-op">%</tt> <tt class="py-name">filename</tt> </tt>
<a name="L2785"></a><tt class="py-lineno">2785</tt>  <tt class="py-line">            <tt id="link-1105" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1105', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1106" class="py-name"><a title="web2py.gluon.dal.DAL.executesql" class="py-name" href="#" onclick="return doclink('link-1106', 'executesql', 'link-1102');">executesql</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L2786"></a><tt class="py-lineno">2786</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-1107" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1107', 'rows', 'link-539');">rows</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2787"></a><tt class="py-lineno">2787</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt id="link-1108" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1108', 'rows', 'link-539');">rows</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L2788"></a><tt class="py-lineno">2788</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-1109" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-1109', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2789"></a><tt class="py-lineno">2789</tt>  <tt class="py-line">                <tt class="py-name">datafile</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-string">'r'</tt><tt class="py-op">)</tt> </tt>
<a name="L2790"></a><tt class="py-lineno">2790</tt>  <tt class="py-line">                <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L2791"></a><tt class="py-lineno">2791</tt>  <tt class="py-line">                    <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt class="py-name">datafile</tt><tt class="py-op">.</tt><tt id="link-1110" class="py-name" targets="Method web2py.gluon.dal.DatabaseStoredFile.read()=web2py.gluon.dal.DatabaseStoredFile-class.html#read,Method web2py.gluon.debug.Pipe.read()=web2py.gluon.debug.Pipe-class.html#read,Method web2py.gluon.languages.lazyT.read()=web2py.gluon.languages.lazyT-class.html#read,Method web2py.gluon.rocket.ChunkedReader.read()=web2py.gluon.rocket.ChunkedReader-class.html#read,Method web2py.gluon.tools.Crud.read()=web2py.gluon.tools.Crud-class.html#read"><a title="web2py.gluon.dal.DatabaseStoredFile.read
web2py.gluon.debug.Pipe.read
web2py.gluon.languages.lazyT.read
web2py.gluon.rocket.ChunkedReader.read
web2py.gluon.tools.Crud.read" class="py-name" href="#" onclick="return doclink('link-1110', 'read', 'link-1110');">read</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2792"></a><tt class="py-lineno">2792</tt>  <tt class="py-line">                <tt class="py-keyword">finally</tt><tt class="py-op">:</tt> </tt>
<a name="L2793"></a><tt class="py-lineno">2793</tt>  <tt class="py-line">                    <tt class="py-name">datafile</tt><tt class="py-op">.</tt><tt id="link-1111" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-1111', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2794"></a><tt class="py-lineno">2794</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">mode</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'r'</tt><tt class="py-op">,</tt><tt class="py-string">'rw'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2795"></a><tt class="py-lineno">2795</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"File %s does not exist"</tt> <tt class="py-op">%</tt> <tt class="py-name">filename</tt> </tt>
</div><a name="L2796"></a><tt class="py-lineno">2796</tt>  <tt class="py-line"> </tt>
<a name="DatabaseStoredFile.read"></a><div id="DatabaseStoredFile.read-def"><a name="L2797"></a><tt class="py-lineno">2797</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile.read-toggle" onclick="return toggle('DatabaseStoredFile.read');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html#read">read</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">bytes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile.read-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DatabaseStoredFile.read-expanded"><a name="L2798"></a><tt class="py-lineno">2798</tt>  <tt class="py-line">        <tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt><tt class="py-op">:</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt><tt class="py-op">+</tt><tt class="py-name">bytes</tt><tt class="py-op">]</tt> </tt>
<a name="L2799"></a><tt class="py-lineno">2799</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt> <tt class="py-op">+=</tt> <tt id="link-1112" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1112', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt> </tt>
<a name="L2800"></a><tt class="py-lineno">2800</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">data</tt> </tt>
</div><a name="L2801"></a><tt class="py-lineno">2801</tt>  <tt class="py-line"> </tt>
<a name="DatabaseStoredFile.readline"></a><div id="DatabaseStoredFile.readline-def"><a name="L2802"></a><tt class="py-lineno">2802</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile.readline-toggle" onclick="return toggle('DatabaseStoredFile.readline');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html#readline">readline</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile.readline-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DatabaseStoredFile.readline-expanded"><a name="L2803"></a><tt class="py-lineno">2803</tt>  <tt class="py-line">        <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt><tt class="py-op">.</tt><tt id="link-1113" class="py-name"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-1113', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'\n'</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-number">1</tt> </tt>
<a name="L2804"></a><tt class="py-lineno">2804</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">i</tt><tt class="py-op">&gt;</tt><tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L2805"></a><tt class="py-lineno">2805</tt>  <tt class="py-line">            <tt class="py-name">data</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt><tt class="py-op">:</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt> </tt>
<a name="L2806"></a><tt class="py-lineno">2806</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2807"></a><tt class="py-lineno">2807</tt>  <tt class="py-line">            <tt class="py-name">data</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">p</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt id="link-1114" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1114', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt><tt class="py-op">)</tt> </tt>
<a name="L2808"></a><tt class="py-lineno">2808</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">data</tt> </tt>
</div><a name="L2809"></a><tt class="py-lineno">2809</tt>  <tt class="py-line"> </tt>
<a name="DatabaseStoredFile.write"></a><div id="DatabaseStoredFile.write-def"><a name="L2810"></a><tt class="py-lineno">2810</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile.write-toggle" onclick="return toggle('DatabaseStoredFile.write');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html#write">write</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile.write-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DatabaseStoredFile.write-expanded"><a name="L2811"></a><tt class="py-lineno">2811</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt> <tt class="py-op">+=</tt> <tt class="py-name">data</tt> </tt>
</div><a name="L2812"></a><tt class="py-lineno">2812</tt>  <tt class="py-line"> </tt>
<a name="DatabaseStoredFile.close"></a><div id="DatabaseStoredFile.close-def"><a name="L2813"></a><tt class="py-lineno">2813</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile.close-toggle" onclick="return toggle('DatabaseStoredFile.close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html#close">close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile.close-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DatabaseStoredFile.close-expanded"><a name="L2814"></a><tt class="py-lineno">2814</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1115" class="py-name"><a title="web2py.gluon.dal.DAL.executesql" class="py-name" href="#" onclick="return doclink('link-1115', 'executesql', 'link-1102');">executesql</a></tt><tt class="py-op">(</tt><tt class="py-string">"DELETE FROM web2py_filesystem WHERE path='%s'"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt> </tt>
<a name="L2815"></a><tt class="py-lineno">2815</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-string">"INSERT INTO web2py_filesystem(path,content) VALUES ('%s','%s')"</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L2816"></a><tt class="py-lineno">2816</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">data</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">"'"</tt><tt class="py-op">,</tt><tt class="py-string">"''"</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2817"></a><tt class="py-lineno">2817</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1116" class="py-name"><a title="web2py.gluon.dal.DAL.executesql" class="py-name" href="#" onclick="return doclink('link-1116', 'executesql', 'link-1102');">executesql</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L2818"></a><tt class="py-lineno">2818</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1117" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-1117', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2819"></a><tt class="py-lineno">2819</tt>  <tt class="py-line"> </tt>
<a name="L2820"></a><tt class="py-lineno">2820</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="DatabaseStoredFile.exists"></a><div id="DatabaseStoredFile.exists-def"><a name="L2821"></a><tt class="py-lineno">2821</tt> <a class="py-toggle" href="#" id="DatabaseStoredFile.exists-toggle" onclick="return toggle('DatabaseStoredFile.exists');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DatabaseStoredFile-class.html#exists">exists</a><tt class="py-op">(</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DatabaseStoredFile.exists-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DatabaseStoredFile.exists-expanded"><a name="L2822"></a><tt class="py-lineno">2822</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-1118" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-1118', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2823"></a><tt class="py-lineno">2823</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">True</tt> </tt>
<a name="L2824"></a><tt class="py-lineno">2824</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-string">"SELECT path FROM web2py_filesystem WHERE path='%s'"</tt> <tt class="py-op">%</tt> <tt class="py-name">filename</tt> </tt>
<a name="L2825"></a><tt class="py-lineno">2825</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1119" class="py-name"><a title="web2py.gluon.dal.DAL.executesql" class="py-name" href="#" onclick="return doclink('link-1119', 'executesql', 'link-1102');">executesql</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2826"></a><tt class="py-lineno">2826</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">True</tt> </tt>
<a name="L2827"></a><tt class="py-lineno">2827</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt>
</div></div><a name="L2828"></a><tt class="py-lineno">2828</tt>  <tt class="py-line"> </tt>
<a name="L2829"></a><tt class="py-lineno">2829</tt>  <tt class="py-line"> </tt>
<a name="UseDatabaseStoredFile"></a><div id="UseDatabaseStoredFile-def"><a name="L2830"></a><tt class="py-lineno">2830</tt> <a class="py-toggle" href="#" id="UseDatabaseStoredFile-toggle" onclick="return toggle('UseDatabaseStoredFile');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.UseDatabaseStoredFile-class.html">UseDatabaseStoredFile</a><tt class="py-op">:</tt> </tt>
</div><div id="UseDatabaseStoredFile-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="UseDatabaseStoredFile-expanded"><a name="L2831"></a><tt class="py-lineno">2831</tt>  <tt class="py-line"> </tt>
<a name="UseDatabaseStoredFile.file_exists"></a><div id="UseDatabaseStoredFile.file_exists-def"><a name="L2832"></a><tt class="py-lineno">2832</tt> <a class="py-toggle" href="#" id="UseDatabaseStoredFile.file_exists-toggle" onclick="return toggle('UseDatabaseStoredFile.file_exists');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_exists">file_exists</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="UseDatabaseStoredFile.file_exists-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="UseDatabaseStoredFile.file_exists-expanded"><a name="L2833"></a><tt class="py-lineno">2833</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1120" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile" class="py-name" href="#" onclick="return doclink('link-1120', 'DatabaseStoredFile', 'link-1103');">DatabaseStoredFile</a></tt><tt class="py-op">.</tt><tt id="link-1121" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-1121', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2834"></a><tt class="py-lineno">2834</tt>  <tt class="py-line"> </tt>
<a name="UseDatabaseStoredFile.file_open"></a><div id="UseDatabaseStoredFile.file_open-def"><a name="L2835"></a><tt class="py-lineno">2835</tt> <a class="py-toggle" href="#" id="UseDatabaseStoredFile.file_open-toggle" onclick="return toggle('UseDatabaseStoredFile.file_open');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_open">file_open</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt><tt class="py-op">=</tt><tt class="py-string">'rb'</tt><tt class="py-op">,</tt> <tt class="py-param">lock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="UseDatabaseStoredFile.file_open-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="UseDatabaseStoredFile.file_open-expanded"><a name="L2836"></a><tt class="py-lineno">2836</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1122" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile" class="py-name" href="#" onclick="return doclink('link-1122', 'DatabaseStoredFile', 'link-1103');">DatabaseStoredFile</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt><tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2837"></a><tt class="py-lineno">2837</tt>  <tt class="py-line"> </tt>
<a name="UseDatabaseStoredFile.file_close"></a><div id="UseDatabaseStoredFile.file_close-def"><a name="L2838"></a><tt class="py-lineno">2838</tt> <a class="py-toggle" href="#" id="UseDatabaseStoredFile.file_close-toggle" onclick="return toggle('UseDatabaseStoredFile.file_close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_close">file_close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">fileobj</tt><tt class="py-op">,</tt> <tt class="py-param">unlock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="UseDatabaseStoredFile.file_close-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="UseDatabaseStoredFile.file_close-expanded"><a name="L2839"></a><tt class="py-lineno">2839</tt>  <tt class="py-line">        <tt class="py-name">fileobj</tt><tt class="py-op">.</tt><tt id="link-1123" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-1123', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2840"></a><tt class="py-lineno">2840</tt>  <tt class="py-line"> </tt>
<a name="UseDatabaseStoredFile.file_delete"></a><div id="UseDatabaseStoredFile.file_delete-def"><a name="L2841"></a><tt class="py-lineno">2841</tt> <a class="py-toggle" href="#" id="UseDatabaseStoredFile.file_delete-toggle" onclick="return toggle('UseDatabaseStoredFile.file_delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.UseDatabaseStoredFile-class.html#file_delete">file_delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="UseDatabaseStoredFile.file_delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="UseDatabaseStoredFile.file_delete-expanded"><a name="L2842"></a><tt class="py-lineno">2842</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-string">"DELETE FROM web2py_filesystem WHERE path='%s'"</tt> <tt class="py-op">%</tt> <tt class="py-name">filename</tt> </tt>
<a name="L2843"></a><tt class="py-lineno">2843</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1124" class="py-name"><a title="web2py.gluon.dal.DAL.executesql" class="py-name" href="#" onclick="return doclink('link-1124', 'executesql', 'link-1102');">executesql</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L2844"></a><tt class="py-lineno">2844</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1125" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-1125', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2845"></a><tt class="py-lineno">2845</tt>  <tt class="py-line"> </tt>
<a name="GoogleSQLAdapter"></a><div id="GoogleSQLAdapter-def"><a name="L2846"></a><tt class="py-lineno">2846</tt> <a class="py-toggle" href="#" id="GoogleSQLAdapter-toggle" onclick="return toggle('GoogleSQLAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleSQLAdapter-class.html">GoogleSQLAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">UseDatabaseStoredFile</tt><tt class="py-op">,</tt><tt class="py-base-class">MySQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleSQLAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="GoogleSQLAdapter-expanded"><a name="L2847"></a><tt class="py-lineno">2847</tt>  <tt class="py-line"> </tt>
<a name="GoogleSQLAdapter.__init__"></a><div id="GoogleSQLAdapter.__init__-def"><a name="L2848"></a><tt class="py-lineno">2848</tt> <a class="py-toggle" href="#" id="GoogleSQLAdapter.__init__-toggle" onclick="return toggle('GoogleSQLAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleSQLAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">db</tt><tt class="py-op">,</tt> <tt class="py-param">uri</tt><tt class="py-op">=</tt><tt class="py-string">'google:sql://realm:domain/database'</tt><tt class="py-op">,</tt> <tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> </tt>
<a name="L2849"></a><tt class="py-lineno">2849</tt>  <tt class="py-line">                 <tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-param">db_codec</tt><tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> <tt class="py-param">check_reserved</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L2850"></a><tt class="py-lineno">2850</tt>  <tt class="py-line">                 <tt class="py-param">migrate</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L2851"></a><tt class="py-lineno">2851</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt> <tt class="py-op">=</tt> <tt class="py-keyword">lambda</tt> <tt id="link-1126" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1126', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1127" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1127', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L2852"></a><tt class="py-lineno">2852</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleSQLAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleSQLAdapter.__init__-expanded"><a name="L2853"></a><tt class="py-lineno">2853</tt>  <tt class="py-line"> </tt>
<a name="L2854"></a><tt class="py-lineno">2854</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2855"></a><tt class="py-lineno">2855</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">"mysql"</tt> </tt>
<a name="L2856"></a><tt class="py-lineno">2856</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L2857"></a><tt class="py-lineno">2857</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L2858"></a><tt class="py-lineno">2858</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L2859"></a><tt class="py-lineno">2859</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L2860"></a><tt class="py-lineno">2860</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'$HOME/'</tt><tt class="py-op">+</tt><tt id="link-1128" class="py-name"><a title="web2py.gluon.dal.thread
web2py.gluon.rewrite.thread" class="py-name" href="#" onclick="return doclink('link-1128', 'thread', 'link-27');">thread</a></tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'/applications/'</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L2861"></a><tt class="py-lineno">2861</tt>  <tt class="py-line"> </tt>
<a name="L2862"></a><tt class="py-lineno">2862</tt>  <tt class="py-line">        <tt id="link-1129" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1129', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;instance&gt;.*)/(?P&lt;db&gt;.*)$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">[</tt><tt id="link-1130" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1130', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-string">'google:sql://'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L2863"></a><tt class="py-lineno">2863</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1131" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1131', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L2864"></a><tt class="py-lineno">2864</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Invalid URI string in SQLDB: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri</tt> </tt>
<a name="L2865"></a><tt class="py-lineno">2865</tt>  <tt class="py-line">        <tt class="py-name">instance</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-1132" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1132', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'instance'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2866"></a><tt class="py-lineno">2866</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">credential_decoder</tt><tt class="py-op">(</tt><tt id="link-1133" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1133', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2867"></a><tt class="py-lineno">2867</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">[</tt><tt class="py-string">'instance'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">instance</tt> </tt>
<a name="L2868"></a><tt class="py-lineno">2868</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L2869"></a><tt class="py-lineno">2869</tt>  <tt class="py-line">            <tt class="py-name">driver_args</tt><tt class="py-op">[</tt><tt class="py-string">'database'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L2870"></a><tt class="py-lineno">2870</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2871"></a><tt class="py-lineno">2871</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">rdbms</tt><tt class="py-op">.</tt><tt id="link-1134" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1134', 'connect', 'link-697');">connect</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2872"></a><tt class="py-lineno">2872</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1135" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1135', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1136" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1136', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2873"></a><tt class="py-lineno">2873</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2874"></a><tt class="py-lineno">2874</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L2875"></a><tt class="py-lineno">2875</tt>  <tt class="py-line">            <tt class="py-comment"># self.execute('DROP DATABASE %s' % db)</tt> </tt>
<a name="L2876"></a><tt class="py-lineno">2876</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1137" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1137', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'CREATE DATABASE IF NOT EXISTS %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> </tt>
<a name="L2877"></a><tt class="py-lineno">2877</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1138" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1138', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">'USE %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> </tt>
<a name="L2878"></a><tt class="py-lineno">2878</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1139" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1139', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET FOREIGN_KEY_CHECKS=1;"</tt><tt class="py-op">)</tt> </tt>
<a name="L2879"></a><tt class="py-lineno">2879</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1140" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1140', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-string">"SET sql_mode='NO_BACKSLASH_ESCAPES';"</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L2880"></a><tt class="py-lineno">2880</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter"></a><div id="NoSQLAdapter-def"><a name="L2881"></a><tt class="py-lineno">2881</tt> <a class="py-toggle" href="#" id="NoSQLAdapter-toggle" onclick="return toggle('NoSQLAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html">NoSQLAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">BaseAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="NoSQLAdapter-expanded"><a name="L2882"></a><tt class="py-lineno">2882</tt>  <tt class="py-line"> </tt>
<a name="L2883"></a><tt class="py-lineno">2883</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="NoSQLAdapter.to_unicode"></a><div id="NoSQLAdapter.to_unicode-def"><a name="L2884"></a><tt class="py-lineno">2884</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.to_unicode-toggle" onclick="return toggle('NoSQLAdapter.to_unicode');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#to_unicode">to_unicode</a><tt class="py-op">(</tt><tt class="py-param">obj</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter.to_unicode-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter.to_unicode-expanded"><a name="L2885"></a><tt class="py-lineno">2885</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2886"></a><tt class="py-lineno">2886</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-1141" class="py-name"><a title="web2py.gluon.languages.lazyT.decode" class="py-name" href="#" onclick="return doclink('link-1141', 'decode', 'link-237');">decode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt> </tt>
<a name="L2887"></a><tt class="py-lineno">2887</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-name">unicode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2888"></a><tt class="py-lineno">2888</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">unicode</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2889"></a><tt class="py-lineno">2889</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">obj</tt> </tt>
</div><a name="L2890"></a><tt class="py-lineno">2890</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter.represent"></a><div id="NoSQLAdapter.represent-def"><a name="L2891"></a><tt class="py-lineno">2891</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.represent-toggle" onclick="return toggle('NoSQLAdapter.represent');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#represent">represent</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter.represent-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter.represent-expanded"><a name="L2892"></a><tt class="py-lineno">2892</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt><tt id="link-1142" class="py-name"><a title="web2py.gluon.dal.CALLABLETYPES" class="py-name" href="#" onclick="return doclink('link-1142', 'CALLABLETYPES', 'link-7');">CALLABLETYPES</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2893"></a><tt class="py-lineno">2893</tt>  <tt class="py-line">            <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L2894"></a><tt class="py-lineno">2894</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">fieldtype</tt><tt class="py-op">,</tt> <tt id="link-1143" class="py-name"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-1143', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2895"></a><tt class="py-lineno">2895</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt class="py-name">encoder</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2896"></a><tt class="py-lineno">2896</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-1144" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-1144', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">,</tt> <tt id="link-1145" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-1145', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2897"></a><tt class="py-lineno">2897</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"non supported on GAE"</tt> </tt>
<a name="L2898"></a><tt class="py-lineno">2898</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'google:datastore'</tt> <tt class="py-keyword">in</tt> <tt id="link-1146" class="py-name"><a title="web2py.gluon.globals" class="py-name" href="#" onclick="return doclink('link-1146', 'globals', 'link-683');">globals</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2899"></a><tt class="py-lineno">2899</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">fieldtype</tt><tt class="py-op">,</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">Property</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2900"></a><tt class="py-lineno">2900</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">obj</tt> </tt>
<a name="L2901"></a><tt class="py-lineno">2901</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-1147" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1147', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2902"></a><tt class="py-lineno">2902</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">obj</tt><tt class="py-op">:</tt> </tt>
<a name="L2903"></a><tt class="py-lineno">2903</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L2904"></a><tt class="py-lineno">2904</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2905"></a><tt class="py-lineno">2905</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">obj</tt><tt class="py-op">]</tt> </tt>
<a name="L2906"></a><tt class="py-lineno">2906</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-op">==</tt> <tt class="py-string">''</tt> <tt class="py-keyword">and</tt>  <tt class="py-keyword">not</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-op">[</tt><tt class="py-string">'st'</tt><tt class="py-op">,</tt><tt class="py-string">'te'</tt><tt class="py-op">,</tt><tt class="py-string">'pa'</tt><tt class="py-op">,</tt><tt class="py-string">'up'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L2907"></a><tt class="py-lineno">2907</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L2908"></a><tt class="py-lineno">2908</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-op">!=</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L2909"></a><tt class="py-lineno">2909</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-name">list</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-1148" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1148', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2910"></a><tt class="py-lineno">2910</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1149" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1149', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">o</tt><tt class="py-op">,</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">o</tt> <tt class="py-keyword">in</tt> <tt class="py-name">obj</tt><tt class="py-op">]</tt> </tt>
<a name="L2911"></a><tt class="py-lineno">2911</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'integer'</tt><tt class="py-op">,</tt><tt class="py-string">'id'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2912"></a><tt class="py-lineno">2912</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2913"></a><tt class="py-lineno">2913</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'double'</tt><tt class="py-op">:</tt> </tt>
<a name="L2914"></a><tt class="py-lineno">2914</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">float</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2915"></a><tt class="py-lineno">2915</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-1150" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1150', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2916"></a><tt class="py-lineno">2916</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-1151" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1151', 'Row', 'link-600');">Row</a></tt><tt class="py-op">,</tt> <tt id="link-1152" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-1152', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2917"></a><tt class="py-lineno">2917</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">obj</tt><tt class="py-op">[</tt><tt class="py-string">'id'</tt><tt class="py-op">]</tt> </tt>
<a name="L2918"></a><tt class="py-lineno">2918</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2919"></a><tt class="py-lineno">2919</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> </tt>
<a name="L2920"></a><tt class="py-lineno">2920</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">obj</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1153" class="py-name"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-1153', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-string">'F'</tt><tt class="py-op">:</tt> </tt>
<a name="L2921"></a><tt class="py-lineno">2921</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L2922"></a><tt class="py-lineno">2922</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2923"></a><tt class="py-lineno">2923</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L2924"></a><tt class="py-lineno">2924</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'date'</tt><tt class="py-op">:</tt> </tt>
<a name="L2925"></a><tt class="py-lineno">2925</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-1154" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1154', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1155" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1155', 'date', 'link-604');">date</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2926"></a><tt class="py-lineno">2926</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-1156" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1156', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1157" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1157', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2927"></a><tt class="py-lineno">2927</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt id="link-1158" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1158', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1159" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1159', 'date', 'link-604');">date</a></tt><tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-1160" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1160', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> </tt>
<a name="L2928"></a><tt class="py-lineno">2928</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt><tt id="link-1161" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1161', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1162" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1162', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2929"></a><tt class="py-lineno">2929</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-1163" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1163', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-1164" class="py-name" targets="Method web2py.gluon.dal.Expression.year()=web2py.gluon.dal.Expression-class.html#year"><a title="web2py.gluon.dal.Expression.year" class="py-name" href="#" onclick="return doclink('link-1164', 'year', 'link-1164');">year</a></tt><tt class="py-op">,</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-1165" class="py-name" targets="Method web2py.gluon.dal.Expression.month()=web2py.gluon.dal.Expression-class.html#month"><a title="web2py.gluon.dal.Expression.month" class="py-name" href="#" onclick="return doclink('link-1165', 'month', 'link-1165');">month</a></tt><tt class="py-op">,</tt> <tt class="py-name">obj</tt><tt class="py-op">.</tt><tt id="link-1166" class="py-name" targets="Method web2py.gluon.dal.Expression.day()=web2py.gluon.dal.Expression-class.html#day"><a title="web2py.gluon.dal.Expression.day" class="py-name" href="#" onclick="return doclink('link-1166', 'day', 'link-1166');">day</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2930"></a><tt class="py-lineno">2930</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt id="link-1167" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1167', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1168" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1168', 'date', 'link-604');">date</a></tt><tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-1169" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1169', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> </tt>
<a name="L2931"></a><tt class="py-lineno">2931</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'time'</tt><tt class="py-op">:</tt> </tt>
<a name="L2932"></a><tt class="py-lineno">2932</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-1170" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1170', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1171" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-1171', 'time', 'link-4');">time</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2933"></a><tt class="py-lineno">2933</tt>  <tt class="py-line">                    <tt class="py-name">time_items</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1172" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1172', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">3</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L2934"></a><tt class="py-lineno">2934</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt id="link-1173" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1173', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">time_items</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">3</tt><tt class="py-op">:</tt> </tt>
<a name="L2935"></a><tt class="py-lineno">2935</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-1174" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-1174', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> </tt>
<a name="L2936"></a><tt class="py-lineno">2936</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2937"></a><tt class="py-lineno">2937</tt>  <tt class="py-line">                        <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-1175" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-1175', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> <tt class="py-op">+</tt> <tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L2938"></a><tt class="py-lineno">2938</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt id="link-1176" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1176', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1177" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-1177', 'time', 'link-4');">time</a></tt><tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-1178" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-1178', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2939"></a><tt class="py-lineno">2939</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> </tt>
<a name="L2940"></a><tt class="py-lineno">2940</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt id="link-1179" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1179', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1180" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1180', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2941"></a><tt class="py-lineno">2941</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-1181" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1181', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1182" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1182', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L2942"></a><tt class="py-lineno">2942</tt>  <tt class="py-line">                    <tt class="py-name">time_items</tt> <tt class="py-op">=</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">11</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1183" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1183', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">3</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L2943"></a><tt class="py-lineno">2943</tt>  <tt class="py-line">                    <tt class="py-keyword">while</tt> <tt id="link-1184" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1184', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">time_items</tt><tt class="py-op">)</tt><tt class="py-op">&lt;</tt><tt class="py-number">3</tt><tt class="py-op">:</tt> </tt>
<a name="L2944"></a><tt class="py-lineno">2944</tt>  <tt class="py-line">                        <tt class="py-name">time_items</tt><tt class="py-op">.</tt><tt id="link-1185" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1185', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">)</tt> </tt>
<a name="L2945"></a><tt class="py-lineno">2945</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-1186" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-1186', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">time_items</tt> </tt>
<a name="L2946"></a><tt class="py-lineno">2946</tt>  <tt class="py-line">                    <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt id="link-1187" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1187', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1188" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1188', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">,</tt> <tt id="link-1189" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1189', 'm', 'link-638');">m</a></tt><tt class="py-op">,</tt> <tt class="py-name">d</tt><tt class="py-op">,</tt> <tt class="py-name">h</tt><tt class="py-op">,</tt> <tt class="py-name">mi</tt><tt class="py-op">,</tt> <tt id="link-1190" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-1190', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> </tt>
<a name="L2947"></a><tt class="py-lineno">2947</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt> <tt class="py-op">==</tt> <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> </tt>
<a name="L2948"></a><tt class="py-lineno">2948</tt>  <tt class="py-line">                <tt class="py-keyword">pass</tt> </tt>
<a name="L2949"></a><tt class="py-lineno">2949</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-1191" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1191', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:string'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2950"></a><tt class="py-lineno">2950</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1192" class="py-name" targets="Static Method web2py.gluon.dal.NoSQLAdapter.to_unicode()=web2py.gluon.dal.NoSQLAdapter-class.html#to_unicode"><a title="web2py.gluon.dal.NoSQLAdapter.to_unicode" class="py-name" href="#" onclick="return doclink('link-1192', 'to_unicode', 'link-1192');">to_unicode</a></tt><tt class="py-op">,</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2951"></a><tt class="py-lineno">2951</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">.</tt><tt id="link-1193" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1193', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L2952"></a><tt class="py-lineno">2952</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">map</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2953"></a><tt class="py-lineno">2953</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L2954"></a><tt class="py-lineno">2954</tt>  <tt class="py-line">                <tt class="py-name">obj</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1194" class="py-name"><a title="web2py.gluon.dal.NoSQLAdapter.to_unicode" class="py-name" href="#" onclick="return doclink('link-1194', 'to_unicode', 'link-1192');">to_unicode</a></tt><tt class="py-op">(</tt><tt class="py-name">obj</tt><tt class="py-op">)</tt> </tt>
<a name="L2955"></a><tt class="py-lineno">2955</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">obj</tt> </tt>
</div><a name="L2956"></a><tt class="py-lineno">2956</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter._insert"></a><div id="NoSQLAdapter._insert-def"><a name="L2957"></a><tt class="py-lineno">2957</tt> <a class="py-toggle" href="#" id="NoSQLAdapter._insert-toggle" onclick="return toggle('NoSQLAdapter._insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#_insert">_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter._insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter._insert-expanded"><a name="L2958"></a><tt class="py-lineno">2958</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'insert %s in %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt> <tt class="py-name">table</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2959"></a><tt class="py-lineno">2959</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter._count"></a><div id="NoSQLAdapter._count-def"><a name="L2960"></a><tt class="py-lineno">2960</tt> <a class="py-toggle" href="#" id="NoSQLAdapter._count-toggle" onclick="return toggle('NoSQLAdapter._count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#_count">_count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter._count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter._count-expanded"><a name="L2961"></a><tt class="py-lineno">2961</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'count %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2962"></a><tt class="py-lineno">2962</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter._select"></a><div id="NoSQLAdapter._select-def"><a name="L2963"></a><tt class="py-lineno">2963</tt> <a class="py-toggle" href="#" id="NoSQLAdapter._select-toggle" onclick="return toggle('NoSQLAdapter._select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#_select">_select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter._select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter._select-expanded"><a name="L2964"></a><tt class="py-lineno">2964</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'select %s where %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2965"></a><tt class="py-lineno">2965</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter._delete"></a><div id="NoSQLAdapter._delete-def"><a name="L2966"></a><tt class="py-lineno">2966</tt> <a class="py-toggle" href="#" id="NoSQLAdapter._delete-toggle" onclick="return toggle('NoSQLAdapter._delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#_delete">_delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter._delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter._delete-expanded"><a name="L2967"></a><tt class="py-lineno">2967</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'delete %s where %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2968"></a><tt class="py-lineno">2968</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter._update"></a><div id="NoSQLAdapter._update-def"><a name="L2969"></a><tt class="py-lineno">2969</tt> <a class="py-toggle" href="#" id="NoSQLAdapter._update-toggle" onclick="return toggle('NoSQLAdapter._update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#_update">_update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter._update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter._update-expanded"><a name="L2970"></a><tt class="py-lineno">2970</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'update %s (%s) where %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L2971"></a><tt class="py-lineno">2971</tt>  <tt class="py-line">                                            <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L2972"></a><tt class="py-lineno">2972</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter.commit"></a><div id="NoSQLAdapter.commit-def"><a name="L2973"></a><tt class="py-lineno">2973</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.commit-toggle" onclick="return toggle('NoSQLAdapter.commit');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#commit">commit</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter.commit-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter.commit-expanded"><a name="L2974"></a><tt class="py-lineno">2974</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L2975"></a><tt class="py-lineno">2975</tt>  <tt class="py-line"><tt class="py-docstring">        remember: no transactions on many NoSQL</tt> </tt>
<a name="L2976"></a><tt class="py-lineno">2976</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L2977"></a><tt class="py-lineno">2977</tt>  <tt class="py-line">        <tt class="py-keyword">pass</tt> </tt>
</div><a name="L2978"></a><tt class="py-lineno">2978</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter.rollback"></a><div id="NoSQLAdapter.rollback-def"><a name="L2979"></a><tt class="py-lineno">2979</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.rollback-toggle" onclick="return toggle('NoSQLAdapter.rollback');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#rollback">rollback</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter.rollback-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter.rollback-expanded"><a name="L2980"></a><tt class="py-lineno">2980</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L2981"></a><tt class="py-lineno">2981</tt>  <tt class="py-line"><tt class="py-docstring">        remember: no transactions on many NoSQL</tt> </tt>
<a name="L2982"></a><tt class="py-lineno">2982</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L2983"></a><tt class="py-lineno">2983</tt>  <tt class="py-line">        <tt class="py-keyword">pass</tt> </tt>
</div><a name="L2984"></a><tt class="py-lineno">2984</tt>  <tt class="py-line"> </tt>
<a name="NoSQLAdapter.close"></a><div id="NoSQLAdapter.close-def"><a name="L2985"></a><tt class="py-lineno">2985</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.close-toggle" onclick="return toggle('NoSQLAdapter.close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#close">close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="NoSQLAdapter.close-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="NoSQLAdapter.close-expanded"><a name="L2986"></a><tt class="py-lineno">2986</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L2987"></a><tt class="py-lineno">2987</tt>  <tt class="py-line"><tt class="py-docstring">        remember: no transactions on many NoSQL</tt> </tt>
<a name="L2988"></a><tt class="py-lineno">2988</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L2989"></a><tt class="py-lineno">2989</tt>  <tt class="py-line">        <tt class="py-keyword">pass</tt> </tt>
</div><a name="L2990"></a><tt class="py-lineno">2990</tt>  <tt class="py-line"> </tt>
<a name="L2991"></a><tt class="py-lineno">2991</tt>  <tt class="py-line"> </tt>
<a name="L2992"></a><tt class="py-lineno">2992</tt>  <tt class="py-line">    <tt class="py-comment"># these functions should never be called!</tt> </tt>
<a name="NoSQLAdapter.OR"></a><div id="NoSQLAdapter.OR-def"><a name="L2993"></a><tt class="py-lineno">2993</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.OR-toggle" onclick="return toggle('NoSQLAdapter.OR');">-</a><tt class="py-line"><tt class="py-comment"></tt>    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#OR">OR</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.AND"></a><div id="NoSQLAdapter.AND-def"><a name="L2994"></a><tt class="py-lineno">2994</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.AND-toggle" onclick="return toggle('NoSQLAdapter.AND');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#AND">AND</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.AS"></a><div id="NoSQLAdapter.AS-def"><a name="L2995"></a><tt class="py-lineno">2995</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.AS-toggle" onclick="return toggle('NoSQLAdapter.AS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#AS">AS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.ON"></a><div id="NoSQLAdapter.ON-def"><a name="L2996"></a><tt class="py-lineno">2996</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.ON-toggle" onclick="return toggle('NoSQLAdapter.ON');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#ON">ON</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.STARTSWITH"></a><div id="NoSQLAdapter.STARTSWITH-def"><a name="L2997"></a><tt class="py-lineno">2997</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.STARTSWITH-toggle" onclick="return toggle('NoSQLAdapter.STARTSWITH');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#STARTSWITH">STARTSWITH</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.ENDSWITH"></a><div id="NoSQLAdapter.ENDSWITH-def"><a name="L2998"></a><tt class="py-lineno">2998</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.ENDSWITH-toggle" onclick="return toggle('NoSQLAdapter.ENDSWITH');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#ENDSWITH">ENDSWITH</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.ADD"></a><div id="NoSQLAdapter.ADD-def"><a name="L2999"></a><tt class="py-lineno">2999</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.ADD-toggle" onclick="return toggle('NoSQLAdapter.ADD');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#ADD">ADD</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.SUB"></a><div id="NoSQLAdapter.SUB-def"><a name="L3000"></a><tt class="py-lineno">3000</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.SUB-toggle" onclick="return toggle('NoSQLAdapter.SUB');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#SUB">SUB</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.MUL"></a><div id="NoSQLAdapter.MUL-def"><a name="L3001"></a><tt class="py-lineno">3001</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.MUL-toggle" onclick="return toggle('NoSQLAdapter.MUL');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#MUL">MUL</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.DIV"></a><div id="NoSQLAdapter.DIV-def"><a name="L3002"></a><tt class="py-lineno">3002</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.DIV-toggle" onclick="return toggle('NoSQLAdapter.DIV');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#DIV">DIV</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.LOWER"></a><div id="NoSQLAdapter.LOWER-def"><a name="L3003"></a><tt class="py-lineno">3003</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.LOWER-toggle" onclick="return toggle('NoSQLAdapter.LOWER');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#LOWER">LOWER</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.UPPER"></a><div id="NoSQLAdapter.UPPER-def"><a name="L3004"></a><tt class="py-lineno">3004</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.UPPER-toggle" onclick="return toggle('NoSQLAdapter.UPPER');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#UPPER">UPPER</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.EXTRACT"></a><div id="NoSQLAdapter.EXTRACT-def"><a name="L3005"></a><tt class="py-lineno">3005</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.EXTRACT-toggle" onclick="return toggle('NoSQLAdapter.EXTRACT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#EXTRACT">EXTRACT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">what</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.AGGREGATE"></a><div id="NoSQLAdapter.AGGREGATE-def"><a name="L3006"></a><tt class="py-lineno">3006</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.AGGREGATE-toggle" onclick="return toggle('NoSQLAdapter.AGGREGATE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#AGGREGATE">AGGREGATE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">what</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.LEFT_JOIN"></a><div id="NoSQLAdapter.LEFT_JOIN-def"><a name="L3007"></a><tt class="py-lineno">3007</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.LEFT_JOIN-toggle" onclick="return toggle('NoSQLAdapter.LEFT_JOIN');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#LEFT_JOIN">LEFT_JOIN</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.RANDOM"></a><div id="NoSQLAdapter.RANDOM-def"><a name="L3008"></a><tt class="py-lineno">3008</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.RANDOM-toggle" onclick="return toggle('NoSQLAdapter.RANDOM');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#RANDOM">RANDOM</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.SUBSTRING"></a><div id="NoSQLAdapter.SUBSTRING-def"><a name="L3009"></a><tt class="py-lineno">3009</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.SUBSTRING-toggle" onclick="return toggle('NoSQLAdapter.SUBSTRING');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#SUBSTRING">SUBSTRING</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">field</tt><tt class="py-op">,</tt><tt class="py-param">parameters</tt><tt class="py-op">)</tt><tt class="py-op">:</tt>  <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.PRIMARY_KEY"></a><div id="NoSQLAdapter.PRIMARY_KEY-def"><a name="L3010"></a><tt class="py-lineno">3010</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.PRIMARY_KEY-toggle" onclick="return toggle('NoSQLAdapter.PRIMARY_KEY');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#PRIMARY_KEY">PRIMARY_KEY</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt>  <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.LIKE"></a><div id="NoSQLAdapter.LIKE-def"><a name="L3011"></a><tt class="py-lineno">3011</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.LIKE-toggle" onclick="return toggle('NoSQLAdapter.LIKE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#LIKE">LIKE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.drop"></a><div id="NoSQLAdapter.drop-def"><a name="L3012"></a><tt class="py-lineno">3012</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.drop-toggle" onclick="return toggle('NoSQLAdapter.drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#drop">drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt>  <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.alias"></a><div id="NoSQLAdapter.alias-def"><a name="L3013"></a><tt class="py-lineno">3013</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.alias-toggle" onclick="return toggle('NoSQLAdapter.alias');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#alias">alias</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">alias</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.migrate_table"></a><div id="NoSQLAdapter.migrate_table-def"><a name="L3014"></a><tt class="py-lineno">3014</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.migrate_table-toggle" onclick="return toggle('NoSQLAdapter.migrate_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#migrate_table">migrate_table</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-param">a</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">b</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.distributed_transaction_begin"></a><div id="NoSQLAdapter.distributed_transaction_begin-def"><a name="L3015"></a><tt class="py-lineno">3015</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.distributed_transaction_begin-toggle" onclick="return toggle('NoSQLAdapter.distributed_transaction_begin');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#distributed_transaction_begin">distributed_transaction_begin</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.prepare"></a><div id="NoSQLAdapter.prepare-def"><a name="L3016"></a><tt class="py-lineno">3016</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.prepare-toggle" onclick="return toggle('NoSQLAdapter.prepare');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#prepare">prepare</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.commit_prepared"></a><div id="NoSQLAdapter.commit_prepared-def"><a name="L3017"></a><tt class="py-lineno">3017</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.commit_prepared-toggle" onclick="return toggle('NoSQLAdapter.commit_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#commit_prepared">commit_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.rollback_prepared"></a><div id="NoSQLAdapter.rollback_prepared-def"><a name="L3018"></a><tt class="py-lineno">3018</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.rollback_prepared-toggle" onclick="return toggle('NoSQLAdapter.rollback_prepared');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#rollback_prepared">rollback_prepared</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.concat_add"></a><div id="NoSQLAdapter.concat_add-def"><a name="L3019"></a><tt class="py-lineno">3019</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.concat_add-toggle" onclick="return toggle('NoSQLAdapter.concat_add');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#concat_add">concat_add</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.constraint_name"></a><div id="NoSQLAdapter.constraint_name-def"><a name="L3020"></a><tt class="py-lineno">3020</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.constraint_name-toggle" onclick="return toggle('NoSQLAdapter.constraint_name');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#constraint_name">constraint_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-param">fieldname</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.create_sequence_and_triggers"></a><div id="NoSQLAdapter.create_sequence_and_triggers-def"><a name="L3021"></a><tt class="py-lineno">3021</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.create_sequence_and_triggers-toggle" onclick="return toggle('NoSQLAdapter.create_sequence_and_triggers');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#create_sequence_and_triggers">create_sequence_and_triggers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="NoSQLAdapter.log_execute"></a><div id="NoSQLAdapter.log_execute-def"><a name="L3022"></a><tt class="py-lineno">3022</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.log_execute-toggle" onclick="return toggle('NoSQLAdapter.log_execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#log_execute">log_execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-param">a</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">b</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.execute"></a><div id="NoSQLAdapter.execute-def"><a name="L3023"></a><tt class="py-lineno">3023</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.execute-toggle" onclick="return toggle('NoSQLAdapter.execute');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#execute">execute</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-param">a</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">b</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.represent_exceptions"></a><div id="NoSQLAdapter.represent_exceptions-def"><a name="L3024"></a><tt class="py-lineno">3024</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.represent_exceptions-toggle" onclick="return toggle('NoSQLAdapter.represent_exceptions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#represent_exceptions">represent_exceptions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.lastrowid"></a><div id="NoSQLAdapter.lastrowid-def"><a name="L3025"></a><tt class="py-lineno">3025</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.lastrowid-toggle" onclick="return toggle('NoSQLAdapter.lastrowid');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#lastrowid">lastrowid</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.integrity_error_class"></a><div id="NoSQLAdapter.integrity_error_class-def"><a name="L3026"></a><tt class="py-lineno">3026</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.integrity_error_class-toggle" onclick="return toggle('NoSQLAdapter.integrity_error_class');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#integrity_error_class">integrity_error_class</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div><a name="NoSQLAdapter.rowslice"></a><div id="NoSQLAdapter.rowslice-def"><a name="L3027"></a><tt class="py-lineno">3027</tt> <a class="py-toggle" href="#" id="NoSQLAdapter.rowslice-toggle" onclick="return toggle('NoSQLAdapter.rowslice');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.NoSQLAdapter-class.html#rowslice">rowslice</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">rows</tt><tt class="py-op">,</tt><tt class="py-param">minimum</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">maximum</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
</div></div><a name="L3028"></a><tt class="py-lineno">3028</tt>  <tt class="py-line"> </tt>
<a name="L3029"></a><tt class="py-lineno">3029</tt>  <tt class="py-line"> </tt>
<a name="GAEF"></a><div id="GAEF-def"><a name="L3030"></a><tt class="py-lineno">3030</tt> <a class="py-toggle" href="#" id="GAEF-toggle" onclick="return toggle('GAEF');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEF-class.html">GAEF</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEF-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="GAEF-expanded"><a name="GAEF.__init__"></a><div id="GAEF.__init__-def"><a name="L3031"></a><tt class="py-lineno">3031</tt> <a class="py-toggle" href="#" id="GAEF.__init__-toggle" onclick="return toggle('GAEF.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEF-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">name</tt><tt class="py-op">,</tt><tt class="py-param">op</tt><tt class="py-op">,</tt><tt class="py-param">value</tt><tt class="py-op">,</tt><tt class="py-param">apply</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEF.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GAEF.__init__-expanded"><a name="L3032"></a><tt class="py-lineno">3032</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1195" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1195', 'name', 'link-119');">name</a></tt><tt class="py-op">=</tt><tt id="link-1196" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1196', 'name', 'link-119');">name</a></tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">and</tt> <tt class="py-string">'__key__'</tt> <tt class="py-keyword">or</tt> <tt id="link-1197" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1197', 'name', 'link-119');">name</a></tt> </tt>
<a name="L3033"></a><tt class="py-lineno">3033</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">=</tt><tt class="py-name">op</tt> </tt>
<a name="L3034"></a><tt class="py-lineno">3034</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">=</tt><tt class="py-name">value</tt> </tt>
<a name="L3035"></a><tt class="py-lineno">3035</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">apply</tt><tt class="py-op">=</tt><tt class="py-name">apply</tt> </tt>
</div><a name="GAEF.__repr__"></a><div id="GAEF.__repr__-def"><a name="L3036"></a><tt class="py-lineno">3036</tt> <a class="py-toggle" href="#" id="GAEF.__repr__-toggle" onclick="return toggle('GAEF.__repr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GAEF-class.html#__repr__">__repr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GAEF.__repr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GAEF.__repr__-expanded"><a name="L3037"></a><tt class="py-lineno">3037</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s %s %s:%s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1198" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1198', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">,</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L3038"></a><tt class="py-lineno">3038</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter"></a><div id="GoogleDatastoreAdapter-def"><a name="L3039"></a><tt class="py-lineno">3039</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter-toggle" onclick="return toggle('GoogleDatastoreAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html">GoogleDatastoreAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">NoSQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="GoogleDatastoreAdapter-expanded"><a name="L3040"></a><tt class="py-lineno">3040</tt>  <tt class="py-line">    <tt id="link-1199" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.uploads_in_blob
web2py.gluon.dal.CouchDBAdapter.uploads_in_blob
web2py.gluon.dal.GoogleDatastoreAdapter.uploads_in_blob
web2py.gluon.dal.MongoDBAdapter.uploads_in_blob" class="py-name" href="#" onclick="return doclink('link-1199', 'uploads_in_blob', 'link-164');">uploads_in_blob</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L3041"></a><tt class="py-lineno">3041</tt>  <tt class="py-line">    <tt id="link-1200" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1200', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L3042"></a><tt class="py-lineno">3042</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.file_exists"></a><div id="GoogleDatastoreAdapter.file_exists-def"><a name="L3043"></a><tt class="py-lineno">3043</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.file_exists-toggle" onclick="return toggle('GoogleDatastoreAdapter.file_exists');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#file_exists">file_exists</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="GoogleDatastoreAdapter.file_open"></a><div id="GoogleDatastoreAdapter.file_open-def"><a name="L3044"></a><tt class="py-lineno">3044</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.file_open-toggle" onclick="return toggle('GoogleDatastoreAdapter.file_open');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#file_open">file_open</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt><tt class="py-op">=</tt><tt class="py-string">'rb'</tt><tt class="py-op">,</tt> <tt class="py-param">lock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="GoogleDatastoreAdapter.file_close"></a><div id="GoogleDatastoreAdapter.file_close-def"><a name="L3045"></a><tt class="py-lineno">3045</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.file_close-toggle" onclick="return toggle('GoogleDatastoreAdapter.file_close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#file_close">file_close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">fileobj</tt><tt class="py-op">,</tt> <tt class="py-param">unlock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="L3046"></a><tt class="py-lineno">3046</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.__init__"></a><div id="GoogleDatastoreAdapter.__init__-def"><a name="L3047"></a><tt class="py-lineno">3047</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.__init__-toggle" onclick="return toggle('GoogleDatastoreAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">,</tt><tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L3048"></a><tt class="py-lineno">3048</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1201" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1201', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1202" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1202', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L3049"></a><tt class="py-lineno">3049</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.__init__-expanded"><a name="L3050"></a><tt class="py-lineno">3050</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1203" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1203', 'types', 'link-2');">types</a></tt><tt class="py-op">.</tt><tt id="link-1204" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-1204', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt> </tt>
<a name="L3051"></a><tt class="py-lineno">3051</tt>  <tt class="py-line">                <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">BooleanProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3052"></a><tt class="py-lineno">3052</tt>  <tt class="py-line">                <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-keyword">lambda</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">StringProperty</tt><tt class="py-op">(</tt><tt class="py-name">multiline</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L3053"></a><tt class="py-lineno">3053</tt>  <tt class="py-line">                <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">TextProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3054"></a><tt class="py-lineno">3054</tt>  <tt class="py-line">                <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">StringProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3055"></a><tt class="py-lineno">3055</tt>  <tt class="py-line">                <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">BlobProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3056"></a><tt class="py-lineno">3056</tt>  <tt class="py-line">                <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">StringProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3057"></a><tt class="py-lineno">3057</tt>  <tt class="py-line">                <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">IntegerProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3058"></a><tt class="py-lineno">3058</tt>  <tt class="py-line">                <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">FloatProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3059"></a><tt class="py-lineno">3059</tt>  <tt class="py-line">                <tt class="py-string">'decimal'</tt><tt class="py-op">:</tt> <tt id="link-1205" class="py-name"><a title="web2py.gluon.dal.GAEDecimalProperty" class="py-name" href="#" onclick="return doclink('link-1205', 'GAEDecimalProperty', 'link-112');">GAEDecimalProperty</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3060"></a><tt class="py-lineno">3060</tt>  <tt class="py-line">                <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">DateProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3061"></a><tt class="py-lineno">3061</tt>  <tt class="py-line">                <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">TimeProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3062"></a><tt class="py-lineno">3062</tt>  <tt class="py-line">                <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">DateTimeProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3063"></a><tt class="py-lineno">3063</tt>  <tt class="py-line">                <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L3064"></a><tt class="py-lineno">3064</tt>  <tt class="py-line">                <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">IntegerProperty</tt><tt class="py-op">,</tt> </tt>
<a name="L3065"></a><tt class="py-lineno">3065</tt>  <tt class="py-line">                <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-keyword">lambda</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">StringListProperty</tt><tt class="py-op">(</tt><tt class="py-name">default</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L3066"></a><tt class="py-lineno">3066</tt>  <tt class="py-line">                <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-keyword">lambda</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">ListProperty</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">default</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L3067"></a><tt class="py-lineno">3067</tt>  <tt class="py-line">                <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-op">(</tt><tt class="py-keyword">lambda</tt><tt class="py-op">:</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">ListProperty</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">default</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L3068"></a><tt class="py-lineno">3068</tt>  <tt class="py-line">        <tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L3069"></a><tt class="py-lineno">3069</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L3070"></a><tt class="py-lineno">3070</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L3071"></a><tt class="py-lineno">3071</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">'google:datastore'</tt> </tt>
<a name="L3072"></a><tt class="py-lineno">3072</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L3073"></a><tt class="py-lineno">3073</tt>  <tt class="py-line">        <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-string">'_lastsql'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L3074"></a><tt class="py-lineno">3074</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-string">'UTF-8'</tt> </tt>
<a name="L3075"></a><tt class="py-lineno">3075</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
<a name="L3076"></a><tt class="py-lineno">3076</tt>  <tt class="py-line">        <tt class="py-name">match</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'.*://(?P&lt;namespace&gt;.+)'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt> </tt>
<a name="L3077"></a><tt class="py-lineno">3077</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">match</tt><tt class="py-op">:</tt> </tt>
<a name="L3078"></a><tt class="py-lineno">3078</tt>  <tt class="py-line">            <tt class="py-name">namespace_manager</tt><tt class="py-op">.</tt><tt class="py-name">set_namespace</tt><tt class="py-op">(</tt><tt class="py-name">match</tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'namespace'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3079"></a><tt class="py-lineno">3079</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.create_table"></a><div id="GoogleDatastoreAdapter.create_table-def"><a name="L3080"></a><tt class="py-lineno">3080</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.create_table-toggle" onclick="return toggle('GoogleDatastoreAdapter.create_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#create_table">create_table</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">migrate</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt><tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> <tt class="py-param">polymodel</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.create_table-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.create_table-expanded"><a name="L3081"></a><tt class="py-lineno">3081</tt>  <tt class="py-line">        <tt class="py-name">myfields</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L3082"></a><tt class="py-lineno">3082</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt id="link-1206" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1206', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3083"></a><tt class="py-lineno">3083</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">polymodel</tt><tt class="py-op">,</tt><tt id="link-1207" class="py-name" targets="Class web2py.gluon.dal.Table=web2py.gluon.dal.Table-class.html"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-1207', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt id="link-1208" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1208', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">polymodel</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3084"></a><tt class="py-lineno">3084</tt>  <tt class="py-line">                <tt class="py-keyword">continue</tt> </tt>
<a name="L3085"></a><tt class="py-lineno">3085</tt>  <tt class="py-line">            <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt id="link-1209" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1209', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> </tt>
<a name="L3086"></a><tt class="py-lineno">3086</tt>  <tt class="py-line">            <tt class="py-name">attr</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L3087"></a><tt class="py-lineno">3087</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt> <tt id="link-1210" class="py-name"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-1210', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3088"></a><tt class="py-lineno">3088</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1211" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1211', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt class="py-name">native</tt> <tt class="py-keyword">or</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">]</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">attr</tt><tt class="py-op">)</tt> </tt>
<a name="L3089"></a><tt class="py-lineno">3089</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt> <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">Property</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3090"></a><tt class="py-lineno">3090</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L3091"></a><tt class="py-lineno">3091</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1212" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1212', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'id'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3092"></a><tt class="py-lineno">3092</tt>  <tt class="py-line">                <tt class="py-keyword">continue</tt> </tt>
<a name="L3093"></a><tt class="py-lineno">3093</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1213" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1213', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'decimal'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3094"></a><tt class="py-lineno">3094</tt>  <tt class="py-line">                <tt class="py-name">precision</tt><tt class="py-op">,</tt> <tt class="py-name">scale</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">7</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1214" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1214', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-string">'()'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">','</tt><tt class="py-op">)</tt> </tt>
<a name="L3095"></a><tt class="py-lineno">3095</tt>  <tt class="py-line">                <tt class="py-name">precision</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">precision</tt><tt class="py-op">)</tt> </tt>
<a name="L3096"></a><tt class="py-lineno">3096</tt>  <tt class="py-line">                <tt class="py-name">scale</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">scale</tt><tt class="py-op">)</tt> </tt>
<a name="L3097"></a><tt class="py-lineno">3097</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt id="link-1215" class="py-name"><a title="web2py.gluon.dal.GAEDecimalProperty" class="py-name" href="#" onclick="return doclink('link-1215', 'GAEDecimalProperty', 'link-112');">GAEDecimalProperty</a></tt><tt class="py-op">(</tt><tt class="py-name">precision</tt><tt class="py-op">,</tt> <tt class="py-name">scale</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-name">attr</tt><tt class="py-op">)</tt> </tt>
<a name="L3098"></a><tt class="py-lineno">3098</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1216" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1216', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3099"></a><tt class="py-lineno">3099</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt><tt class="py-op">:</tt> </tt>
<a name="L3100"></a><tt class="py-lineno">3100</tt>  <tt class="py-line">                    <tt class="py-name">attr</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">required</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L3101"></a><tt class="py-lineno">3101</tt>  <tt class="py-line">                <tt class="py-name">referenced</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1217" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1217', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3102"></a><tt class="py-lineno">3102</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1218" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1218', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">9</tt><tt class="py-op">]</tt><tt class="py-op">]</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">referenced</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3103"></a><tt class="py-lineno">3103</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1219" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1219', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3104"></a><tt class="py-lineno">3104</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt><tt class="py-op">:</tt> </tt>
<a name="L3105"></a><tt class="py-lineno">3105</tt>  <tt class="py-line">                    <tt class="py-name">attr</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">required</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L3106"></a><tt class="py-lineno">3106</tt>  <tt class="py-line">                <tt class="py-name">referenced</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">15</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1220" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1220', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3107"></a><tt class="py-lineno">3107</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1221" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1221', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">14</tt><tt class="py-op">]</tt><tt class="py-op">]</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">attr</tt><tt class="py-op">)</tt> </tt>
<a name="L3108"></a><tt class="py-lineno">3108</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1222" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1222', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3109"></a><tt class="py-lineno">3109</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1223" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1223', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">]</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">attr</tt><tt class="py-op">)</tt> </tt>
<a name="L3110"></a><tt class="py-lineno">3110</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1224" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1224', 'types', 'link-2');">types</a></tt>\ </tt>
<a name="L3111"></a><tt class="py-lineno">3111</tt>  <tt class="py-line">                 <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1225" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1225', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L3112"></a><tt class="py-lineno">3112</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Field: unknown field type: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L3113"></a><tt class="py-lineno">3113</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3114"></a><tt class="py-lineno">3114</tt>  <tt class="py-line">                <tt class="py-name">ftype</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1226" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1226', 'types', 'link-2');">types</a></tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">]</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">attr</tt><tt class="py-op">)</tt> </tt>
<a name="L3115"></a><tt class="py-lineno">3115</tt>  <tt class="py-line">            <tt class="py-name">myfields</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1227" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1227', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">ftype</tt> </tt>
<a name="L3116"></a><tt class="py-lineno">3116</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">polymodel</tt><tt class="py-op">:</tt> </tt>
<a name="L3117"></a><tt class="py-lineno">3117</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt> <tt class="py-op">=</tt> <tt class="py-name">classobj</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">Model</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">myfields</tt><tt class="py-op">)</tt> </tt>
<a name="L3118"></a><tt class="py-lineno">3118</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">polymodel</tt><tt class="py-op">==</tt><tt class="py-name">True</tt><tt class="py-op">:</tt> </tt>
<a name="L3119"></a><tt class="py-lineno">3119</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt> <tt class="py-op">=</tt> <tt class="py-name">classobj</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">PolyModel</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">myfields</tt><tt class="py-op">)</tt> </tt>
<a name="L3120"></a><tt class="py-lineno">3120</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">polymodel</tt><tt class="py-op">,</tt><tt id="link-1228" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-1228', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3121"></a><tt class="py-lineno">3121</tt>  <tt class="py-line">            <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt> <tt class="py-op">=</tt> <tt class="py-name">classobj</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">polymodel</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt><tt class="py-op">,</tt> <tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">myfields</tt><tt class="py-op">)</tt> </tt>
<a name="L3122"></a><tt class="py-lineno">3122</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3123"></a><tt class="py-lineno">3123</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"polymodel must be None, True, a table or a tablename"</tt> </tt>
<a name="L3124"></a><tt class="py-lineno">3124</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L3125"></a><tt class="py-lineno">3125</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.expand"></a><div id="GoogleDatastoreAdapter.expand-def"><a name="L3126"></a><tt class="py-lineno">3126</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.expand-toggle" onclick="return toggle('GoogleDatastoreAdapter.expand');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#expand">expand</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">expression</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.expand-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.expand-expanded"><a name="L3127"></a><tt class="py-lineno">3127</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt id="link-1229" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-1229', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3128"></a><tt class="py-lineno">3128</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'text'</tt><tt class="py-op">,</tt><tt class="py-string">'blob'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3129"></a><tt class="py-lineno">3129</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'AppEngine does not index by: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L3130"></a><tt class="py-lineno">3130</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-1230" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1230', 'name', 'link-119');">name</a></tt> </tt>
<a name="L3131"></a><tt class="py-lineno">3131</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-1231" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-1231', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">,</tt> <tt id="link-1232" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1232', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3132"></a><tt class="py-lineno">3132</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L3133"></a><tt class="py-lineno">3133</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-1233" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1233', 'first', 'link-297');">first</a></tt><tt class="py-op">,</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">second</tt><tt class="py-op">)</tt> </tt>
<a name="L3134"></a><tt class="py-lineno">3134</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-1234" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1234', 'first', 'link-297');">first</a></tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L3135"></a><tt class="py-lineno">3135</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">.</tt><tt id="link-1235" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1235', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3136"></a><tt class="py-lineno">3136</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3137"></a><tt class="py-lineno">3137</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3138"></a><tt class="py-lineno">3138</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">:</tt> </tt>
<a name="L3139"></a><tt class="py-lineno">3139</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1236" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1236', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
<a name="L3140"></a><tt class="py-lineno">3140</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt><tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3141"></a><tt class="py-lineno">3141</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-1237" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1237', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1238" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1238', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">expression</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3142"></a><tt class="py-lineno">3142</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3143"></a><tt class="py-lineno">3143</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3144"></a><tt class="py-lineno">3144</tt>  <tt class="py-line"> </tt>
<a name="L3145"></a><tt class="py-lineno">3145</tt>  <tt class="py-line">    <tt class="py-comment">### TODO from gql.py Expression</tt> </tt>
<a name="GoogleDatastoreAdapter.AND"></a><div id="GoogleDatastoreAdapter.AND-def"><a name="L3146"></a><tt class="py-lineno">3146</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.AND-toggle" onclick="return toggle('GoogleDatastoreAdapter.AND');">-</a><tt class="py-line"><tt class="py-comment"></tt>    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#AND">AND</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.AND-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.AND-expanded"><a name="L3147"></a><tt class="py-lineno">3147</tt>  <tt class="py-line">        <tt class="py-name">a</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1239" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1239', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1240" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1240', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3148"></a><tt class="py-lineno">3148</tt>  <tt class="py-line">        <tt id="link-1241" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1241', 'b', 'link-188');">b</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1242" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1242', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt> </tt>
<a name="L3149"></a><tt class="py-lineno">3149</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1243" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1243', 'b', 'link-188');">b</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1244" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1244', 'name', 'link-119');">name</a></tt><tt class="py-op">==</tt><tt class="py-string">'__key__'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">a</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1245" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1245', 'name', 'link-119');">name</a></tt><tt class="py-op">!=</tt><tt class="py-string">'__key__'</tt><tt class="py-op">:</tt> </tt>
<a name="L3150"></a><tt class="py-lineno">3150</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1246" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1246', 'b', 'link-188');">b</a></tt><tt class="py-op">+</tt><tt class="py-name">a</tt> </tt>
<a name="L3151"></a><tt class="py-lineno">3151</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">a</tt><tt class="py-op">+</tt><tt id="link-1247" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1247', 'b', 'link-188');">b</a></tt> </tt>
</div><a name="L3152"></a><tt class="py-lineno">3152</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.EQ"></a><div id="GoogleDatastoreAdapter.EQ-def"><a name="L3153"></a><tt class="py-lineno">3153</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.EQ-toggle" onclick="return toggle('GoogleDatastoreAdapter.EQ');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#EQ">EQ</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.EQ-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.EQ-expanded"><a name="L3154"></a><tt class="py-lineno">3154</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt> <tt class="py-name">Key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3155"></a><tt class="py-lineno">3155</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1248" class="py-name" targets="Class web2py.gluon.dal.GAEF=web2py.gluon.dal.GAEF-class.html"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1248', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1249" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1249', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1250" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1250', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'='</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1251" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1251', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">==</tt><tt id="link-1252" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1252', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3156"></a><tt class="py-lineno">3156</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1253" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1253', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1254" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1254', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1255" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1255', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'='</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1256" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1256', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1257" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1257', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1258" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1258', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">==</tt><tt id="link-1259" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1259', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3157"></a><tt class="py-lineno">3157</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.NE"></a><div id="GoogleDatastoreAdapter.NE-def"><a name="L3158"></a><tt class="py-lineno">3158</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.NE-toggle" onclick="return toggle('GoogleDatastoreAdapter.NE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#NE">NE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.NE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.NE-expanded"><a name="L3159"></a><tt class="py-lineno">3159</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1260" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1260', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3160"></a><tt class="py-lineno">3160</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1261" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1261', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1262" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1262', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1263" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1263', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'!='</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1264" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1264', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1265" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1265', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1266" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1266', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">!=</tt><tt id="link-1267" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1267', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3161"></a><tt class="py-lineno">3161</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3162"></a><tt class="py-lineno">3162</tt>  <tt class="py-line">            <tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">Key</tt><tt class="py-op">.</tt><tt class="py-name">from_path</tt><tt class="py-op">(</tt><tt id="link-1268" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1268', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3163"></a><tt class="py-lineno">3163</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1269" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1269', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1270" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1270', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1271" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1271', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'!='</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1272" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1272', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">!=</tt><tt id="link-1273" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1273', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3164"></a><tt class="py-lineno">3164</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.LT"></a><div id="GoogleDatastoreAdapter.LT-def"><a name="L3165"></a><tt class="py-lineno">3165</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.LT-toggle" onclick="return toggle('GoogleDatastoreAdapter.LT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#LT">LT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.LT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.LT-expanded"><a name="L3166"></a><tt class="py-lineno">3166</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1274" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1274', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3167"></a><tt class="py-lineno">3167</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1275" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1275', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1276" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1276', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1277" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1277', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&lt;'</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1278" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1278', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1279" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1279', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1280" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1280', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&lt;</tt><tt id="link-1281" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1281', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3168"></a><tt class="py-lineno">3168</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3169"></a><tt class="py-lineno">3169</tt>  <tt class="py-line">            <tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">Key</tt><tt class="py-op">.</tt><tt class="py-name">from_path</tt><tt class="py-op">(</tt><tt id="link-1282" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1282', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3170"></a><tt class="py-lineno">3170</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1283" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1283', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1284" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1284', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1285" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1285', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&lt;'</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1286" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1286', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&lt;</tt><tt id="link-1287" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1287', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3171"></a><tt class="py-lineno">3171</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.LE"></a><div id="GoogleDatastoreAdapter.LE-def"><a name="L3172"></a><tt class="py-lineno">3172</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.LE-toggle" onclick="return toggle('GoogleDatastoreAdapter.LE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#LE">LE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.LE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.LE-expanded"><a name="L3173"></a><tt class="py-lineno">3173</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1288" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1288', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3174"></a><tt class="py-lineno">3174</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1289" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1289', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1290" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1290', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1291" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1291', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&lt;='</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1292" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1292', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1293" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1293', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1294" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1294', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&lt;=</tt><tt id="link-1295" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1295', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3175"></a><tt class="py-lineno">3175</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3176"></a><tt class="py-lineno">3176</tt>  <tt class="py-line">            <tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">Key</tt><tt class="py-op">.</tt><tt class="py-name">from_path</tt><tt class="py-op">(</tt><tt id="link-1296" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1296', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3177"></a><tt class="py-lineno">3177</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1297" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1297', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1298" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1298', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1299" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1299', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&lt;='</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1300" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1300', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&lt;=</tt><tt id="link-1301" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1301', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3178"></a><tt class="py-lineno">3178</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.GT"></a><div id="GoogleDatastoreAdapter.GT-def"><a name="L3179"></a><tt class="py-lineno">3179</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.GT-toggle" onclick="return toggle('GoogleDatastoreAdapter.GT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#GT">GT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.GT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.GT-expanded"><a name="L3180"></a><tt class="py-lineno">3180</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1302" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1302', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt> <tt class="py-keyword">or</tt> <tt class="py-name">second</tt><tt class="py-op">==</tt><tt class="py-number">0</tt> <tt class="py-keyword">or</tt> <tt class="py-name">second</tt> <tt class="py-op">==</tt> <tt class="py-string">'0'</tt><tt class="py-op">:</tt> </tt>
<a name="L3181"></a><tt class="py-lineno">3181</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1303" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1303', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1304" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1304', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1305" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1305', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&gt;'</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1306" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1306', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1307" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1307', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1308" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1308', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&gt;</tt><tt id="link-1309" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1309', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3182"></a><tt class="py-lineno">3182</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3183"></a><tt class="py-lineno">3183</tt>  <tt class="py-line">            <tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">Key</tt><tt class="py-op">.</tt><tt class="py-name">from_path</tt><tt class="py-op">(</tt><tt id="link-1310" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1310', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3184"></a><tt class="py-lineno">3184</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1311" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1311', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1312" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1312', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1313" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1313', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&gt;'</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1314" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1314', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&gt;</tt><tt id="link-1315" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1315', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3185"></a><tt class="py-lineno">3185</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.GE"></a><div id="GoogleDatastoreAdapter.GE-def"><a name="L3186"></a><tt class="py-lineno">3186</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.GE-toggle" onclick="return toggle('GoogleDatastoreAdapter.GE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#GE">GE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.GE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.GE-expanded"><a name="L3187"></a><tt class="py-lineno">3187</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1316" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1316', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3188"></a><tt class="py-lineno">3188</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1317" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1317', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1318" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1318', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1319" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1319', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&gt;='</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1320" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1320', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1321" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1321', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1322" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1322', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&gt;=</tt><tt id="link-1323" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1323', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3189"></a><tt class="py-lineno">3189</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3190"></a><tt class="py-lineno">3190</tt>  <tt class="py-line">            <tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">Key</tt><tt class="py-op">.</tt><tt class="py-name">from_path</tt><tt class="py-op">(</tt><tt id="link-1324" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1324', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">long</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3191"></a><tt class="py-lineno">3191</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1325" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1325', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1326" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1326', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1327" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1327', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'&gt;='</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1328" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1328', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&gt;=</tt><tt id="link-1329" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1329', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3192"></a><tt class="py-lineno">3192</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.INVERT"></a><div id="GoogleDatastoreAdapter.INVERT-def"><a name="L3193"></a><tt class="py-lineno">3193</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.INVERT-toggle" onclick="return toggle('GoogleDatastoreAdapter.INVERT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#INVERT">INVERT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.INVERT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.INVERT-expanded"><a name="L3194"></a><tt class="py-lineno">3194</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'-%s'</tt> <tt class="py-op">%</tt> <tt id="link-1330" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1330', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1331" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1331', 'name', 'link-119');">name</a></tt> </tt>
</div><a name="L3195"></a><tt class="py-lineno">3195</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.COMMA"></a><div id="GoogleDatastoreAdapter.COMMA-def"><a name="L3196"></a><tt class="py-lineno">3196</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.COMMA-toggle" onclick="return toggle('GoogleDatastoreAdapter.COMMA');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#COMMA">COMMA</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.COMMA-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.COMMA-expanded"><a name="L3197"></a><tt class="py-lineno">3197</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s, %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1332" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1332', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1333" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1333', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1334" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1334', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3198"></a><tt class="py-lineno">3198</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.BELONGS"></a><div id="GoogleDatastoreAdapter.BELONGS-def"><a name="L3199"></a><tt class="py-lineno">3199</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.BELONGS-toggle" onclick="return toggle('GoogleDatastoreAdapter.BELONGS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#BELONGS">BELONGS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.BELONGS-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.BELONGS-expanded"><a name="L3200"></a><tt class="py-lineno">3200</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3201"></a><tt class="py-lineno">3201</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
<a name="L3202"></a><tt class="py-lineno">3202</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1335" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1335', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3203"></a><tt class="py-lineno">3203</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1336" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1336', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1337" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1337', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1338" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1338', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'in'</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1339" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1339', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1340" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1340', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1341" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1341', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt> <tt class="py-keyword">in</tt> <tt id="link-1342" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1342', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3204"></a><tt class="py-lineno">3204</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3205"></a><tt class="py-lineno">3205</tt>  <tt class="py-line">            <tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">Key</tt><tt class="py-op">.</tt><tt class="py-name">from_path</tt><tt class="py-op">(</tt><tt id="link-1343" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1343', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">second</tt><tt class="py-op">]</tt> </tt>
<a name="L3206"></a><tt class="py-lineno">3206</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1344" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1344', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1345" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1345', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1346" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1346', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'in'</tt><tt class="py-op">,</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1347" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1347', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt> <tt class="py-keyword">in</tt> <tt id="link-1348" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1348', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3207"></a><tt class="py-lineno">3207</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.CONTAINS"></a><div id="GoogleDatastoreAdapter.CONTAINS-def"><a name="L3208"></a><tt class="py-lineno">3208</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.CONTAINS-toggle" onclick="return toggle('GoogleDatastoreAdapter.CONTAINS');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#CONTAINS">CONTAINS</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.CONTAINS-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.CONTAINS-expanded"><a name="L3209"></a><tt class="py-lineno">3209</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1349" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1349', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1350" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1350', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3210"></a><tt class="py-lineno">3210</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not supported"</tt> </tt>
<a name="L3211"></a><tt class="py-lineno">3211</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1351" class="py-name"><a title="web2py.gluon.dal.GAEF" class="py-name" href="#" onclick="return doclink('link-1351', 'GAEF', 'link-1248');">GAEF</a></tt><tt class="py-op">(</tt><tt id="link-1352" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1352', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt id="link-1353" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1353', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-string">'='</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1354" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1354', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1355" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1355', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">5</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1356" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1356', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt> <tt class="py-keyword">in</tt> <tt id="link-1357" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1357', 'b', 'link-188');">b</a></tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3212"></a><tt class="py-lineno">3212</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.NOT"></a><div id="GoogleDatastoreAdapter.NOT-def"><a name="L3213"></a><tt class="py-lineno">3213</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.NOT-toggle" onclick="return toggle('GoogleDatastoreAdapter.NOT');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#NOT">NOT</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.NOT-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.NOT-expanded"><a name="L3214"></a><tt class="py-lineno">3214</tt>  <tt class="py-line">        <tt class="py-name">nops</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1358" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.EQ()=web2py.gluon.dal.BaseAdapter-class.html#EQ,Method web2py.gluon.dal.CouchDBAdapter.EQ()=web2py.gluon.dal.CouchDBAdapter-class.html#EQ,Method web2py.gluon.dal.GoogleDatastoreAdapter.EQ()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#EQ"><a title="web2py.gluon.dal.BaseAdapter.EQ
web2py.gluon.dal.CouchDBAdapter.EQ
web2py.gluon.dal.GoogleDatastoreAdapter.EQ" class="py-name" href="#" onclick="return doclink('link-1358', 'EQ', 'link-1358');">EQ</a></tt><tt class="py-op">:</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1359" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.NE()=web2py.gluon.dal.BaseAdapter-class.html#NE,Method web2py.gluon.dal.CouchDBAdapter.NE()=web2py.gluon.dal.CouchDBAdapter-class.html#NE,Method web2py.gluon.dal.GoogleDatastoreAdapter.NE()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#NE"><a title="web2py.gluon.dal.BaseAdapter.NE
web2py.gluon.dal.CouchDBAdapter.NE
web2py.gluon.dal.GoogleDatastoreAdapter.NE" class="py-name" href="#" onclick="return doclink('link-1359', 'NE', 'link-1359');">NE</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3215"></a><tt class="py-lineno">3215</tt>  <tt class="py-line">                 <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1360" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.NE
web2py.gluon.dal.CouchDBAdapter.NE
web2py.gluon.dal.GoogleDatastoreAdapter.NE" class="py-name" href="#" onclick="return doclink('link-1360', 'NE', 'link-1359');">NE</a></tt><tt class="py-op">:</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1361" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EQ
web2py.gluon.dal.CouchDBAdapter.EQ
web2py.gluon.dal.GoogleDatastoreAdapter.EQ" class="py-name" href="#" onclick="return doclink('link-1361', 'EQ', 'link-1358');">EQ</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3216"></a><tt class="py-lineno">3216</tt>  <tt class="py-line">                 <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1362" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.LT()=web2py.gluon.dal.BaseAdapter-class.html#LT,Method web2py.gluon.dal.GoogleDatastoreAdapter.LT()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#LT"><a title="web2py.gluon.dal.BaseAdapter.LT
web2py.gluon.dal.GoogleDatastoreAdapter.LT" class="py-name" href="#" onclick="return doclink('link-1362', 'LT', 'link-1362');">LT</a></tt><tt class="py-op">:</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1363" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.GE()=web2py.gluon.dal.BaseAdapter-class.html#GE,Method web2py.gluon.dal.GoogleDatastoreAdapter.GE()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#GE"><a title="web2py.gluon.dal.BaseAdapter.GE
web2py.gluon.dal.GoogleDatastoreAdapter.GE" class="py-name" href="#" onclick="return doclink('link-1363', 'GE', 'link-1363');">GE</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3217"></a><tt class="py-lineno">3217</tt>  <tt class="py-line">                 <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1364" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.GT()=web2py.gluon.dal.BaseAdapter-class.html#GT,Method web2py.gluon.dal.GoogleDatastoreAdapter.GT()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#GT"><a title="web2py.gluon.dal.BaseAdapter.GT
web2py.gluon.dal.GoogleDatastoreAdapter.GT" class="py-name" href="#" onclick="return doclink('link-1364', 'GT', 'link-1364');">GT</a></tt><tt class="py-op">:</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1365" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.LE()=web2py.gluon.dal.BaseAdapter-class.html#LE,Method web2py.gluon.dal.GoogleDatastoreAdapter.LE()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#LE"><a title="web2py.gluon.dal.BaseAdapter.LE
web2py.gluon.dal.GoogleDatastoreAdapter.LE" class="py-name" href="#" onclick="return doclink('link-1365', 'LE', 'link-1365');">LE</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3218"></a><tt class="py-lineno">3218</tt>  <tt class="py-line">                 <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1366" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.LE
web2py.gluon.dal.GoogleDatastoreAdapter.LE" class="py-name" href="#" onclick="return doclink('link-1366', 'LE', 'link-1365');">LE</a></tt><tt class="py-op">:</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1367" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.GT
web2py.gluon.dal.GoogleDatastoreAdapter.GT" class="py-name" href="#" onclick="return doclink('link-1367', 'GT', 'link-1364');">GT</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3219"></a><tt class="py-lineno">3219</tt>  <tt class="py-line">                 <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1368" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.GE
web2py.gluon.dal.GoogleDatastoreAdapter.GE" class="py-name" href="#" onclick="return doclink('link-1368', 'GE', 'link-1363');">GE</a></tt><tt class="py-op">:</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1369" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.LT
web2py.gluon.dal.GoogleDatastoreAdapter.LT" class="py-name" href="#" onclick="return doclink('link-1369', 'LT', 'link-1362');">LT</a></tt><tt class="py-op">}</tt> </tt>
<a name="L3220"></a><tt class="py-lineno">3220</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-1370" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1370', 'first', 'link-297');">first</a></tt><tt class="py-op">,</tt><tt id="link-1371" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1371', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3221"></a><tt class="py-lineno">3221</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not suported"</tt> </tt>
<a name="L3222"></a><tt class="py-lineno">3222</tt>  <tt class="py-line">        <tt class="py-name">nop</tt> <tt class="py-op">=</tt> <tt class="py-name">nops</tt><tt class="py-op">.</tt><tt id="link-1372" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1372', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt id="link-1373" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1373', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L3223"></a><tt class="py-lineno">3223</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">nop</tt><tt class="py-op">:</tt> </tt>
<a name="L3224"></a><tt class="py-lineno">3224</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not suported %s"</tt> <tt class="py-op">%</tt> <tt id="link-1374" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1374', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">.</tt><tt class="py-name">__name__</tt> </tt>
<a name="L3225"></a><tt class="py-lineno">3225</tt>  <tt class="py-line">        <tt id="link-1375" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1375', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">op</tt> <tt class="py-op">=</tt> <tt class="py-name">nop</tt> </tt>
<a name="L3226"></a><tt class="py-lineno">3226</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1376" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1376', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1377" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1377', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L3227"></a><tt class="py-lineno">3227</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.truncate"></a><div id="GoogleDatastoreAdapter.truncate-def"><a name="L3228"></a><tt class="py-lineno">3228</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.truncate-toggle" onclick="return toggle('GoogleDatastoreAdapter.truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#truncate">truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">mode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.truncate-expanded"><a name="L3229"></a><tt class="py-lineno">3229</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">0</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1378" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-1378', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3230"></a><tt class="py-lineno">3230</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.select_raw"></a><div id="GoogleDatastoreAdapter.select_raw-def"><a name="L3231"></a><tt class="py-lineno">3231</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.select_raw-toggle" onclick="return toggle('GoogleDatastoreAdapter.select_raw');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#select_raw">select_raw</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.select_raw-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.select_raw-expanded"><a name="L3232"></a><tt class="py-lineno">3232</tt>  <tt class="py-line">        <tt class="py-name">new_fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3233"></a><tt class="py-lineno">3233</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3234"></a><tt class="py-lineno">3234</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt id="link-1379" class="py-name"><a title="web2py.gluon.dal.SQLALL" class="py-name" href="#" onclick="return doclink('link-1379', 'SQLALL', 'link-439');">SQLALL</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3235"></a><tt class="py-lineno">3235</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt> <tt class="py-op">+=</tt> <tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">table</tt> </tt>
<a name="L3236"></a><tt class="py-lineno">3236</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3237"></a><tt class="py-lineno">3237</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-1380" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1380', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> </tt>
<a name="L3238"></a><tt class="py-lineno">3238</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">new_fields</tt> </tt>
<a name="L3239"></a><tt class="py-lineno">3239</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L3240"></a><tt class="py-lineno">3240</tt>  <tt class="py-line">            <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1381" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.get_table()=web2py.gluon.dal.BaseAdapter-class.html#get_table"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-1381', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3241"></a><tt class="py-lineno">3241</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3242"></a><tt class="py-lineno">3242</tt>  <tt class="py-line">            <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">fields</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> </tt>
<a name="L3243"></a><tt class="py-lineno">3243</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">fields</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">&gt;</tt><tt class="py-number">0</tt> </tt>
<a name="L3244"></a><tt class="py-lineno">3244</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3245"></a><tt class="py-lineno">3245</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Unable to determine a tablename"</tt> </tt>
<a name="L3246"></a><tt class="py-lineno">3246</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1382" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.filter_tenant" class="py-name" href="#" onclick="return doclink('link-1382', 'filter_tenant', 'link-477');">filter_tenant</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3247"></a><tt class="py-lineno">3247</tt>  <tt class="py-line">        <tt class="py-name">tableobj</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt> </tt>
<a name="L3248"></a><tt class="py-lineno">3248</tt>  <tt class="py-line">        <tt id="link-1383" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1383', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-name">tableobj</tt><tt class="py-op">.</tt><tt class="py-name">all</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3249"></a><tt class="py-lineno">3249</tt>  <tt class="py-line">        <tt class="py-name">filters</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1384" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1384', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3250"></a><tt class="py-lineno">3250</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">filter</tt> <tt class="py-keyword">in</tt> <tt class="py-name">filters</tt><tt class="py-op">:</tt> </tt>
<a name="L3251"></a><tt class="py-lineno">3251</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt id="link-1385" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1385', 'name', 'link-119');">name</a></tt><tt class="py-op">==</tt><tt class="py-string">'__key__'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">==</tt><tt class="py-string">'&gt;'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">==</tt><tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L3252"></a><tt class="py-lineno">3252</tt>  <tt class="py-line">                <tt class="py-keyword">continue</tt> </tt>
<a name="L3253"></a><tt class="py-lineno">3253</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt id="link-1386" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1386', 'name', 'link-119');">name</a></tt><tt class="py-op">==</tt><tt class="py-string">'__key__'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">==</tt><tt class="py-string">'='</tt><tt class="py-op">:</tt> </tt>
<a name="L3254"></a><tt class="py-lineno">3254</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">==</tt><tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L3255"></a><tt class="py-lineno">3255</tt>  <tt class="py-line">                    <tt id="link-1387" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1387', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3256"></a><tt class="py-lineno">3256</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">Key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3257"></a><tt class="py-lineno">3257</tt>  <tt class="py-line">                    <tt class="py-name">item</tt> <tt class="py-op">=</tt> <tt class="py-name">tableobj</tt><tt class="py-op">.</tt><tt id="link-1388" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1388', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L3258"></a><tt class="py-lineno">3258</tt>  <tt class="py-line">                    <tt id="link-1389" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1389', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">item</tt> <tt class="py-keyword">and</tt> <tt class="py-op">[</tt><tt class="py-name">item</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3259"></a><tt class="py-lineno">3259</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3260"></a><tt class="py-lineno">3260</tt>  <tt class="py-line">                    <tt class="py-name">item</tt> <tt class="py-op">=</tt> <tt class="py-name">tableobj</tt><tt class="py-op">.</tt><tt class="py-name">get_by_id</tt><tt class="py-op">(</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L3261"></a><tt class="py-lineno">3261</tt>  <tt class="py-line">                    <tt id="link-1390" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1390', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">item</tt> <tt class="py-keyword">and</tt> <tt class="py-op">[</tt><tt class="py-name">item</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3262"></a><tt class="py-lineno">3262</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-1391" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1391', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt><tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-comment"># i.e. there is a single record!</tt> </tt>
<a name="L3263"></a><tt class="py-lineno">3263</tt>  <tt class="py-line">                <tt id="link-1392" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1392', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">i</tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt id="link-1393" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1393', 'items', 'link-266');">items</a></tt> <tt class="py-keyword">if</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">apply</tt><tt class="py-op">(</tt><tt class="py-name">getattr</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt id="link-1394" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1394', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L3264"></a><tt class="py-lineno">3264</tt>  <tt class="py-line">                                                          <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3265"></a><tt class="py-lineno">3265</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3266"></a><tt class="py-lineno">3266</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">filter</tt><tt class="py-op">.</tt><tt id="link-1395" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1395', 'name', 'link-119');">name</a></tt><tt class="py-op">==</tt><tt class="py-string">'__key__'</tt><tt class="py-op">:</tt> <tt id="link-1396" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1396', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt class="py-name">order</tt><tt class="py-op">(</tt><tt class="py-string">'__key__'</tt><tt class="py-op">)</tt> </tt>
<a name="L3267"></a><tt class="py-lineno">3267</tt>  <tt class="py-line">                <tt id="link-1397" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1397', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt id="link-1398" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1398', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt class="py-name">filter</tt><tt class="py-op">(</tt><tt class="py-string">'%s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt id="link-1399" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1399', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">filter</tt><tt class="py-op">.</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L3268"></a><tt class="py-lineno">3268</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-1400" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1400', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt><tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3269"></a><tt class="py-lineno">3269</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-1401" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1401', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'left'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3270"></a><tt class="py-lineno">3270</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Set: no left join in appengine'</tt> </tt>
<a name="L3271"></a><tt class="py-lineno">3271</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-1402" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1402', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'groupby'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3272"></a><tt class="py-lineno">3272</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Set: no groupby in appengine'</tt> </tt>
<a name="L3273"></a><tt class="py-lineno">3273</tt>  <tt class="py-line">            <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-1403" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1403', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'orderby'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L3274"></a><tt class="py-lineno">3274</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">orderby</tt><tt class="py-op">:</tt> </tt>
<a name="L3275"></a><tt class="py-lineno">3275</tt>  <tt class="py-line">                <tt class="py-comment">### THIS REALLY NEEDS IMPROVEMENT !!!</tt> </tt>
<a name="L3276"></a><tt class="py-lineno">3276</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3277"></a><tt class="py-lineno">3277</tt>  <tt class="py-line">                    <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt id="link-1404" class="py-name"><a title="web2py.gluon.dal.xorify" class="py-name" href="#" onclick="return doclink('link-1404', 'xorify', 'link-523');">xorify</a></tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">)</tt> </tt>
<a name="L3278"></a><tt class="py-lineno">3278</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">,</tt><tt id="link-1405" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-1405', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3279"></a><tt class="py-lineno">3279</tt>  <tt class="py-line">                    <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1406" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1406', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">orderby</tt><tt class="py-op">)</tt> </tt>
<a name="L3280"></a><tt class="py-lineno">3280</tt>  <tt class="py-line">                <tt class="py-name">orders</tt> <tt class="py-op">=</tt> <tt class="py-name">orderby</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">', '</tt><tt class="py-op">)</tt> </tt>
<a name="L3281"></a><tt class="py-lineno">3281</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">order</tt> <tt class="py-keyword">in</tt> <tt class="py-name">orders</tt><tt class="py-op">:</tt> </tt>
<a name="L3282"></a><tt class="py-lineno">3282</tt>  <tt class="py-line">                    <tt class="py-name">order</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-string">'-id'</tt><tt class="py-op">:</tt><tt class="py-string">'-__key__'</tt><tt class="py-op">,</tt><tt class="py-string">'id'</tt><tt class="py-op">:</tt><tt class="py-string">'__key__'</tt><tt class="py-op">}</tt><tt class="py-op">.</tt><tt id="link-1407" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1407', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">order</tt><tt class="py-op">,</tt><tt class="py-name">order</tt><tt class="py-op">)</tt> </tt>
<a name="L3283"></a><tt class="py-lineno">3283</tt>  <tt class="py-line">                    <tt id="link-1408" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1408', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt id="link-1409" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1409', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt class="py-name">order</tt><tt class="py-op">(</tt><tt class="py-name">order</tt><tt class="py-op">)</tt> </tt>
<a name="L3284"></a><tt class="py-lineno">3284</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-1410" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1410', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'limitby'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3285"></a><tt class="py-lineno">3285</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmax</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">attributes</tt><tt class="py-op">[</tt><tt class="py-string">'limitby'</tt><tt class="py-op">]</tt> </tt>
<a name="L3286"></a><tt class="py-lineno">3286</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt class="py-name">limit</tt><tt class="py-op">,</tt> <tt class="py-name">offset</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">lmax</tt> <tt class="py-op">-</tt> <tt class="py-name">lmin</tt><tt class="py-op">,</tt> <tt class="py-name">lmin</tt><tt class="py-op">)</tt> </tt>
<a name="L3287"></a><tt class="py-lineno">3287</tt>  <tt class="py-line">                <tt id="link-1411" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1411', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt id="link-1412" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1412', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt id="link-1413" class="py-name" targets="Function web2py.gluon.tools.fetch()=web2py.gluon.tools-module.html#fetch"><a title="web2py.gluon.tools.fetch" class="py-name" href="#" onclick="return doclink('link-1413', 'fetch', 'link-1413');">fetch</a></tt><tt class="py-op">(</tt><tt class="py-name">limit</tt><tt class="py-op">,</tt> <tt class="py-name">offset</tt><tt class="py-op">=</tt><tt class="py-name">offset</tt><tt class="py-op">)</tt> </tt>
<a name="L3288"></a><tt class="py-lineno">3288</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt> </tt>
<a name="L3289"></a><tt class="py-lineno">3289</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt id="link-1414" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1414', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3290"></a><tt class="py-lineno">3290</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.select"></a><div id="GoogleDatastoreAdapter.select-def"><a name="L3291"></a><tt class="py-lineno">3291</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.select-toggle" onclick="return toggle('GoogleDatastoreAdapter.select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#select">select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.select-expanded"><a name="L3292"></a><tt class="py-lineno">3292</tt>  <tt class="py-line">        <tt class="py-op">(</tt><tt id="link-1415" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1415', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1416" class="py-name" targets="Method web2py.gluon.dal.GoogleDatastoreAdapter.select_raw()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#select_raw"><a title="web2py.gluon.dal.GoogleDatastoreAdapter.select_raw" class="py-name" href="#" onclick="return doclink('link-1416', 'select_raw', 'link-1416');">select_raw</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt><tt class="py-name">attributes</tt><tt class="py-op">)</tt> </tt>
<a name="L3293"></a><tt class="py-lineno">3293</tt>  <tt class="py-line">        <tt class="py-comment"># self.db['_lastsql'] = self._select(query,fields,attributes)</tt> </tt>
<a name="L3294"></a><tt class="py-lineno">3294</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt id="link-1417" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1417', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt> </tt>
<a name="L3295"></a><tt class="py-lineno">3295</tt>  <tt class="py-line">            <tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">key</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">id</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">getattr</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt> <tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">]</tt> </tt>
<a name="L3296"></a><tt class="py-lineno">3296</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-1418" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1418', 'items', 'link-266');">items</a></tt><tt class="py-op">]</tt> </tt>
<a name="L3297"></a><tt class="py-lineno">3297</tt>  <tt class="py-line">        <tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">t</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">t</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">]</tt> </tt>
<a name="L3298"></a><tt class="py-lineno">3298</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1419" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.parse
web2py.gluon.template.TemplateParser.parse" class="py-name" href="#" onclick="return doclink('link-1419', 'parse', 'link-550');">parse</a></tt><tt class="py-op">(</tt><tt id="link-1420" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1420', 'rows', 'link-539');">rows</a></tt><tt class="py-op">,</tt> <tt class="py-name">colnames</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3299"></a><tt class="py-lineno">3299</tt>  <tt class="py-line"> </tt>
<a name="L3300"></a><tt class="py-lineno">3300</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.count"></a><div id="GoogleDatastoreAdapter.count-def"><a name="L3301"></a><tt class="py-lineno">3301</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.count-toggle" onclick="return toggle('GoogleDatastoreAdapter.count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#count">count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.count-expanded"><a name="L3302"></a><tt class="py-lineno">3302</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">distinct</tt><tt class="py-op">:</tt> </tt>
<a name="L3303"></a><tt class="py-lineno">3303</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"COUNT DISTINCT not supported"</tt> </tt>
<a name="L3304"></a><tt class="py-lineno">3304</tt>  <tt class="py-line">        <tt class="py-op">(</tt><tt id="link-1421" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1421', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1422" class="py-name"><a title="web2py.gluon.dal.GoogleDatastoreAdapter.select_raw" class="py-name" href="#" onclick="return doclink('link-1422', 'select_raw', 'link-1416');">select_raw</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3305"></a><tt class="py-lineno">3305</tt>  <tt class="py-line">        <tt class="py-comment"># self.db['_lastsql'] = self._count(query)</tt> </tt>
<a name="L3306"></a><tt class="py-lineno">3306</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3307"></a><tt class="py-lineno">3307</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1423" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1423', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-1424" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1424', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3308"></a><tt class="py-lineno">3308</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt> <tt class="py-name">TypeError</tt><tt class="py-op">:</tt> </tt>
<a name="L3309"></a><tt class="py-lineno">3309</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1425" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1425', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt id="link-1426" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.count()=web2py.gluon.dal.BaseAdapter-class.html#count,Method web2py.gluon.dal.CouchDBAdapter.count()=web2py.gluon.dal.CouchDBAdapter-class.html#count,Method web2py.gluon.dal.Field.count()=web2py.gluon.dal.Field-class.html#count,Method web2py.gluon.dal.GoogleDatastoreAdapter.count()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#count,Method web2py.gluon.dal.MongoDBAdapter.count()=web2py.gluon.dal.MongoDBAdapter-class.html#count,Method web2py.gluon.dal.Set.count()=web2py.gluon.dal.Set-class.html#count"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-1426', 'count', 'link-1426');">count</a></tt><tt class="py-op">(</tt><tt class="py-name">limit</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3310"></a><tt class="py-lineno">3310</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.delete"></a><div id="GoogleDatastoreAdapter.delete-def"><a name="L3311"></a><tt class="py-lineno">3311</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.delete-toggle" onclick="return toggle('GoogleDatastoreAdapter.delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#delete">delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.delete-expanded"><a name="L3312"></a><tt class="py-lineno">3312</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L3313"></a><tt class="py-lineno">3313</tt>  <tt class="py-line"><tt class="py-docstring">        This function was changed on 2010-05-04 because according to</tt> </tt>
<a name="L3314"></a><tt class="py-lineno">3314</tt>  <tt class="py-line"><tt class="py-docstring">        http://code.google.com/p/googleappengine/issues/detail?id=3119</tt> </tt>
<a name="L3315"></a><tt class="py-lineno">3315</tt>  <tt class="py-line"><tt class="py-docstring">        GAE no longer support deleting more than 1000 records.</tt> </tt>
<a name="L3316"></a><tt class="py-lineno">3316</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L3317"></a><tt class="py-lineno">3317</tt>  <tt class="py-line">        <tt class="py-comment"># self.db['_lastsql'] = self._delete(tablename,query)</tt> </tt>
<a name="L3318"></a><tt class="py-lineno">3318</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-op">(</tt><tt id="link-1427" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1427', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1428" class="py-name"><a title="web2py.gluon.dal.GoogleDatastoreAdapter.select_raw" class="py-name" href="#" onclick="return doclink('link-1428', 'select_raw', 'link-1416');">select_raw</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3319"></a><tt class="py-lineno">3319</tt>  <tt class="py-line">        <tt class="py-comment"># items can be one item or a query</tt> </tt>
<a name="L3320"></a><tt class="py-lineno">3320</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-1429" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1429', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt><tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3321"></a><tt class="py-lineno">3321</tt>  <tt class="py-line">            <tt class="py-name">counter</tt> <tt class="py-op">=</tt> <tt id="link-1430" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1430', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt id="link-1431" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-1431', 'count', 'link-1426');">count</a></tt><tt class="py-op">(</tt><tt class="py-name">limit</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L3322"></a><tt class="py-lineno">3322</tt>  <tt class="py-line">            <tt class="py-name">leftitems</tt> <tt class="py-op">=</tt> <tt id="link-1432" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1432', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt id="link-1433" class="py-name"><a title="web2py.gluon.tools.fetch" class="py-name" href="#" onclick="return doclink('link-1433', 'fetch', 'link-1413');">fetch</a></tt><tt class="py-op">(</tt><tt class="py-number">1000</tt><tt class="py-op">)</tt> </tt>
<a name="L3323"></a><tt class="py-lineno">3323</tt>  <tt class="py-line">            <tt class="py-keyword">while</tt> <tt id="link-1434" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1434', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">leftitems</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3324"></a><tt class="py-lineno">3324</tt>  <tt class="py-line">                <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt id="link-1435" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-1435', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-name">leftitems</tt><tt class="py-op">)</tt> </tt>
<a name="L3325"></a><tt class="py-lineno">3325</tt>  <tt class="py-line">                <tt class="py-name">leftitems</tt> <tt class="py-op">=</tt> <tt id="link-1436" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1436', 'items', 'link-266');">items</a></tt><tt class="py-op">.</tt><tt id="link-1437" class="py-name"><a title="web2py.gluon.tools.fetch" class="py-name" href="#" onclick="return doclink('link-1437', 'fetch', 'link-1413');">fetch</a></tt><tt class="py-op">(</tt><tt class="py-number">1000</tt><tt class="py-op">)</tt> </tt>
<a name="L3326"></a><tt class="py-lineno">3326</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3327"></a><tt class="py-lineno">3327</tt>  <tt class="py-line">            <tt class="py-name">counter</tt> <tt class="py-op">=</tt> <tt id="link-1438" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1438', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-1439" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1439', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3328"></a><tt class="py-lineno">3328</tt>  <tt class="py-line">            <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt id="link-1440" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-1440', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt id="link-1441" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1441', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3329"></a><tt class="py-lineno">3329</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">counter</tt> </tt>
</div><a name="L3330"></a><tt class="py-lineno">3330</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.update"></a><div id="GoogleDatastoreAdapter.update-def"><a name="L3331"></a><tt class="py-lineno">3331</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.update-toggle" onclick="return toggle('GoogleDatastoreAdapter.update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#update">update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">update_fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.update-expanded"><a name="L3332"></a><tt class="py-lineno">3332</tt>  <tt class="py-line">        <tt class="py-comment"># self.db['_lastsql'] = self._update(tablename,query,update_fields)</tt> </tt>
<a name="L3333"></a><tt class="py-lineno">3333</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-op">(</tt><tt id="link-1442" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1442', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1443" class="py-name"><a title="web2py.gluon.dal.GoogleDatastoreAdapter.select_raw" class="py-name" href="#" onclick="return doclink('link-1443', 'select_raw', 'link-1416');">select_raw</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3334"></a><tt class="py-lineno">3334</tt>  <tt class="py-line">        <tt class="py-name">counter</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
<a name="L3335"></a><tt class="py-lineno">3335</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-1444" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1444', 'items', 'link-266');">items</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3336"></a><tt class="py-lineno">3336</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">field</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt> <tt class="py-keyword">in</tt> <tt class="py-name">update_fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3337"></a><tt class="py-lineno">3337</tt>  <tt class="py-line">                <tt class="py-name">setattr</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1445" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1445', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1446" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1446', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3338"></a><tt class="py-lineno">3338</tt>  <tt class="py-line">            <tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">put</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3339"></a><tt class="py-lineno">3339</tt>  <tt class="py-line">            <tt class="py-name">counter</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
<a name="L3340"></a><tt class="py-lineno">3340</tt>  <tt class="py-line">        <tt id="link-1447" class="py-name"><a title="web2py.gluon.cache.logger
web2py.gluon.compileapp.logger
web2py.gluon.dal.logger
web2py.gluon.debug.logger
web2py.gluon.main.logger
web2py.gluon.newcron.logger
web2py.gluon.portalocker.logger
web2py.gluon.restricted.logger
web2py.gluon.rewrite.logger
web2py.gluon.shell.logger
web2py.gluon.tools.logger
web2py.gluon.utils.logger
web2py.gluon.widget.logger" class="py-name" href="#" onclick="return doclink('link-1447', 'logger', 'link-24');">logger</a></tt><tt class="py-op">.</tt><tt class="py-name">info</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">counter</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3341"></a><tt class="py-lineno">3341</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">counter</tt> </tt>
</div><a name="L3342"></a><tt class="py-lineno">3342</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.insert"></a><div id="GoogleDatastoreAdapter.insert-def"><a name="L3343"></a><tt class="py-lineno">3343</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.insert-toggle" onclick="return toggle('GoogleDatastoreAdapter.insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#insert">insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.insert-expanded"><a name="L3344"></a><tt class="py-lineno">3344</tt>  <tt class="py-line">        <tt class="py-name">dfields</tt><tt class="py-op">=</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt id="link-1448" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1448', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1449" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1449', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L3345"></a><tt class="py-lineno">3345</tt>  <tt class="py-line">        <tt class="py-comment"># table._db['_lastsql'] = self._insert(table,fields)</tt> </tt>
<a name="L3346"></a><tt class="py-lineno">3346</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">tmp</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">dfields</tt><tt class="py-op">)</tt> </tt>
<a name="L3347"></a><tt class="py-lineno">3347</tt>  <tt class="py-line">        <tt class="py-name">tmp</tt><tt class="py-op">.</tt><tt class="py-name">put</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3348"></a><tt class="py-lineno">3348</tt>  <tt class="py-line">        <tt class="py-name">rid</tt> <tt class="py-op">=</tt> <tt id="link-1450" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-1450', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">(</tt><tt class="py-name">tmp</tt><tt class="py-op">.</tt><tt class="py-name">key</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">id</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3349"></a><tt class="py-lineno">3349</tt>  <tt class="py-line">        <tt class="py-op">(</tt><tt class="py-name">rid</tt><tt class="py-op">.</tt><tt class="py-name">_table</tt><tt class="py-op">,</tt> <tt class="py-name">rid</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L3350"></a><tt class="py-lineno">3350</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">rid</tt> </tt>
</div><a name="L3351"></a><tt class="py-lineno">3351</tt>  <tt class="py-line"> </tt>
<a name="GoogleDatastoreAdapter.bulk_insert"></a><div id="GoogleDatastoreAdapter.bulk_insert-def"><a name="L3352"></a><tt class="py-lineno">3352</tt> <a class="py-toggle" href="#" id="GoogleDatastoreAdapter.bulk_insert-toggle" onclick="return toggle('GoogleDatastoreAdapter.bulk_insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.GoogleDatastoreAdapter-class.html#bulk_insert">bulk_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">items</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="GoogleDatastoreAdapter.bulk_insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="GoogleDatastoreAdapter.bulk_insert-expanded"><a name="L3353"></a><tt class="py-lineno">3353</tt>  <tt class="py-line">        <tt class="py-name">parsed_items</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3354"></a><tt class="py-lineno">3354</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-1451" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1451', 'items', 'link-266');">items</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3355"></a><tt class="py-lineno">3355</tt>  <tt class="py-line">            <tt class="py-name">dfields</tt><tt class="py-op">=</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt id="link-1452" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1452', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1453" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1453', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">item</tt><tt class="py-op">)</tt> </tt>
<a name="L3356"></a><tt class="py-lineno">3356</tt>  <tt class="py-line">            <tt class="py-name">parsed_items</tt><tt class="py-op">.</tt><tt id="link-1454" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1454', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tableobj</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">dfields</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3357"></a><tt class="py-lineno">3357</tt>  <tt class="py-line">        <tt class="py-name">gae</tt><tt class="py-op">.</tt><tt class="py-name">put</tt><tt class="py-op">(</tt><tt class="py-name">parsed_items</tt><tt class="py-op">)</tt> </tt>
<a name="L3358"></a><tt class="py-lineno">3358</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">True</tt> </tt>
</div></div><a name="L3359"></a><tt class="py-lineno">3359</tt>  <tt class="py-line"> </tt>
<a name="uuid2int"></a><div id="uuid2int-def"><a name="L3360"></a><tt class="py-lineno">3360</tt> <a class="py-toggle" href="#" id="uuid2int-toggle" onclick="return toggle('uuid2int');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#uuid2int">uuid2int</a><tt class="py-op">(</tt><tt class="py-param">uuidv</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="uuid2int-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="uuid2int-expanded"><a name="L3361"></a><tt class="py-lineno">3361</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">uuid</tt><tt class="py-op">.</tt><tt class="py-name">UUID</tt><tt class="py-op">(</tt><tt class="py-name">uuidv</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">int</tt> </tt>
</div><a name="L3362"></a><tt class="py-lineno">3362</tt>  <tt class="py-line"> </tt>
<a name="int2uuid"></a><div id="int2uuid-def"><a name="L3363"></a><tt class="py-lineno">3363</tt> <a class="py-toggle" href="#" id="int2uuid-toggle" onclick="return toggle('int2uuid');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#int2uuid">int2uuid</a><tt class="py-op">(</tt><tt class="py-param">n</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="int2uuid-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="int2uuid-expanded"><a name="L3364"></a><tt class="py-lineno">3364</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">uuid</tt><tt class="py-op">.</tt><tt class="py-name">UUID</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">=</tt><tt class="py-name">n</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3365"></a><tt class="py-lineno">3365</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter"></a><div id="CouchDBAdapter-def"><a name="L3366"></a><tt class="py-lineno">3366</tt> <a class="py-toggle" href="#" id="CouchDBAdapter-toggle" onclick="return toggle('CouchDBAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html">CouchDBAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">NoSQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="CouchDBAdapter-expanded"><a name="L3367"></a><tt class="py-lineno">3367</tt>  <tt class="py-line">    <tt id="link-1455" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.uploads_in_blob
web2py.gluon.dal.CouchDBAdapter.uploads_in_blob
web2py.gluon.dal.GoogleDatastoreAdapter.uploads_in_blob
web2py.gluon.dal.MongoDBAdapter.uploads_in_blob" class="py-name" href="#" onclick="return doclink('link-1455', 'uploads_in_blob', 'link-164');">uploads_in_blob</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L3368"></a><tt class="py-lineno">3368</tt>  <tt class="py-line">    <tt id="link-1456" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1456', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L3369"></a><tt class="py-lineno">3369</tt>  <tt class="py-line">                <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-name">bool</tt><tt class="py-op">,</tt> </tt>
<a name="L3370"></a><tt class="py-lineno">3370</tt>  <tt class="py-line">                <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3371"></a><tt class="py-lineno">3371</tt>  <tt class="py-line">                <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3372"></a><tt class="py-lineno">3372</tt>  <tt class="py-line">                <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3373"></a><tt class="py-lineno">3373</tt>  <tt class="py-line">                <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3374"></a><tt class="py-lineno">3374</tt>  <tt class="py-line">                <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3375"></a><tt class="py-lineno">3375</tt>  <tt class="py-line">                <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-name">long</tt><tt class="py-op">,</tt> </tt>
<a name="L3376"></a><tt class="py-lineno">3376</tt>  <tt class="py-line">                <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-name">float</tt><tt class="py-op">,</tt> </tt>
<a name="L3377"></a><tt class="py-lineno">3377</tt>  <tt class="py-line">                <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt id="link-1457" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1457', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1458" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1458', 'date', 'link-604');">date</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3378"></a><tt class="py-lineno">3378</tt>  <tt class="py-line">                <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt id="link-1459" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1459', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1460" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-1460', 'time', 'link-4');">time</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3379"></a><tt class="py-lineno">3379</tt>  <tt class="py-line">                <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt id="link-1461" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1461', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1462" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1462', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3380"></a><tt class="py-lineno">3380</tt>  <tt class="py-line">                <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-name">long</tt><tt class="py-op">,</tt> </tt>
<a name="L3381"></a><tt class="py-lineno">3381</tt>  <tt class="py-line">                <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-name">long</tt><tt class="py-op">,</tt> </tt>
<a name="L3382"></a><tt class="py-lineno">3382</tt>  <tt class="py-line">                <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-name">list</tt><tt class="py-op">,</tt> </tt>
<a name="L3383"></a><tt class="py-lineno">3383</tt>  <tt class="py-line">                <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-name">list</tt><tt class="py-op">,</tt> </tt>
<a name="L3384"></a><tt class="py-lineno">3384</tt>  <tt class="py-line">                <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-name">list</tt><tt class="py-op">,</tt> </tt>
<a name="L3385"></a><tt class="py-lineno">3385</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L3386"></a><tt class="py-lineno">3386</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.file_exists"></a><div id="CouchDBAdapter.file_exists-def"><a name="L3387"></a><tt class="py-lineno">3387</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.file_exists-toggle" onclick="return toggle('CouchDBAdapter.file_exists');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#file_exists">file_exists</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="CouchDBAdapter.file_open"></a><div id="CouchDBAdapter.file_open-def"><a name="L3388"></a><tt class="py-lineno">3388</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.file_open-toggle" onclick="return toggle('CouchDBAdapter.file_open');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#file_open">file_open</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt><tt class="py-op">=</tt><tt class="py-string">'rb'</tt><tt class="py-op">,</tt> <tt class="py-param">lock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="CouchDBAdapter.file_close"></a><div id="CouchDBAdapter.file_close-def"><a name="L3389"></a><tt class="py-lineno">3389</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.file_close-toggle" onclick="return toggle('CouchDBAdapter.file_close');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#file_close">file_close</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">fileobj</tt><tt class="py-op">,</tt> <tt class="py-param">unlock</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt>
</div><a name="L3390"></a><tt class="py-lineno">3390</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.expand"></a><div id="CouchDBAdapter.expand-def"><a name="L3391"></a><tt class="py-lineno">3391</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.expand-toggle" onclick="return toggle('CouchDBAdapter.expand');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#expand">expand</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">expression</tt><tt class="py-op">,</tt><tt class="py-param">field_type</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.expand-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.expand-expanded"><a name="L3392"></a><tt class="py-lineno">3392</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt id="link-1463" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-1463', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3393"></a><tt class="py-lineno">3393</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3394"></a><tt class="py-lineno">3394</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-string">"%s._id"</tt> <tt class="py-op">%</tt> <tt class="py-name">expression</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> </tt>
<a name="L3395"></a><tt class="py-lineno">3395</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1464" class="py-name"><a title="web2py.gluon.dal.BaseAdapter" class="py-name" href="#" onclick="return doclink('link-1464', 'BaseAdapter', 'link-825');">BaseAdapter</a></tt><tt class="py-op">.</tt><tt id="link-1465" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1465', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">expression</tt><tt class="py-op">,</tt><tt class="py-name">field_type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3396"></a><tt class="py-lineno">3396</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.AND"></a><div id="CouchDBAdapter.AND-def"><a name="L3397"></a><tt class="py-lineno">3397</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.AND-toggle" onclick="return toggle('CouchDBAdapter.AND');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#AND">AND</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.AND-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.AND-expanded"><a name="L3398"></a><tt class="py-lineno">3398</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s &amp;&amp; %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1466" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1466', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1467" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1467', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1468" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1468', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3399"></a><tt class="py-lineno">3399</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.OR"></a><div id="CouchDBAdapter.OR-def"><a name="L3400"></a><tt class="py-lineno">3400</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.OR-toggle" onclick="return toggle('CouchDBAdapter.OR');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#OR">OR</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.OR-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.OR-expanded"><a name="L3401"></a><tt class="py-lineno">3401</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s || %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1469" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1469', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1470" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1470', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1471" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1471', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3402"></a><tt class="py-lineno">3402</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.EQ"></a><div id="CouchDBAdapter.EQ-def"><a name="L3403"></a><tt class="py-lineno">3403</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.EQ-toggle" onclick="return toggle('CouchDBAdapter.EQ');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#EQ">EQ</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.EQ-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.EQ-expanded"><a name="L3404"></a><tt class="py-lineno">3404</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">second</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L3405"></a><tt class="py-lineno">3405</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'(%s == null)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1472" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1472', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1473" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1473', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3406"></a><tt class="py-lineno">3406</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s == %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1474" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1474', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1475" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1475', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1476" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1476', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1477" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1477', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3407"></a><tt class="py-lineno">3407</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.NE"></a><div id="CouchDBAdapter.NE-def"><a name="L3408"></a><tt class="py-lineno">3408</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.NE-toggle" onclick="return toggle('CouchDBAdapter.NE');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#NE">NE</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.NE-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.NE-expanded"><a name="L3409"></a><tt class="py-lineno">3409</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">second</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L3410"></a><tt class="py-lineno">3410</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'(%s != null)'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1478" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1478', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1479" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1479', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3411"></a><tt class="py-lineno">3411</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'(%s != %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1480" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1480', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1481" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1481', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1482" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1482', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">,</tt><tt id="link-1483" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1483', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3412"></a><tt class="py-lineno">3412</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.COMMA"></a><div id="CouchDBAdapter.COMMA-def"><a name="L3413"></a><tt class="py-lineno">3413</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.COMMA-toggle" onclick="return toggle('CouchDBAdapter.COMMA');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#COMMA">COMMA</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">first</tt><tt class="py-op">,</tt><tt class="py-param">second</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.COMMA-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.COMMA-expanded"><a name="L3414"></a><tt class="py-lineno">3414</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'%s + %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1484" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1484', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt id="link-1485" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1485', 'first', 'link-297');">first</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1486" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1486', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">second</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3415"></a><tt class="py-lineno">3415</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.represent"></a><div id="CouchDBAdapter.represent-def"><a name="L3416"></a><tt class="py-lineno">3416</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.represent-toggle" onclick="return toggle('CouchDBAdapter.represent');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#represent">represent</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">obj</tt><tt class="py-op">,</tt> <tt class="py-param">fieldtype</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.represent-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.represent-expanded"><a name="L3417"></a><tt class="py-lineno">3417</tt>  <tt class="py-line">        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt id="link-1487" class="py-name" targets="Class web2py.gluon.dal.NoSQLAdapter=web2py.gluon.dal.NoSQLAdapter-class.html"><a title="web2py.gluon.dal.NoSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1487', 'NoSQLAdapter', 'link-1487');">NoSQLAdapter</a></tt><tt class="py-op">.</tt><tt id="link-1488" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1488', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">obj</tt><tt class="py-op">,</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">)</tt> </tt>
<a name="L3418"></a><tt class="py-lineno">3418</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldtype</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L3419"></a><tt class="py-lineno">3419</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3420"></a><tt class="py-lineno">3420</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">repr</tt><tt class="py-op">(</tt><tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt><tt class="py-name">unicode</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">value</tt> <tt class="py-keyword">or</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt id="link-1489" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-1489', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3421"></a><tt class="py-lineno">3421</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.__init__"></a><div id="CouchDBAdapter.__init__-def"><a name="L3422"></a><tt class="py-lineno">3422</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.__init__-toggle" onclick="return toggle('CouchDBAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">=</tt><tt class="py-string">'couchdb://127.0.0.1:5984'</tt><tt class="py-op">,</tt> </tt>
<a name="L3423"></a><tt class="py-lineno">3423</tt>  <tt class="py-line">                 <tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L3424"></a><tt class="py-lineno">3424</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1490" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1490', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1491" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1491', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L3425"></a><tt class="py-lineno">3425</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.__init__-expanded"><a name="L3426"></a><tt class="py-lineno">3426</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L3427"></a><tt class="py-lineno">3427</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L3428"></a><tt class="py-lineno">3428</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">'couchdb'</tt> </tt>
<a name="L3429"></a><tt class="py-lineno">3429</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L3430"></a><tt class="py-lineno">3430</tt>  <tt class="py-line">        <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-string">'_lastsql'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L3431"></a><tt class="py-lineno">3431</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-string">'UTF-8'</tt> </tt>
<a name="L3432"></a><tt class="py-lineno">3432</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L3433"></a><tt class="py-lineno">3433</tt>  <tt class="py-line"> </tt>
<a name="L3434"></a><tt class="py-lineno">3434</tt>  <tt class="py-line">        <tt id="link-1492" class="py-name" targets="Method web2py.gluon.tools.Auth.url()=web2py.gluon.tools.Auth-class.html#url,Method web2py.gluon.tools.Crud.url()=web2py.gluon.tools.Crud-class.html#url"><a title="web2py.gluon.tools.Auth.url
web2py.gluon.tools.Crud.url" class="py-name" href="#" onclick="return doclink('link-1492', 'url', 'link-1492');">url</a></tt><tt class="py-op">=</tt><tt class="py-string">'http://'</tt><tt class="py-op">+</tt><tt class="py-name">uri</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L3435"></a><tt class="py-lineno">3435</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">url</tt><tt class="py-op">=</tt><tt id="link-1493" class="py-name"><a title="web2py.gluon.tools.Auth.url
web2py.gluon.tools.Crud.url" class="py-name" href="#" onclick="return doclink('link-1493', 'url', 'link-1492');">url</a></tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3436"></a><tt class="py-lineno">3436</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">couchdb</tt><tt class="py-op">.</tt><tt class="py-name">Server</tt><tt class="py-op">(</tt><tt id="link-1494" class="py-name"><a title="web2py.gluon.tools.Auth.url
web2py.gluon.tools.Crud.url" class="py-name" href="#" onclick="return doclink('link-1494', 'url', 'link-1492');">url</a></tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3437"></a><tt class="py-lineno">3437</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1495" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1495', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1496" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1496', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L3438"></a><tt class="py-lineno">3438</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.create_table"></a><div id="CouchDBAdapter.create_table-def"><a name="L3439"></a><tt class="py-lineno">3439</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.create_table-toggle" onclick="return toggle('CouchDBAdapter.create_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#create_table">create_table</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">,</tt> <tt class="py-param">migrate</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> <tt class="py-param">polymodel</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.create_table-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.create_table-expanded"><a name="L3440"></a><tt class="py-lineno">3440</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">migrate</tt><tt class="py-op">:</tt> </tt>
<a name="L3441"></a><tt class="py-lineno">3441</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3442"></a><tt class="py-lineno">3442</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">.</tt><tt id="link-1497" class="py-name" targets="Method web2py.gluon.tools.Crud.create()=web2py.gluon.tools.Crud-class.html#create"><a title="web2py.gluon.tools.Crud.create" class="py-name" href="#" onclick="return doclink('link-1497', 'create', 'link-1497');">create</a></tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L3443"></a><tt class="py-lineno">3443</tt>  <tt class="py-line">            <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L3444"></a><tt class="py-lineno">3444</tt>  <tt class="py-line">                <tt class="py-keyword">pass</tt> </tt>
</div><a name="L3445"></a><tt class="py-lineno">3445</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.insert"></a><div id="CouchDBAdapter.insert-def"><a name="L3446"></a><tt class="py-lineno">3446</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.insert-toggle" onclick="return toggle('CouchDBAdapter.insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#insert">insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.insert-expanded"><a name="L3447"></a><tt class="py-lineno">3447</tt>  <tt class="py-line">        <tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt id="link-1498" class="py-name" targets="Function web2py.gluon.dal.uuid2int()=web2py.gluon.dal-module.html#uuid2int"><a title="web2py.gluon.dal.uuid2int" class="py-name" href="#" onclick="return doclink('link-1498', 'uuid2int', 'link-1498');">uuid2int</a></tt><tt class="py-op">(</tt><tt id="link-1499" class="py-name"><a title="web2py.gluon.utils.web2py_uuid" class="py-name" href="#" onclick="return doclink('link-1499', 'web2py_uuid', 'link-14');">web2py_uuid</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3448"></a><tt class="py-lineno">3448</tt>  <tt class="py-line">        <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3449"></a><tt class="py-lineno">3449</tt>  <tt class="py-line">        <tt id="link-1500" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-1500', 'values', 'link-321');">values</a></tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt id="link-1501" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1501', 'k', 'link-189');">k</a></tt><tt class="py-op">.</tt><tt id="link-1502" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1502', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt id="link-1503" class="py-name"><a title="web2py.gluon.dal.NoSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1503', 'NoSQLAdapter', 'link-1487');">NoSQLAdapter</a></tt><tt class="py-op">.</tt><tt id="link-1504" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1504', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt id="link-1505" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1505', 'k', 'link-189');">k</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-1506" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1506', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L3450"></a><tt class="py-lineno">3450</tt>  <tt class="py-line">        <tt id="link-1507" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-1507', 'values', 'link-321');">values</a></tt><tt class="py-op">[</tt><tt class="py-string">'_id'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">)</tt> </tt>
<a name="L3451"></a><tt class="py-lineno">3451</tt>  <tt class="py-line">        <tt class="py-name">ctable</tt><tt class="py-op">.</tt><tt class="py-name">save</tt><tt class="py-op">(</tt><tt id="link-1508" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-1508', 'values', 'link-321');">values</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3452"></a><tt class="py-lineno">3452</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">id</tt> </tt>
</div><a name="L3453"></a><tt class="py-lineno">3453</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter._select"></a><div id="CouchDBAdapter._select-def"><a name="L3454"></a><tt class="py-lineno">3454</tt> <a class="py-toggle" href="#" id="CouchDBAdapter._select-toggle" onclick="return toggle('CouchDBAdapter._select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#_select">_select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter._select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter._select-expanded"><a name="L3455"></a><tt class="py-lineno">3455</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1509" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1509', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3456"></a><tt class="py-lineno">3456</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not Supported"</tt> </tt>
<a name="L3457"></a><tt class="py-lineno">3457</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-name">attributes</tt><tt class="py-op">.</tt><tt id="link-1510" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1510', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">-</tt><tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-string">'orderby'</tt><tt class="py-op">,</tt><tt class="py-string">'groupby'</tt><tt class="py-op">,</tt><tt class="py-string">'limitby'</tt><tt class="py-op">,</tt> </tt>
<a name="L3458"></a><tt class="py-lineno">3458</tt>  <tt class="py-line">                                               <tt class="py-string">'required'</tt><tt class="py-op">,</tt><tt class="py-string">'cache'</tt><tt class="py-op">,</tt><tt class="py-string">'left'</tt><tt class="py-op">,</tt> </tt>
<a name="L3459"></a><tt class="py-lineno">3459</tt>  <tt class="py-line">                                               <tt class="py-string">'distinct'</tt><tt class="py-op">,</tt><tt class="py-string">'having'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3460"></a><tt class="py-lineno">3460</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'invalid select attribute: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
<a name="L3461"></a><tt class="py-lineno">3461</tt>  <tt class="py-line">        <tt class="py-name">new_fields</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3462"></a><tt class="py-lineno">3462</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3463"></a><tt class="py-lineno">3463</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt><tt id="link-1511" class="py-name"><a title="web2py.gluon.dal.SQLALL" class="py-name" href="#" onclick="return doclink('link-1511', 'SQLALL', 'link-439');">SQLALL</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3464"></a><tt class="py-lineno">3464</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt> <tt class="py-op">+=</tt> <tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">table</tt> </tt>
<a name="L3465"></a><tt class="py-lineno">3465</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3466"></a><tt class="py-lineno">3466</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-1512" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1512', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> </tt>
<a name="L3467"></a><tt class="py-lineno">3467</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">uid</tt><tt class="py-op">(</tt><tt class="py-param">fd</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3468"></a><tt class="py-lineno">3468</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">fd</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">and</tt> <tt class="py-string">'_id'</tt> <tt class="py-keyword">or</tt> <tt class="py-name">fd</tt> </tt>
</div><a name="L3469"></a><tt class="py-lineno">3469</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">get</tt><tt class="py-op">(</tt><tt class="py-param">row</tt><tt class="py-op">,</tt><tt class="py-param">fd</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3470"></a><tt class="py-lineno">3470</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">fd</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">[</tt><tt class="py-string">'_id'</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">row</tt><tt class="py-op">.</tt><tt id="link-1513" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1513', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">fd</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3471"></a><tt class="py-lineno">3471</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">new_fields</tt> </tt>
<a name="L3472"></a><tt class="py-lineno">3472</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1514" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-1514', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3473"></a><tt class="py-lineno">3473</tt>  <tt class="py-line">        <tt class="py-name">fieldnames</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">.</tt><tt id="link-1515" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1515', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-name">fields</tt> <tt class="py-keyword">or</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3474"></a><tt class="py-lineno">3474</tt>  <tt class="py-line">        <tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt id="link-1516" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1516', 'k', 'link-189');">k</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-1517" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1517', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">fieldnames</tt><tt class="py-op">]</tt> </tt>
<a name="L3475"></a><tt class="py-lineno">3475</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt id="link-1518" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1518', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">uid</tt><tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fieldnames</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3476"></a><tt class="py-lineno">3476</tt>  <tt class="py-line">        <tt class="py-name">fn</tt><tt class="py-op">=</tt><tt class="py-string">"function(%(t)s){if(%(query)s)emit(%(order)s,[%(fields)s]);}"</tt> <tt class="py-op">%</tt>\ </tt>
<a name="L3477"></a><tt class="py-lineno">3477</tt>  <tt class="py-line">            <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">=</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L3478"></a><tt class="py-lineno">3478</tt>  <tt class="py-line">                 <tt class="py-name">query</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1519" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-1519', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L3479"></a><tt class="py-lineno">3479</tt>  <tt class="py-line">                 <tt class="py-name">order</tt><tt class="py-op">=</tt><tt class="py-string">'%s._id'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L3480"></a><tt class="py-lineno">3480</tt>  <tt class="py-line">                 <tt class="py-name">fields</tt><tt class="py-op">=</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L3481"></a><tt class="py-lineno">3481</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">fn</tt><tt class="py-op">,</tt> <tt class="py-name">colnames</tt> </tt>
</div><a name="L3482"></a><tt class="py-lineno">3482</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.select"></a><div id="CouchDBAdapter.select-def"><a name="L3483"></a><tt class="py-lineno">3483</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.select-toggle" onclick="return toggle('CouchDBAdapter.select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#select">select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.select-expanded"><a name="L3484"></a><tt class="py-lineno">3484</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1520" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1520', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3485"></a><tt class="py-lineno">3485</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not Supported"</tt> </tt>
<a name="L3486"></a><tt class="py-lineno">3486</tt>  <tt class="py-line">        <tt class="py-name">fn</tt><tt class="py-op">,</tt> <tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1521" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._select
web2py.gluon.dal.CouchDBAdapter._select
web2py.gluon.dal.NoSQLAdapter._select
web2py.gluon.dal.Set._select" class="py-name" href="#" onclick="return doclink('link-1521', '_select', 'link-536');">_select</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt><tt class="py-name">attributes</tt><tt class="py-op">)</tt> </tt>
<a name="L3487"></a><tt class="py-lineno">3487</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">colnames</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L3488"></a><tt class="py-lineno">3488</tt>  <tt class="py-line">        <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3489"></a><tt class="py-lineno">3489</tt>  <tt class="py-line">        <tt id="link-1522" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1522', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">cols</tt><tt class="py-op">[</tt><tt class="py-string">'value'</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">cols</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ctable</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">(</tt><tt class="py-name">fn</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3490"></a><tt class="py-lineno">3490</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1523" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.parse
web2py.gluon.template.TemplateParser.parse" class="py-name" href="#" onclick="return doclink('link-1523', 'parse', 'link-550');">parse</a></tt><tt class="py-op">(</tt><tt id="link-1524" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1524', 'rows', 'link-539');">rows</a></tt><tt class="py-op">,</tt> <tt class="py-name">colnames</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3491"></a><tt class="py-lineno">3491</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.delete"></a><div id="CouchDBAdapter.delete-def"><a name="L3492"></a><tt class="py-lineno">3492</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.delete-toggle" onclick="return toggle('CouchDBAdapter.delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#delete">delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.delete-expanded"><a name="L3493"></a><tt class="py-lineno">3493</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1525" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1525', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3494"></a><tt class="py-lineno">3494</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not Supported"</tt> </tt>
<a name="L3495"></a><tt class="py-lineno">3495</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-1526" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1526', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">==</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1527" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EQ
web2py.gluon.dal.CouchDBAdapter.EQ
web2py.gluon.dal.GoogleDatastoreAdapter.EQ" class="py-name" href="#" onclick="return doclink('link-1527', 'EQ', 'link-1358');">EQ</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3496"></a><tt class="py-lineno">3496</tt>  <tt class="py-line">            <tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> </tt>
<a name="L3497"></a><tt class="py-lineno">3497</tt>  <tt class="py-line">            <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-1528" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1528', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> </tt>
<a name="L3498"></a><tt class="py-lineno">3498</tt>  <tt class="py-line">            <tt class="py-keyword">assert</tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt> <tt class="py-op">==</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-1529" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1529', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L3499"></a><tt class="py-lineno">3499</tt>  <tt class="py-line">            <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3500"></a><tt class="py-lineno">3500</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3501"></a><tt class="py-lineno">3501</tt>  <tt class="py-line">                <tt class="py-keyword">del</tt> <tt class="py-name">ctable</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3502"></a><tt class="py-lineno">3502</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-number">1</tt> </tt>
<a name="L3503"></a><tt class="py-lineno">3503</tt>  <tt class="py-line">            <tt class="py-keyword">except</tt> <tt class="py-name">couchdb</tt><tt class="py-op">.</tt><tt id="link-1530" class="py-name" targets="Module web2py.gluon.http=web2py.gluon.http-module.html"><a title="web2py.gluon.http" class="py-name" href="#" onclick="return doclink('link-1530', 'http', 'link-1530');">http</a></tt><tt class="py-op">.</tt><tt class="py-name">ResourceNotFound</tt><tt class="py-op">:</tt> </tt>
<a name="L3504"></a><tt class="py-lineno">3504</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-number">0</tt> </tt>
<a name="L3505"></a><tt class="py-lineno">3505</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3506"></a><tt class="py-lineno">3506</tt>  <tt class="py-line">            <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1531" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-1531', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3507"></a><tt class="py-lineno">3507</tt>  <tt class="py-line">            <tt id="link-1532" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1532', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1533" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1533', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L3508"></a><tt class="py-lineno">3508</tt>  <tt class="py-line">            <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3509"></a><tt class="py-lineno">3509</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">row</tt> <tt class="py-keyword">in</tt> <tt id="link-1534" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1534', 'rows', 'link-539');">rows</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3510"></a><tt class="py-lineno">3510</tt>  <tt class="py-line">                <tt class="py-keyword">del</tt> <tt class="py-name">ctable</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">.</tt><tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3511"></a><tt class="py-lineno">3511</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1535" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1535', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-1536" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1536', 'rows', 'link-539');">rows</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L3512"></a><tt class="py-lineno">3512</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.update"></a><div id="CouchDBAdapter.update-def"><a name="L3513"></a><tt class="py-lineno">3513</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.update-toggle" onclick="return toggle('CouchDBAdapter.update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#update">update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.update-expanded"><a name="L3514"></a><tt class="py-lineno">3514</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1537" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1537', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3515"></a><tt class="py-lineno">3515</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not Supported"</tt> </tt>
<a name="L3516"></a><tt class="py-lineno">3516</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-1538" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1538', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">==</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1539" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EQ
web2py.gluon.dal.CouchDBAdapter.EQ
web2py.gluon.dal.GoogleDatastoreAdapter.EQ" class="py-name" href="#" onclick="return doclink('link-1539', 'EQ', 'link-1358');">EQ</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3517"></a><tt class="py-lineno">3517</tt>  <tt class="py-line">            <tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> </tt>
<a name="L3518"></a><tt class="py-lineno">3518</tt>  <tt class="py-line">            <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt id="link-1540" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1540', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> </tt>
<a name="L3519"></a><tt class="py-lineno">3519</tt>  <tt class="py-line">            <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3520"></a><tt class="py-lineno">3520</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3521"></a><tt class="py-lineno">3521</tt>  <tt class="py-line">                <tt class="py-name">doc</tt> <tt class="py-op">=</tt> <tt class="py-name">ctable</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3522"></a><tt class="py-lineno">3522</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-name">value</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3523"></a><tt class="py-lineno">3523</tt>  <tt class="py-line">                    <tt class="py-name">doc</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-1541" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1541', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-1542" class="py-name"><a title="web2py.gluon.dal.NoSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1542', 'NoSQLAdapter', 'link-1487');">NoSQLAdapter</a></tt><tt class="py-op">.</tt><tt id="link-1543" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1543', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">value</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-1544" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1544', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
<a name="L3524"></a><tt class="py-lineno">3524</tt>  <tt class="py-line">                <tt class="py-name">ctable</tt><tt class="py-op">.</tt><tt class="py-name">save</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">)</tt> </tt>
<a name="L3525"></a><tt class="py-lineno">3525</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-number">1</tt> </tt>
<a name="L3526"></a><tt class="py-lineno">3526</tt>  <tt class="py-line">            <tt class="py-keyword">except</tt> <tt class="py-name">couchdb</tt><tt class="py-op">.</tt><tt id="link-1545" class="py-name"><a title="web2py.gluon.http" class="py-name" href="#" onclick="return doclink('link-1545', 'http', 'link-1530');">http</a></tt><tt class="py-op">.</tt><tt class="py-name">ResourceNotFound</tt><tt class="py-op">:</tt> </tt>
<a name="L3527"></a><tt class="py-lineno">3527</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-number">0</tt> </tt>
<a name="L3528"></a><tt class="py-lineno">3528</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3529"></a><tt class="py-lineno">3529</tt>  <tt class="py-line">            <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1546" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-1546', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3530"></a><tt class="py-lineno">3530</tt>  <tt class="py-line">            <tt id="link-1547" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1547', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1548" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1548', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L3531"></a><tt class="py-lineno">3531</tt>  <tt class="py-line">            <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3532"></a><tt class="py-lineno">3532</tt>  <tt class="py-line">            <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3533"></a><tt class="py-lineno">3533</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">row</tt> <tt class="py-keyword">in</tt> <tt id="link-1549" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1549', 'rows', 'link-539');">rows</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3534"></a><tt class="py-lineno">3534</tt>  <tt class="py-line">                <tt class="py-name">doc</tt> <tt class="py-op">=</tt> <tt class="py-name">ctable</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">.</tt><tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L3535"></a><tt class="py-lineno">3535</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-name">value</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L3536"></a><tt class="py-lineno">3536</tt>  <tt class="py-line">                    <tt class="py-name">doc</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-1550" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1550', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-1551" class="py-name"><a title="web2py.gluon.dal.NoSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1551', 'NoSQLAdapter', 'link-1487');">NoSQLAdapter</a></tt><tt class="py-op">.</tt><tt id="link-1552" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1552', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">value</tt><tt class="py-op">,</tt><tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-1553" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1553', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
<a name="L3537"></a><tt class="py-lineno">3537</tt>  <tt class="py-line">                <tt class="py-name">ctable</tt><tt class="py-op">.</tt><tt class="py-name">save</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">)</tt> </tt>
<a name="L3538"></a><tt class="py-lineno">3538</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1554" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1554', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-1555" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1555', 'rows', 'link-539');">rows</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L3539"></a><tt class="py-lineno">3539</tt>  <tt class="py-line"> </tt>
<a name="CouchDBAdapter.count"></a><div id="CouchDBAdapter.count-def"><a name="L3540"></a><tt class="py-lineno">3540</tt> <a class="py-toggle" href="#" id="CouchDBAdapter.count-toggle" onclick="return toggle('CouchDBAdapter.count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.CouchDBAdapter-class.html#count">count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="CouchDBAdapter.count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="CouchDBAdapter.count-expanded"><a name="L3541"></a><tt class="py-lineno">3541</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">distinct</tt><tt class="py-op">:</tt> </tt>
<a name="L3542"></a><tt class="py-lineno">3542</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"COUNT DISTINCT not supported"</tt> </tt>
<a name="L3543"></a><tt class="py-lineno">3543</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1556" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-1556', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3544"></a><tt class="py-lineno">3544</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not Supported"</tt> </tt>
<a name="L3545"></a><tt class="py-lineno">3545</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1557" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-1557', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L3546"></a><tt class="py-lineno">3546</tt>  <tt class="py-line">        <tt id="link-1558" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1558', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1559" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1559', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L3547"></a><tt class="py-lineno">3547</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1560" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1560', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-1561" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-1561', 'rows', 'link-539');">rows</a></tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L3548"></a><tt class="py-lineno">3548</tt>  <tt class="py-line"> </tt>
<a name="cleanup"></a><div id="cleanup-def"><a name="L3549"></a><tt class="py-lineno">3549</tt> <a class="py-toggle" href="#" id="cleanup-toggle" onclick="return toggle('cleanup');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#cleanup">cleanup</a><tt class="py-op">(</tt><tt class="py-param">text</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="cleanup-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="cleanup-expanded"><a name="L3550"></a><tt class="py-lineno">3550</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L3551"></a><tt class="py-lineno">3551</tt>  <tt class="py-line"><tt class="py-docstring">    validates that the given text is clean: only contains [0-9a-zA-Z_]</tt> </tt>
<a name="L3552"></a><tt class="py-lineno">3552</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L3553"></a><tt class="py-lineno">3553</tt>  <tt class="py-line"> </tt>
<a name="L3554"></a><tt class="py-lineno">3554</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'[^0-9a-zA-Z_]'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">findall</tt><tt class="py-op">(</tt><tt class="py-name">text</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3555"></a><tt class="py-lineno">3555</tt>  <tt class="py-line">        <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L3556"></a><tt class="py-lineno">3556</tt>  <tt class="py-line">            <tt class="py-string">'only [0-9a-zA-Z_] allowed in table and field names, received %s'</tt> \ </tt>
<a name="L3557"></a><tt class="py-lineno">3557</tt>  <tt class="py-line">            <tt class="py-op">%</tt> <tt class="py-name">text</tt> </tt>
<a name="L3558"></a><tt class="py-lineno">3558</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">text</tt> </tt>
</div><a name="L3559"></a><tt class="py-lineno">3559</tt>  <tt class="py-line"> </tt>
<a name="L3560"></a><tt class="py-lineno">3560</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter"></a><div id="MongoDBAdapter-def"><a name="L3561"></a><tt class="py-lineno">3561</tt> <a class="py-toggle" href="#" id="MongoDBAdapter-toggle" onclick="return toggle('MongoDBAdapter');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html">MongoDBAdapter</a><tt class="py-op">(</tt><tt class="py-base-class">NoSQLAdapter</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="MongoDBAdapter-expanded"><a name="L3562"></a><tt class="py-lineno">3562</tt>  <tt class="py-line">    <tt id="link-1562" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.uploads_in_blob
web2py.gluon.dal.CouchDBAdapter.uploads_in_blob
web2py.gluon.dal.GoogleDatastoreAdapter.uploads_in_blob
web2py.gluon.dal.MongoDBAdapter.uploads_in_blob" class="py-name" href="#" onclick="return doclink('link-1562', 'uploads_in_blob', 'link-164');">uploads_in_blob</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L3563"></a><tt class="py-lineno">3563</tt>  <tt class="py-line">    <tt id="link-1563" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.types
web2py.gluon.dal.CouchDBAdapter.types
web2py.gluon.dal.DB2Adapter.types
web2py.gluon.dal.FireBirdAdapter.types
web2py.gluon.dal.GoogleDatastoreAdapter.types
web2py.gluon.dal.InformixAdapter.types
web2py.gluon.dal.IngresAdapter.types
web2py.gluon.dal.IngresUnicodeAdapter.types
web2py.gluon.dal.MSSQL2Adapter.types
web2py.gluon.dal.MSSQLAdapter.types
web2py.gluon.dal.MongoDBAdapter.types
web2py.gluon.dal.MySQLAdapter.types
web2py.gluon.dal.OracleAdapter.types
web2py.gluon.dal.PostgreSQLAdapter.types
web2py.gluon.dal.SAPDBAdapter.types
web2py.gluon.dal.TeradataAdapter.types" class="py-name" href="#" onclick="return doclink('link-1563', 'types', 'link-2');">types</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L3564"></a><tt class="py-lineno">3564</tt>  <tt class="py-line">                <tt class="py-string">'boolean'</tt><tt class="py-op">:</tt> <tt class="py-name">bool</tt><tt class="py-op">,</tt> </tt>
<a name="L3565"></a><tt class="py-lineno">3565</tt>  <tt class="py-line">                <tt class="py-string">'string'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3566"></a><tt class="py-lineno">3566</tt>  <tt class="py-line">                <tt class="py-string">'text'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3567"></a><tt class="py-lineno">3567</tt>  <tt class="py-line">                <tt class="py-string">'password'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3568"></a><tt class="py-lineno">3568</tt>  <tt class="py-line">                <tt class="py-string">'blob'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3569"></a><tt class="py-lineno">3569</tt>  <tt class="py-line">                <tt class="py-string">'upload'</tt><tt class="py-op">:</tt> <tt class="py-name">str</tt><tt class="py-op">,</tt> </tt>
<a name="L3570"></a><tt class="py-lineno">3570</tt>  <tt class="py-line">                <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> <tt class="py-name">long</tt><tt class="py-op">,</tt> </tt>
<a name="L3571"></a><tt class="py-lineno">3571</tt>  <tt class="py-line">                <tt class="py-string">'double'</tt><tt class="py-op">:</tt> <tt class="py-name">float</tt><tt class="py-op">,</tt> </tt>
<a name="L3572"></a><tt class="py-lineno">3572</tt>  <tt class="py-line">                <tt class="py-string">'date'</tt><tt class="py-op">:</tt> <tt id="link-1564" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1564', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1565" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1565', 'date', 'link-604');">date</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3573"></a><tt class="py-lineno">3573</tt>  <tt class="py-line">                <tt class="py-string">'time'</tt><tt class="py-op">:</tt> <tt id="link-1566" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1566', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1567" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-1567', 'time', 'link-4');">time</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3574"></a><tt class="py-lineno">3574</tt>  <tt class="py-line">                <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> <tt id="link-1568" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1568', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1569" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1569', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3575"></a><tt class="py-lineno">3575</tt>  <tt class="py-line">                <tt class="py-string">'id'</tt><tt class="py-op">:</tt> <tt class="py-name">long</tt><tt class="py-op">,</tt> </tt>
<a name="L3576"></a><tt class="py-lineno">3576</tt>  <tt class="py-line">                <tt class="py-string">'reference'</tt><tt class="py-op">:</tt> <tt class="py-name">long</tt><tt class="py-op">,</tt> </tt>
<a name="L3577"></a><tt class="py-lineno">3577</tt>  <tt class="py-line">                <tt class="py-string">'list:string'</tt><tt class="py-op">:</tt> <tt class="py-name">list</tt><tt class="py-op">,</tt> </tt>
<a name="L3578"></a><tt class="py-lineno">3578</tt>  <tt class="py-line">                <tt class="py-string">'list:integer'</tt><tt class="py-op">:</tt> <tt class="py-name">list</tt><tt class="py-op">,</tt> </tt>
<a name="L3579"></a><tt class="py-lineno">3579</tt>  <tt class="py-line">                <tt class="py-string">'list:reference'</tt><tt class="py-op">:</tt> <tt class="py-name">list</tt><tt class="py-op">,</tt> </tt>
<a name="L3580"></a><tt class="py-lineno">3580</tt>  <tt class="py-line">        <tt class="py-op">}</tt> </tt>
<a name="L3581"></a><tt class="py-lineno">3581</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter.__init__"></a><div id="MongoDBAdapter.__init__-def"><a name="L3582"></a><tt class="py-lineno">3582</tt> <a class="py-toggle" href="#" id="MongoDBAdapter.__init__-toggle" onclick="return toggle('MongoDBAdapter.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">db</tt><tt class="py-op">,</tt><tt class="py-param">uri</tt><tt class="py-op">=</tt><tt class="py-string">'mongodb://127.0.0.1:5984/db'</tt><tt class="py-op">,</tt> </tt>
<a name="L3583"></a><tt class="py-lineno">3583</tt>  <tt class="py-line">                 <tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">db_codec</tt> <tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> </tt>
<a name="L3584"></a><tt class="py-lineno">3584</tt>  <tt class="py-line">                 <tt class="py-param">credential_decoder</tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-1570" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1570', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt><tt id="link-1571" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1571', 'x', 'link-114');">x</a></tt><tt class="py-op">,</tt> <tt class="py-name">driver_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> </tt>
<a name="L3585"></a><tt class="py-lineno">3585</tt>  <tt class="py-line">                    <tt class="py-name">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MongoDBAdapter.__init__-expanded"><a name="L3586"></a><tt class="py-lineno">3586</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L3587"></a><tt class="py-lineno">3587</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L3588"></a><tt class="py-lineno">3588</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt> <tt class="py-op">=</tt> <tt class="py-string">'mongodb'</tt> </tt>
<a name="L3589"></a><tt class="py-lineno">3589</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt> <tt class="py-op">=</tt> <tt class="py-name">folder</tt> </tt>
<a name="L3590"></a><tt class="py-lineno">3590</tt>  <tt class="py-line">        <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-string">'_lastsql'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L3591"></a><tt class="py-lineno">3591</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db_codec</tt> <tt class="py-op">=</tt> <tt class="py-string">'UTF-8'</tt> </tt>
<a name="L3592"></a><tt class="py-lineno">3592</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L3593"></a><tt class="py-lineno">3593</tt>  <tt class="py-line"> </tt>
<a name="L3594"></a><tt class="py-lineno">3594</tt>  <tt class="py-line">        <tt id="link-1572" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1572', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^(?P&lt;host&gt;[^\:/]+)(\:(?P&lt;port&gt;[0-9]+))?/(?P&lt;db&gt;.+)$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3595"></a><tt class="py-lineno">3595</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1573" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1573', 'm', 'link-638');">m</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3596"></a><tt class="py-lineno">3596</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Invalid URI string in DAL: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri</tt> </tt>
<a name="L3597"></a><tt class="py-lineno">3597</tt>  <tt class="py-line">        <tt class="py-name">host</tt> <tt class="py-op">=</tt> <tt id="link-1574" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1574', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'host'</tt><tt class="py-op">)</tt> </tt>
<a name="L3598"></a><tt class="py-lineno">3598</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">host</tt><tt class="py-op">:</tt> </tt>
<a name="L3599"></a><tt class="py-lineno">3599</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'mongodb: host name required'</tt> </tt>
<a name="L3600"></a><tt class="py-lineno">3600</tt>  <tt class="py-line">        <tt class="py-name">dbname</tt> <tt class="py-op">=</tt> <tt id="link-1575" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1575', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'db'</tt><tt class="py-op">)</tt> </tt>
<a name="L3601"></a><tt class="py-lineno">3601</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">dbname</tt><tt class="py-op">:</tt> </tt>
<a name="L3602"></a><tt class="py-lineno">3602</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'mongodb: db name required'</tt> </tt>
<a name="L3603"></a><tt class="py-lineno">3603</tt>  <tt class="py-line">        <tt class="py-name">port</tt> <tt class="py-op">=</tt> <tt id="link-1576" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-1576', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'port'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-number">27017</tt> </tt>
<a name="L3604"></a><tt class="py-lineno">3604</tt>  <tt class="py-line">        <tt class="py-name">driver_args</tt><tt class="py-op">.</tt><tt id="link-1577" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-1577', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">host</tt><tt class="py-op">=</tt><tt class="py-name">host</tt><tt class="py-op">,</tt><tt class="py-name">port</tt><tt class="py-op">=</tt><tt class="py-name">port</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3605"></a><tt class="py-lineno">3605</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">connect</tt><tt class="py-op">(</tt><tt class="py-param">dbname</tt><tt class="py-op">=</tt><tt class="py-name">dbname</tt><tt class="py-op">,</tt><tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3606"></a><tt class="py-lineno">3606</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">pymongo</tt><tt class="py-op">.</tt><tt id="link-1578" class="py-name"><a title="web2py.gluon.rocket.Connection" class="py-name" href="#" onclick="return doclink('link-1578', 'Connection', 'link-695');">Connection</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">driver_args</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-name">dbname</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3607"></a><tt class="py-lineno">3607</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1579" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.pool_connection" class="py-name" href="#" onclick="return doclink('link-1579', 'pool_connection', 'link-696');">pool_connection</a></tt><tt class="py-op">(</tt><tt id="link-1580" class="py-name"><a title="web2py.gluon.globals.Session.connect" class="py-name" href="#" onclick="return doclink('link-1580', 'connect', 'link-697');">connect</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L3608"></a><tt class="py-lineno">3608</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter.insert"></a><div id="MongoDBAdapter.insert-def"><a name="L3609"></a><tt class="py-lineno">3609</tt> <a class="py-toggle" href="#" id="MongoDBAdapter.insert-toggle" onclick="return toggle('MongoDBAdapter.insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html#insert">insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter.insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MongoDBAdapter.insert-expanded"><a name="L3610"></a><tt class="py-lineno">3610</tt>  <tt class="py-line">        <tt class="py-name">ctable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">connection</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L3611"></a><tt class="py-lineno">3611</tt>  <tt class="py-line">        <tt id="link-1581" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-1581', 'values', 'link-321');">values</a></tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt id="link-1582" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1582', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1583" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1583', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">table</tt><tt class="py-op">[</tt><tt id="link-1584" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1584', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-1585" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1585', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L3612"></a><tt class="py-lineno">3612</tt>  <tt class="py-line">        <tt class="py-name">ctable</tt><tt class="py-op">.</tt><tt id="link-1586" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-1586', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt id="link-1587" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-1587', 'values', 'link-321');">values</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3613"></a><tt class="py-lineno">3613</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1588" class="py-name"><a title="web2py.gluon.dal.uuid2int" class="py-name" href="#" onclick="return doclink('link-1588', 'uuid2int', 'link-1498');">uuid2int</a></tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3614"></a><tt class="py-lineno">3614</tt>  <tt class="py-line"> </tt>
<a name="L3615"></a><tt class="py-lineno">3615</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter.count"></a><div id="MongoDBAdapter.count-def"><a name="L3616"></a><tt class="py-lineno">3616</tt> <a class="py-toggle" href="#" id="MongoDBAdapter.count-toggle" onclick="return toggle('MongoDBAdapter.count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html#count">count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter.count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MongoDBAdapter.count-expanded"><a name="L3617"></a><tt class="py-lineno">3617</tt>  <tt class="py-line">        <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not implemented"</tt> </tt>
</div><a name="L3618"></a><tt class="py-lineno">3618</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter.select"></a><div id="MongoDBAdapter.select-def"><a name="L3619"></a><tt class="py-lineno">3619</tt> <a class="py-toggle" href="#" id="MongoDBAdapter.select-toggle" onclick="return toggle('MongoDBAdapter.select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html#select">select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter.select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MongoDBAdapter.select-expanded"><a name="L3620"></a><tt class="py-lineno">3620</tt>  <tt class="py-line">        <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not implemented"</tt> </tt>
</div><a name="L3621"></a><tt class="py-lineno">3621</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter.delete"></a><div id="MongoDBAdapter.delete-def"><a name="L3622"></a><tt class="py-lineno">3622</tt> <a class="py-toggle" href="#" id="MongoDBAdapter.delete-toggle" onclick="return toggle('MongoDBAdapter.delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html#delete">delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter.delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MongoDBAdapter.delete-expanded"><a name="L3623"></a><tt class="py-lineno">3623</tt>  <tt class="py-line">        <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not implemented"</tt> </tt>
</div><a name="L3624"></a><tt class="py-lineno">3624</tt>  <tt class="py-line"> </tt>
<a name="MongoDBAdapter.update"></a><div id="MongoDBAdapter.update-def"><a name="L3625"></a><tt class="py-lineno">3625</tt> <a class="py-toggle" href="#" id="MongoDBAdapter.update-toggle" onclick="return toggle('MongoDBAdapter.update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.MongoDBAdapter-class.html#update">update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">tablename</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="MongoDBAdapter.update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="MongoDBAdapter.update-expanded"><a name="L3626"></a><tt class="py-lineno">3626</tt>  <tt class="py-line">        <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Not implemented"</tt> </tt>
</div></div><a name="L3627"></a><tt class="py-lineno">3627</tt>  <tt class="py-line"> </tt>
<a name="L3628"></a><tt class="py-lineno">3628</tt>  <tt class="py-line"> </tt>
<a name="L3629"></a><tt class="py-lineno">3629</tt>  <tt class="py-line"><tt class="py-comment">########################################################################</tt> </tt>
<a name="L3630"></a><tt class="py-lineno">3630</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># end of adapters</tt> </tt>
<a name="L3631"></a><tt class="py-lineno">3631</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">########################################################################</tt> </tt>
<a name="L3632"></a><tt class="py-lineno">3632</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L3633"></a><tt class="py-lineno">3633</tt>  <tt class="py-line"><tt id="link-1589" class="py-name" targets="Variable web2py.gluon.dal.ADAPTERS=web2py.gluon.dal-module.html#ADAPTERS,Variable web2py.gluon.reserved_sql_keywords.ADAPTERS=web2py.gluon.reserved_sql_keywords-module.html#ADAPTERS"><a title="web2py.gluon.dal.ADAPTERS
web2py.gluon.reserved_sql_keywords.ADAPTERS" class="py-name" href="#" onclick="return doclink('link-1589', 'ADAPTERS', 'link-1589');">ADAPTERS</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt>
<a name="L3634"></a><tt class="py-lineno">3634</tt>  <tt class="py-line">    <tt class="py-string">'sqlite'</tt><tt class="py-op">:</tt> <tt id="link-1590" class="py-name"><a title="web2py.gluon.dal.SQLiteAdapter" class="py-name" href="#" onclick="return doclink('link-1590', 'SQLiteAdapter', 'link-698');">SQLiteAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3635"></a><tt class="py-lineno">3635</tt>  <tt class="py-line">    <tt class="py-string">'sqlite:memory'</tt><tt class="py-op">:</tt> <tt id="link-1591" class="py-name"><a title="web2py.gluon.dal.SQLiteAdapter" class="py-name" href="#" onclick="return doclink('link-1591', 'SQLiteAdapter', 'link-698');">SQLiteAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3636"></a><tt class="py-lineno">3636</tt>  <tt class="py-line">    <tt class="py-string">'mysql'</tt><tt class="py-op">:</tt> <tt id="link-1592" class="py-name" targets="Class web2py.gluon.dal.MySQLAdapter=web2py.gluon.dal.MySQLAdapter-class.html"><a title="web2py.gluon.dal.MySQLAdapter" class="py-name" href="#" onclick="return doclink('link-1592', 'MySQLAdapter', 'link-1592');">MySQLAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3637"></a><tt class="py-lineno">3637</tt>  <tt class="py-line">    <tt class="py-string">'postgres'</tt><tt class="py-op">:</tt> <tt id="link-1593" class="py-name" targets="Class web2py.gluon.dal.PostgreSQLAdapter=web2py.gluon.dal.PostgreSQLAdapter-class.html"><a title="web2py.gluon.dal.PostgreSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1593', 'PostgreSQLAdapter', 'link-1593');">PostgreSQLAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3638"></a><tt class="py-lineno">3638</tt>  <tt class="py-line">    <tt class="py-string">'oracle'</tt><tt class="py-op">:</tt> <tt id="link-1594" class="py-name" targets="Class web2py.gluon.dal.OracleAdapter=web2py.gluon.dal.OracleAdapter-class.html"><a title="web2py.gluon.dal.OracleAdapter" class="py-name" href="#" onclick="return doclink('link-1594', 'OracleAdapter', 'link-1594');">OracleAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3639"></a><tt class="py-lineno">3639</tt>  <tt class="py-line">    <tt class="py-string">'mssql'</tt><tt class="py-op">:</tt> <tt id="link-1595" class="py-name" targets="Class web2py.gluon.dal.MSSQLAdapter=web2py.gluon.dal.MSSQLAdapter-class.html"><a title="web2py.gluon.dal.MSSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1595', 'MSSQLAdapter', 'link-1595');">MSSQLAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3640"></a><tt class="py-lineno">3640</tt>  <tt class="py-line">    <tt class="py-string">'mssql2'</tt><tt class="py-op">:</tt> <tt id="link-1596" class="py-name" targets="Class web2py.gluon.dal.MSSQL2Adapter=web2py.gluon.dal.MSSQL2Adapter-class.html"><a title="web2py.gluon.dal.MSSQL2Adapter" class="py-name" href="#" onclick="return doclink('link-1596', 'MSSQL2Adapter', 'link-1596');">MSSQL2Adapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3641"></a><tt class="py-lineno">3641</tt>  <tt class="py-line">    <tt class="py-string">'db2'</tt><tt class="py-op">:</tt> <tt id="link-1597" class="py-name" targets="Class web2py.gluon.dal.DB2Adapter=web2py.gluon.dal.DB2Adapter-class.html"><a title="web2py.gluon.dal.DB2Adapter" class="py-name" href="#" onclick="return doclink('link-1597', 'DB2Adapter', 'link-1597');">DB2Adapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3642"></a><tt class="py-lineno">3642</tt>  <tt class="py-line">    <tt class="py-string">'teradata'</tt><tt class="py-op">:</tt> <tt id="link-1598" class="py-name" targets="Class web2py.gluon.dal.TeradataAdapter=web2py.gluon.dal.TeradataAdapter-class.html"><a title="web2py.gluon.dal.TeradataAdapter" class="py-name" href="#" onclick="return doclink('link-1598', 'TeradataAdapter', 'link-1598');">TeradataAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3643"></a><tt class="py-lineno">3643</tt>  <tt class="py-line">    <tt class="py-string">'informix'</tt><tt class="py-op">:</tt> <tt id="link-1599" class="py-name" targets="Class web2py.gluon.dal.InformixAdapter=web2py.gluon.dal.InformixAdapter-class.html"><a title="web2py.gluon.dal.InformixAdapter" class="py-name" href="#" onclick="return doclink('link-1599', 'InformixAdapter', 'link-1599');">InformixAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3644"></a><tt class="py-lineno">3644</tt>  <tt class="py-line">    <tt class="py-string">'firebird'</tt><tt class="py-op">:</tt> <tt id="link-1600" class="py-name" targets="Class web2py.gluon.dal.FireBirdAdapter=web2py.gluon.dal.FireBirdAdapter-class.html"><a title="web2py.gluon.dal.FireBirdAdapter" class="py-name" href="#" onclick="return doclink('link-1600', 'FireBirdAdapter', 'link-1600');">FireBirdAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3645"></a><tt class="py-lineno">3645</tt>  <tt class="py-line">    <tt class="py-string">'firebird_embedded'</tt><tt class="py-op">:</tt> <tt id="link-1601" class="py-name"><a title="web2py.gluon.dal.FireBirdAdapter" class="py-name" href="#" onclick="return doclink('link-1601', 'FireBirdAdapter', 'link-1600');">FireBirdAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3646"></a><tt class="py-lineno">3646</tt>  <tt class="py-line">    <tt class="py-string">'ingres'</tt><tt class="py-op">:</tt> <tt id="link-1602" class="py-name" targets="Class web2py.gluon.dal.IngresAdapter=web2py.gluon.dal.IngresAdapter-class.html"><a title="web2py.gluon.dal.IngresAdapter" class="py-name" href="#" onclick="return doclink('link-1602', 'IngresAdapter', 'link-1602');">IngresAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3647"></a><tt class="py-lineno">3647</tt>  <tt class="py-line">    <tt class="py-string">'ingresu'</tt><tt class="py-op">:</tt> <tt id="link-1603" class="py-name" targets="Class web2py.gluon.dal.IngresUnicodeAdapter=web2py.gluon.dal.IngresUnicodeAdapter-class.html"><a title="web2py.gluon.dal.IngresUnicodeAdapter" class="py-name" href="#" onclick="return doclink('link-1603', 'IngresUnicodeAdapter', 'link-1603');">IngresUnicodeAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3648"></a><tt class="py-lineno">3648</tt>  <tt class="py-line">    <tt class="py-string">'sapdb'</tt><tt class="py-op">:</tt> <tt id="link-1604" class="py-name" targets="Class web2py.gluon.dal.SAPDBAdapter=web2py.gluon.dal.SAPDBAdapter-class.html"><a title="web2py.gluon.dal.SAPDBAdapter" class="py-name" href="#" onclick="return doclink('link-1604', 'SAPDBAdapter', 'link-1604');">SAPDBAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3649"></a><tt class="py-lineno">3649</tt>  <tt class="py-line">    <tt class="py-string">'cubrid'</tt><tt class="py-op">:</tt> <tt id="link-1605" class="py-name" targets="Class web2py.gluon.dal.CubridAdapter=web2py.gluon.dal.CubridAdapter-class.html"><a title="web2py.gluon.dal.CubridAdapter" class="py-name" href="#" onclick="return doclink('link-1605', 'CubridAdapter', 'link-1605');">CubridAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3650"></a><tt class="py-lineno">3650</tt>  <tt class="py-line">    <tt class="py-string">'jdbc:sqlite'</tt><tt class="py-op">:</tt> <tt id="link-1606" class="py-name" targets="Class web2py.gluon.dal.JDBCSQLiteAdapter=web2py.gluon.dal.JDBCSQLiteAdapter-class.html"><a title="web2py.gluon.dal.JDBCSQLiteAdapter" class="py-name" href="#" onclick="return doclink('link-1606', 'JDBCSQLiteAdapter', 'link-1606');">JDBCSQLiteAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3651"></a><tt class="py-lineno">3651</tt>  <tt class="py-line">    <tt class="py-string">'jdbc:sqlite:memory'</tt><tt class="py-op">:</tt> <tt id="link-1607" class="py-name"><a title="web2py.gluon.dal.JDBCSQLiteAdapter" class="py-name" href="#" onclick="return doclink('link-1607', 'JDBCSQLiteAdapter', 'link-1606');">JDBCSQLiteAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3652"></a><tt class="py-lineno">3652</tt>  <tt class="py-line">    <tt class="py-string">'jdbc:postgres'</tt><tt class="py-op">:</tt> <tt id="link-1608" class="py-name" targets="Class web2py.gluon.dal.JDBCPostgreSQLAdapter=web2py.gluon.dal.JDBCPostgreSQLAdapter-class.html"><a title="web2py.gluon.dal.JDBCPostgreSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1608', 'JDBCPostgreSQLAdapter', 'link-1608');">JDBCPostgreSQLAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3653"></a><tt class="py-lineno">3653</tt>  <tt class="py-line">    <tt class="py-string">'gae'</tt><tt class="py-op">:</tt> <tt id="link-1609" class="py-name" targets="Class web2py.gluon.dal.GoogleDatastoreAdapter=web2py.gluon.dal.GoogleDatastoreAdapter-class.html"><a title="web2py.gluon.dal.GoogleDatastoreAdapter" class="py-name" href="#" onclick="return doclink('link-1609', 'GoogleDatastoreAdapter', 'link-1609');">GoogleDatastoreAdapter</a></tt><tt class="py-op">,</tt> <tt class="py-comment"># discouraged, for backward compatibility</tt> </tt>
<a name="L3654"></a><tt class="py-lineno">3654</tt>  <tt class="py-line">    <tt class="py-string">'google:datastore'</tt><tt class="py-op">:</tt> <tt id="link-1610" class="py-name"><a title="web2py.gluon.dal.GoogleDatastoreAdapter" class="py-name" href="#" onclick="return doclink('link-1610', 'GoogleDatastoreAdapter', 'link-1609');">GoogleDatastoreAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3655"></a><tt class="py-lineno">3655</tt>  <tt class="py-line">    <tt class="py-string">'google:sql'</tt><tt class="py-op">:</tt> <tt id="link-1611" class="py-name" targets="Class web2py.gluon.dal.GoogleSQLAdapter=web2py.gluon.dal.GoogleSQLAdapter-class.html"><a title="web2py.gluon.dal.GoogleSQLAdapter" class="py-name" href="#" onclick="return doclink('link-1611', 'GoogleSQLAdapter', 'link-1611');">GoogleSQLAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3656"></a><tt class="py-lineno">3656</tt>  <tt class="py-line">    <tt class="py-string">'couchdb'</tt><tt class="py-op">:</tt> <tt id="link-1612" class="py-name" targets="Class web2py.gluon.dal.CouchDBAdapter=web2py.gluon.dal.CouchDBAdapter-class.html"><a title="web2py.gluon.dal.CouchDBAdapter" class="py-name" href="#" onclick="return doclink('link-1612', 'CouchDBAdapter', 'link-1612');">CouchDBAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3657"></a><tt class="py-lineno">3657</tt>  <tt class="py-line">    <tt class="py-string">'mongodb'</tt><tt class="py-op">:</tt> <tt id="link-1613" class="py-name" targets="Class web2py.gluon.dal.MongoDBAdapter=web2py.gluon.dal.MongoDBAdapter-class.html"><a title="web2py.gluon.dal.MongoDBAdapter" class="py-name" href="#" onclick="return doclink('link-1613', 'MongoDBAdapter', 'link-1613');">MongoDBAdapter</a></tt><tt class="py-op">,</tt> </tt>
<a name="L3658"></a><tt class="py-lineno">3658</tt>  <tt class="py-line"><tt class="py-op">}</tt> </tt>
<a name="L3659"></a><tt class="py-lineno">3659</tt>  <tt class="py-line"> </tt>
<a name="L3660"></a><tt class="py-lineno">3660</tt>  <tt class="py-line"> </tt>
<a name="sqlhtml_validators"></a><div id="sqlhtml_validators-def"><a name="L3661"></a><tt class="py-lineno">3661</tt> <a class="py-toggle" href="#" id="sqlhtml_validators-toggle" onclick="return toggle('sqlhtml_validators');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#sqlhtml_validators">sqlhtml_validators</a><tt class="py-op">(</tt><tt class="py-param">field</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="sqlhtml_validators-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="sqlhtml_validators-expanded"><a name="L3662"></a><tt class="py-lineno">3662</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L3663"></a><tt class="py-lineno">3663</tt>  <tt class="py-line"><tt class="py-docstring">    Field type validation, using web2py's validators mechanism.</tt> </tt>
<a name="L3664"></a><tt class="py-lineno">3664</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L3665"></a><tt class="py-lineno">3665</tt>  <tt class="py-line"><tt class="py-docstring">    makes sure the content of a field is in line with the declared</tt> </tt>
<a name="L3666"></a><tt class="py-lineno">3666</tt>  <tt class="py-line"><tt class="py-docstring">    fieldtype</tt> </tt>
<a name="L3667"></a><tt class="py-lineno">3667</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L3668"></a><tt class="py-lineno">3668</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1614" class="py-name"><a title="web2py.gluon.dal.have_validators" class="py-name" href="#" onclick="return doclink('link-1614', 'have_validators', 'link-22');">have_validators</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3669"></a><tt class="py-lineno">3669</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3670"></a><tt class="py-lineno">3670</tt>  <tt class="py-line">    <tt class="py-name">field_type</tt><tt class="py-op">,</tt> <tt class="py-name">field_length</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">length</tt> </tt>
<a name="L3671"></a><tt class="py-lineno">3671</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">,</tt> <tt id="link-1615" class="py-name"><a title="web2py.gluon.dal.SQLCustomType" class="py-name" href="#" onclick="return doclink('link-1615', 'SQLCustomType', 'link-191');">SQLCustomType</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3672"></a><tt class="py-lineno">3672</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">,</tt> <tt class="py-string">'validator'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3673"></a><tt class="py-lineno">3673</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt class="py-name">validator</tt> </tt>
<a name="L3674"></a><tt class="py-lineno">3674</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3675"></a><tt class="py-lineno">3675</tt>  <tt class="py-line">            <tt class="py-name">field_type</tt> <tt class="py-op">=</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L3676"></a><tt class="py-lineno">3676</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field_type</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3677"></a><tt class="py-lineno">3677</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3678"></a><tt class="py-lineno">3678</tt>  <tt class="py-line">    <tt id="link-1616" class="py-name" targets="Method web2py.gluon.tools.Auth.requires()=web2py.gluon.tools.Auth-class.html#requires"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1616', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3679"></a><tt class="py-lineno">3679</tt>  <tt class="py-line">    <tt class="py-keyword">def</tt> <tt class="py-def-name">ff</tt><tt class="py-op">(</tt><tt class="py-param">r</tt><tt class="py-op">,</tt><tt class="py-param">id</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3680"></a><tt class="py-lineno">3680</tt>  <tt class="py-line">        <tt class="py-name">row</tt><tt class="py-op">=</tt><tt class="py-name">r</tt><tt class="py-op">(</tt><tt class="py-name">id</tt><tt class="py-op">)</tt> </tt>
<a name="L3681"></a><tt class="py-lineno">3681</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">row</tt><tt class="py-op">:</tt> </tt>
<a name="L3682"></a><tt class="py-lineno">3682</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">id</tt> </tt>
<a name="L3683"></a><tt class="py-lineno">3683</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">,</tt> <tt class="py-string">'_format'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3684"></a><tt class="py-lineno">3684</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt> <tt class="py-op">%</tt> <tt class="py-name">row</tt> </tt>
<a name="L3685"></a><tt class="py-lineno">3685</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">,</tt> <tt class="py-string">'_format'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">callable</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3686"></a><tt class="py-lineno">3686</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">)</tt> </tt>
<a name="L3687"></a><tt class="py-lineno">3687</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3688"></a><tt class="py-lineno">3688</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">id</tt> </tt>
</div><a name="L3689"></a><tt class="py-lineno">3689</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'string'</tt><tt class="py-op">:</tt> </tt>
<a name="L3690"></a><tt class="py-lineno">3690</tt>  <tt class="py-line">        <tt id="link-1617" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1617', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1618" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1618', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1619" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1619', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1620" class="py-name" targets="Class web2py.gluon.validators.IS_LENGTH=web2py.gluon.validators.IS_LENGTH-class.html"><a title="web2py.gluon.validators.IS_LENGTH" class="py-name" href="#" onclick="return doclink('link-1620', 'IS_LENGTH', 'link-1620');">IS_LENGTH</a></tt><tt class="py-op">(</tt><tt class="py-name">field_length</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3691"></a><tt class="py-lineno">3691</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'text'</tt><tt class="py-op">:</tt> </tt>
<a name="L3692"></a><tt class="py-lineno">3692</tt>  <tt class="py-line">        <tt id="link-1621" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1621', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1622" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1622', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1623" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1623', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1624" class="py-name"><a title="web2py.gluon.validators.IS_LENGTH" class="py-name" href="#" onclick="return doclink('link-1624', 'IS_LENGTH', 'link-1620');">IS_LENGTH</a></tt><tt class="py-op">(</tt><tt class="py-name">field_length</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3693"></a><tt class="py-lineno">3693</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'password'</tt><tt class="py-op">:</tt> </tt>
<a name="L3694"></a><tt class="py-lineno">3694</tt>  <tt class="py-line">        <tt id="link-1625" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1625', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1626" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1626', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1627" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1627', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1628" class="py-name"><a title="web2py.gluon.validators.IS_LENGTH" class="py-name" href="#" onclick="return doclink('link-1628', 'IS_LENGTH', 'link-1620');">IS_LENGTH</a></tt><tt class="py-op">(</tt><tt class="py-name">field_length</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3695"></a><tt class="py-lineno">3695</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'double'</tt><tt class="py-op">:</tt> </tt>
<a name="L3696"></a><tt class="py-lineno">3696</tt>  <tt class="py-line">        <tt id="link-1629" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1629', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1630" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1630', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1631" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1631', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1632" class="py-name" targets="Class web2py.gluon.validators.IS_FLOAT_IN_RANGE=web2py.gluon.validators.IS_FLOAT_IN_RANGE-class.html"><a title="web2py.gluon.validators.IS_FLOAT_IN_RANGE" class="py-name" href="#" onclick="return doclink('link-1632', 'IS_FLOAT_IN_RANGE', 'link-1632');">IS_FLOAT_IN_RANGE</a></tt><tt class="py-op">(</tt><tt class="py-op">-</tt><tt class="py-number">1e100</tt><tt class="py-op">,</tt> <tt class="py-number">1e100</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3697"></a><tt class="py-lineno">3697</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> </tt>
<a name="L3698"></a><tt class="py-lineno">3698</tt>  <tt class="py-line">        <tt id="link-1633" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1633', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1634" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1634', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1635" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1635', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1636" class="py-name" targets="Class web2py.gluon.validators.IS_INT_IN_RANGE=web2py.gluon.validators.IS_INT_IN_RANGE-class.html"><a title="web2py.gluon.validators.IS_INT_IN_RANGE" class="py-name" href="#" onclick="return doclink('link-1636', 'IS_INT_IN_RANGE', 'link-1636');">IS_INT_IN_RANGE</a></tt><tt class="py-op">(</tt><tt class="py-op">-</tt><tt class="py-number">1e100</tt><tt class="py-op">,</tt> <tt class="py-number">1e100</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3699"></a><tt class="py-lineno">3699</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-1637" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1637', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'decimal'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3700"></a><tt class="py-lineno">3700</tt>  <tt class="py-line">        <tt id="link-1638" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1638', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1639" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1639', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1640" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1640', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1641" class="py-name" targets="Class web2py.gluon.validators.IS_DECIMAL_IN_RANGE=web2py.gluon.validators.IS_DECIMAL_IN_RANGE-class.html"><a title="web2py.gluon.validators.IS_DECIMAL_IN_RANGE" class="py-name" href="#" onclick="return doclink('link-1641', 'IS_DECIMAL_IN_RANGE', 'link-1641');">IS_DECIMAL_IN_RANGE</a></tt><tt class="py-op">(</tt><tt class="py-op">-</tt><tt class="py-number">10</tt><tt class="py-op">**</tt><tt class="py-number">10</tt><tt class="py-op">,</tt> <tt class="py-number">10</tt><tt class="py-op">**</tt><tt class="py-number">10</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3701"></a><tt class="py-lineno">3701</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'date'</tt><tt class="py-op">:</tt> </tt>
<a name="L3702"></a><tt class="py-lineno">3702</tt>  <tt class="py-line">        <tt id="link-1642" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1642', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1643" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1643', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1644" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1644', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1645" class="py-name" targets="Class web2py.gluon.validators.IS_DATE=web2py.gluon.validators.IS_DATE-class.html"><a title="web2py.gluon.validators.IS_DATE" class="py-name" href="#" onclick="return doclink('link-1645', 'IS_DATE', 'link-1645');">IS_DATE</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3703"></a><tt class="py-lineno">3703</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'time'</tt><tt class="py-op">:</tt> </tt>
<a name="L3704"></a><tt class="py-lineno">3704</tt>  <tt class="py-line">        <tt id="link-1646" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1646', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1647" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1647', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1648" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1648', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1649" class="py-name" targets="Class web2py.gluon.validators.IS_TIME=web2py.gluon.validators.IS_TIME-class.html"><a title="web2py.gluon.validators.IS_TIME" class="py-name" href="#" onclick="return doclink('link-1649', 'IS_TIME', 'link-1649');">IS_TIME</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3705"></a><tt class="py-lineno">3705</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt> <tt class="py-op">==</tt> <tt class="py-string">'datetime'</tt><tt class="py-op">:</tt> </tt>
<a name="L3706"></a><tt class="py-lineno">3706</tt>  <tt class="py-line">        <tt id="link-1650" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1650', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1651" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1651', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1652" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1652', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1653" class="py-name" targets="Class web2py.gluon.validators.IS_DATETIME=web2py.gluon.validators.IS_DATETIME-class.html"><a title="web2py.gluon.validators.IS_DATETIME" class="py-name" href="#" onclick="return doclink('link-1653', 'IS_DATETIME', 'link-1653');">IS_DATETIME</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3707"></a><tt class="py-lineno">3707</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-1654" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1654', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L3708"></a><tt class="py-lineno">3708</tt>  <tt class="py-line">            <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-1655" class="py-name"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-1655', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> <tt class="py-op">&lt;</tt> <tt class="py-number">0</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L3709"></a><tt class="py-lineno">3709</tt>  <tt class="py-line">            <tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1656" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1656', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3710"></a><tt class="py-lineno">3710</tt>  <tt class="py-line">        <tt class="py-name">referenced</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> </tt>
<a name="L3711"></a><tt class="py-lineno">3711</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">repr_ref</tt><tt class="py-op">(</tt><tt class="py-param">id</tt><tt class="py-op">,</tt> <tt class="py-param">r</tt><tt class="py-op">=</tt><tt class="py-name">referenced</tt><tt class="py-op">,</tt> <tt class="py-param">f</tt><tt class="py-op">=</tt><tt class="py-name">ff</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">return</tt> <tt class="py-name">f</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">,</tt> <tt class="py-name">id</tt><tt class="py-op">)</tt> </tt>
<a name="L3712"></a><tt class="py-lineno">3712</tt>  <tt class="py-line">        <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1657" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1657', 'represent', 'link-304');">represent</a></tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1658" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1658', 'represent', 'link-304');">represent</a></tt> <tt class="py-keyword">or</tt> <tt class="py-name">repr_ref</tt> </tt>
<a name="L3713"></a><tt class="py-lineno">3713</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">referenced</tt><tt class="py-op">,</tt> <tt class="py-string">'_format'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">:</tt> </tt>
<a name="L3714"></a><tt class="py-lineno">3714</tt>  <tt class="py-line">            <tt id="link-1659" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1659', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt id="link-1660" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1660', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1661" class="py-name" targets="Class web2py.gluon.validators.IS_IN_DB=web2py.gluon.validators.IS_IN_DB-class.html"><a title="web2py.gluon.validators.IS_IN_DB" class="py-name" href="#" onclick="return doclink('link-1661', 'IS_IN_DB', 'link-1661');">IS_IN_DB</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">,</tt> </tt>
<a name="L3715"></a><tt class="py-lineno">3715</tt>  <tt class="py-line">                                           <tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">)</tt> </tt>
<a name="L3716"></a><tt class="py-lineno">3716</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt><tt class="py-op">:</tt> </tt>
<a name="L3717"></a><tt class="py-lineno">3717</tt>  <tt class="py-line">                <tt id="link-1662" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1662', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt class="py-name">_and</tt> <tt class="py-op">=</tt> <tt id="link-1663" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1663', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1664" class="py-name" targets="Class web2py.gluon.validators.IS_NOT_IN_DB=web2py.gluon.validators.IS_NOT_IN_DB-class.html"><a title="web2py.gluon.validators.IS_NOT_IN_DB" class="py-name" href="#" onclick="return doclink('link-1664', 'IS_NOT_IN_DB', 'link-1664');">IS_NOT_IN_DB</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L3718"></a><tt class="py-lineno">3718</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> <tt class="py-op">==</tt> <tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L3719"></a><tt class="py-lineno">3719</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt id="link-1665" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1665', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1666" class="py-name" targets="Class web2py.gluon.validators.IS_EMPTY_OR=web2py.gluon.validators.IS_EMPTY_OR-class.html"><a title="web2py.gluon.validators.IS_EMPTY_OR" class="py-name" href="#" onclick="return doclink('link-1666', 'IS_EMPTY_OR', 'link-1666');">IS_EMPTY_OR</a></tt><tt class="py-op">(</tt><tt id="link-1667" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1667', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3720"></a><tt class="py-lineno">3720</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1668" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1668', 'requires', 'link-1616');">requires</a></tt> </tt>
<a name="L3721"></a><tt class="py-lineno">3721</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-1669" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1669', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:reference'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L3722"></a><tt class="py-lineno">3722</tt>  <tt class="py-line">            <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-1670" class="py-name"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-1670', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> <tt class="py-op">&lt;</tt> <tt class="py-number">0</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L3723"></a><tt class="py-lineno">3723</tt>  <tt class="py-line">            <tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">15</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1671" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1671', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3724"></a><tt class="py-lineno">3724</tt>  <tt class="py-line">        <tt class="py-name">referenced</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-number">15</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> </tt>
<a name="L3725"></a><tt class="py-lineno">3725</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">list_ref_repr</tt><tt class="py-op">(</tt><tt class="py-param">ids</tt><tt class="py-op">,</tt> <tt class="py-param">r</tt><tt class="py-op">=</tt><tt class="py-name">referenced</tt><tt class="py-op">,</tt> <tt class="py-param">f</tt><tt class="py-op">=</tt><tt class="py-name">ff</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3726"></a><tt class="py-lineno">3726</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ids</tt><tt class="py-op">:</tt> </tt>
<a name="L3727"></a><tt class="py-lineno">3727</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L3728"></a><tt class="py-lineno">3728</tt>  <tt class="py-line">            <tt class="py-name">refs</tt> <tt class="py-op">=</tt> <tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-1672" class="py-name"><a title="web2py.gluon.dal.Expression.belongs" class="py-name" href="#" onclick="return doclink('link-1672', 'belongs', 'link-468');">belongs</a></tt><tt class="py-op">(</tt><tt class="py-name">ids</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1673" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1673', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">)</tt> </tt>
<a name="L3729"></a><tt class="py-lineno">3729</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">refs</tt> <tt class="py-keyword">and</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-1674" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1674', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">,</tt><tt class="py-name">ref</tt><tt class="py-op">.</tt><tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">ref</tt> <tt class="py-keyword">in</tt> <tt class="py-name">refs</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3730"></a><tt class="py-lineno">3730</tt>  <tt class="py-line">        <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1675" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1675', 'represent', 'link-304');">represent</a></tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1676" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1676', 'represent', 'link-304');">represent</a></tt> <tt class="py-keyword">or</tt> <tt class="py-name">list_ref_repr</tt> </tt>
<a name="L3731"></a><tt class="py-lineno">3731</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">referenced</tt><tt class="py-op">,</tt> <tt class="py-string">'_format'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">:</tt> </tt>
<a name="L3732"></a><tt class="py-lineno">3732</tt>  <tt class="py-line">            <tt id="link-1677" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1677', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt id="link-1678" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1678', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1679" class="py-name"><a title="web2py.gluon.validators.IS_IN_DB" class="py-name" href="#" onclick="return doclink('link-1679', 'IS_IN_DB', 'link-1661');">IS_IN_DB</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">,</tt> </tt>
<a name="L3733"></a><tt class="py-lineno">3733</tt>  <tt class="py-line">                                           <tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt><tt class="py-op">,</tt><tt class="py-name">multiple</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L3734"></a><tt class="py-lineno">3734</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3735"></a><tt class="py-lineno">3735</tt>  <tt class="py-line">            <tt id="link-1680" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1680', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt id="link-1681" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1681', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1682" class="py-name"><a title="web2py.gluon.validators.IS_IN_DB" class="py-name" href="#" onclick="return doclink('link-1682', 'IS_IN_DB', 'link-1661');">IS_IN_DB</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">referenced</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">,</tt> </tt>
<a name="L3736"></a><tt class="py-lineno">3736</tt>  <tt class="py-line">                                           <tt class="py-name">multiple</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L3737"></a><tt class="py-lineno">3737</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt><tt class="py-op">:</tt> </tt>
<a name="L3738"></a><tt class="py-lineno">3738</tt>  <tt class="py-line">            <tt id="link-1683" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1683', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt class="py-name">_and</tt> <tt class="py-op">=</tt> <tt id="link-1684" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1684', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1685" class="py-name"><a title="web2py.gluon.validators.IS_NOT_IN_DB" class="py-name" href="#" onclick="return doclink('link-1685', 'IS_NOT_IN_DB', 'link-1664');">IS_NOT_IN_DB</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L3739"></a><tt class="py-lineno">3739</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1686" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1686', 'requires', 'link-1616');">requires</a></tt> </tt>
<a name="L3740"></a><tt class="py-lineno">3740</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-name">field_type</tt><tt class="py-op">.</tt><tt id="link-1687" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1687', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3741"></a><tt class="py-lineno">3741</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">repr_list</tt><tt class="py-op">(</tt><tt class="py-param">values</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-keyword">return</tt><tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-1688" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1688', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt id="link-1689" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-1689', 'values', 'link-321');">values</a></tt> <tt class="py-keyword">or</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3742"></a><tt class="py-lineno">3742</tt>  <tt class="py-line">        <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1690" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1690', 'represent', 'link-304');">represent</a></tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-1691" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-1691', 'represent', 'link-304');">represent</a></tt> <tt class="py-keyword">or</tt> <tt class="py-name">repr_list</tt> </tt>
<a name="L3743"></a><tt class="py-lineno">3743</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt><tt class="py-op">:</tt> </tt>
<a name="L3744"></a><tt class="py-lineno">3744</tt>  <tt class="py-line">        <tt id="link-1692" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1692', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1693" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-1693', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt id="link-1694" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1694', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1695" class="py-name"><a title="web2py.gluon.validators.IS_NOT_IN_DB" class="py-name" href="#" onclick="return doclink('link-1695', 'IS_NOT_IN_DB', 'link-1664');">IS_NOT_IN_DB</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3745"></a><tt class="py-lineno">3745</tt>  <tt class="py-line">    <tt class="py-name">sff</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'in'</tt><tt class="py-op">,</tt> <tt class="py-string">'do'</tt><tt class="py-op">,</tt> <tt class="py-string">'da'</tt><tt class="py-op">,</tt> <tt class="py-string">'ti'</tt><tt class="py-op">,</tt> <tt class="py-string">'de'</tt><tt class="py-op">,</tt> <tt class="py-string">'bo'</tt><tt class="py-op">]</tt> </tt>
<a name="L3746"></a><tt class="py-lineno">3746</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sff</tt><tt class="py-op">:</tt> </tt>
<a name="L3747"></a><tt class="py-lineno">3747</tt>  <tt class="py-line">        <tt id="link-1696" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1696', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt id="link-1697" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-1697', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt id="link-1698" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1698', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1699" class="py-name" targets="Class web2py.gluon.validators.IS_NOT_EMPTY=web2py.gluon.validators.IS_NOT_EMPTY-class.html"><a title="web2py.gluon.validators.IS_NOT_EMPTY" class="py-name" href="#" onclick="return doclink('link-1699', 'IS_NOT_EMPTY', 'link-1699');">IS_NOT_EMPTY</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3748"></a><tt class="py-lineno">3748</tt>  <tt class="py-line">    <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field_type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sff</tt> <tt class="py-keyword">and</tt> <tt id="link-1700" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1700', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3749"></a><tt class="py-lineno">3749</tt>  <tt class="py-line">        <tt id="link-1701" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1701', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-1702" class="py-name"><a title="web2py.gluon.tools.validators
web2py.gluon.validators" class="py-name" href="#" onclick="return doclink('link-1702', 'validators', 'link-21');">validators</a></tt><tt class="py-op">.</tt><tt id="link-1703" class="py-name"><a title="web2py.gluon.validators.IS_EMPTY_OR" class="py-name" href="#" onclick="return doclink('link-1703', 'IS_EMPTY_OR', 'link-1666');">IS_EMPTY_OR</a></tt><tt class="py-op">(</tt><tt id="link-1704" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1704', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3750"></a><tt class="py-lineno">3750</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt id="link-1705" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-1705', 'requires', 'link-1616');">requires</a></tt> </tt>
</div><a name="L3751"></a><tt class="py-lineno">3751</tt>  <tt class="py-line"> </tt>
<a name="L3752"></a><tt class="py-lineno">3752</tt>  <tt class="py-line"> </tt>
<a name="bar_escape"></a><div id="bar_escape-def"><a name="L3753"></a><tt class="py-lineno">3753</tt> <a class="py-toggle" href="#" id="bar_escape-toggle" onclick="return toggle('bar_escape');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#bar_escape">bar_escape</a><tt class="py-op">(</tt><tt class="py-param">item</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="bar_escape-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="bar_escape-expanded"><a name="L3754"></a><tt class="py-lineno">3754</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'|'</tt><tt class="py-op">,</tt> <tt class="py-string">'||'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3755"></a><tt class="py-lineno">3755</tt>  <tt class="py-line"> </tt>
<a name="bar_encode"></a><div id="bar_encode-def"><a name="L3756"></a><tt class="py-lineno">3756</tt> <a class="py-toggle" href="#" id="bar_encode-toggle" onclick="return toggle('bar_encode');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#bar_encode">bar_encode</a><tt class="py-op">(</tt><tt class="py-param">items</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="bar_encode-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="bar_encode-expanded"><a name="L3757"></a><tt class="py-lineno">3757</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-string">'|%s|'</tt> <tt class="py-op">%</tt> <tt class="py-string">'|'</tt><tt class="py-op">.</tt><tt id="link-1706" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1706', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt id="link-1707" class="py-name" targets="Function web2py.gluon.dal.bar_escape()=web2py.gluon.dal-module.html#bar_escape"><a title="web2py.gluon.dal.bar_escape" class="py-name" href="#" onclick="return doclink('link-1707', 'bar_escape', 'link-1707');">bar_escape</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-1708" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1708', 'items', 'link-266');">items</a></tt> <tt class="py-keyword">if</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1709" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1709', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3758"></a><tt class="py-lineno">3758</tt>  <tt class="py-line"> </tt>
<a name="bar_decode_integer"></a><div id="bar_decode_integer-def"><a name="L3759"></a><tt class="py-lineno">3759</tt> <a class="py-toggle" href="#" id="bar_decode_integer-toggle" onclick="return toggle('bar_decode_integer');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#bar_decode_integer">bar_decode_integer</a><tt class="py-op">(</tt><tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="bar_decode_integer-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="bar_decode_integer-expanded"><a name="L3760"></a><tt class="py-lineno">3760</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt id="link-1710" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1710', 'x', 'link-114');">x</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-1711" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1711', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'|'</tt><tt class="py-op">)</tt> <tt class="py-keyword">if</tt> <tt id="link-1712" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1712', 'x', 'link-114');">x</a></tt><tt class="py-op">.</tt><tt id="link-1713" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1713', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3761"></a><tt class="py-lineno">3761</tt>  <tt class="py-line"> </tt>
<a name="bar_decode_string"></a><div id="bar_decode_string-def"><a name="L3762"></a><tt class="py-lineno">3762</tt> <a class="py-toggle" href="#" id="bar_decode_string-toggle" onclick="return toggle('bar_decode_string');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#bar_decode_string">bar_decode_string</a><tt class="py-op">(</tt><tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="bar_decode_string-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="bar_decode_string-expanded"><a name="L3763"></a><tt class="py-lineno">3763</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt id="link-1714" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1714', 'x', 'link-114');">x</a></tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'||'</tt><tt class="py-op">,</tt> <tt class="py-string">'|'</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-1715" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1715', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt id="link-1716" class="py-name"><a title="web2py.gluon.dal.string_unpack" class="py-name" href="#" onclick="return doclink('link-1716', 'string_unpack', 'link-32');">string_unpack</a></tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-keyword">if</tt> <tt id="link-1717" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-1717', 'x', 'link-114');">x</a></tt><tt class="py-op">.</tt><tt id="link-1718" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1718', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3764"></a><tt class="py-lineno">3764</tt>  <tt class="py-line"> </tt>
<a name="L3765"></a><tt class="py-lineno">3765</tt>  <tt class="py-line"> </tt>
<a name="Row"></a><div id="Row-def"><a name="L3766"></a><tt class="py-lineno">3766</tt> <a class="py-toggle" href="#" id="Row-toggle" onclick="return toggle('Row');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html">Row</a><tt class="py-op">(</tt><tt class="py-base-class">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Row-expanded"><a name="L3767"></a><tt class="py-lineno">3767</tt>  <tt class="py-line"> </tt>
<a name="L3768"></a><tt class="py-lineno">3768</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L3769"></a><tt class="py-lineno">3769</tt>  <tt class="py-line"><tt class="py-docstring">    a dictionary that lets you do d['a'] as well as d.a</tt> </tt>
<a name="L3770"></a><tt class="py-lineno">3770</tt>  <tt class="py-line"><tt class="py-docstring">    this is only used to store a Row</tt> </tt>
<a name="L3771"></a><tt class="py-lineno">3771</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L3772"></a><tt class="py-lineno">3772</tt>  <tt class="py-line"> </tt>
<a name="Row.__getitem__"></a><div id="Row.__getitem__-def"><a name="L3773"></a><tt class="py-lineno">3773</tt> <a class="py-toggle" href="#" id="Row.__getitem__-toggle" onclick="return toggle('Row.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__getitem__-expanded"><a name="L3774"></a><tt class="py-lineno">3774</tt>  <tt class="py-line">        <tt class="py-name">key</tt><tt class="py-op">=</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L3775"></a><tt class="py-lineno">3775</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1719" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1719', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'_extra'</tt><tt class="py-op">,</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3776"></a><tt class="py-lineno">3776</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_extra</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
<a name="L3777"></a><tt class="py-lineno">3777</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1720" class="py-name" targets="Method web2py.gluon.compileapp.mybuiltin.__getitem__()=web2py.gluon.compileapp.mybuiltin-class.html#__getitem__,Method web2py.gluon.dal.DAL.__getitem__()=web2py.gluon.dal.DAL-class.html#__getitem__,Method web2py.gluon.dal.Expression.__getitem__()=web2py.gluon.dal.Expression-class.html#__getitem__,Method web2py.gluon.dal.Reference.__getitem__()=web2py.gluon.dal.Reference-class.html#__getitem__,Method web2py.gluon.dal.Row.__getitem__()=web2py.gluon.dal.Row-class.html#__getitem__,Method web2py.gluon.dal.Rows.__getitem__()=web2py.gluon.dal.Rows-class.html#__getitem__,Method web2py.gluon.dal.SQLCustomType.__getitem__()=web2py.gluon.dal.SQLCustomType-class.html#__getitem__,Method web2py.gluon.dal.Table.__getitem__()=web2py.gluon.dal.Table-class.html#__getitem__,Method web2py.gluon.html.DIV.__getitem__()=web2py.gluon.html.DIV-class.html#__getitem__,Method web2py.gluon.html.XML.__getitem__()=web2py.gluon.html.XML-class.html#__getitem__,Method web2py.gluon.html.__TAG__.__getitem__()=web2py.gluon.html.__TAG__-class.html#__getitem__,Method web2py.gluon.languages.lazyT.__getitem__()=web2py.gluon.languages.lazyT-class.html#__getitem__,Method web2py.gluon.rocket.FileWrapper.__getitem__()=web2py.gluon.rocket.FileWrapper-class.html#__getitem__,Method web2py.gluon.rocket.Headers.__getitem__()=web2py.gluon.rocket.Headers-class.html#__getitem__"><a title="web2py.gluon.compileapp.mybuiltin.__getitem__
web2py.gluon.dal.DAL.__getitem__
web2py.gluon.dal.Expression.__getitem__
web2py.gluon.dal.Reference.__getitem__
web2py.gluon.dal.Row.__getitem__
web2py.gluon.dal.Rows.__getitem__
web2py.gluon.dal.SQLCustomType.__getitem__
web2py.gluon.dal.Table.__getitem__
web2py.gluon.html.DIV.__getitem__
web2py.gluon.html.XML.__getitem__
web2py.gluon.html.__TAG__.__getitem__
web2py.gluon.languages.lazyT.__getitem__
web2py.gluon.rocket.FileWrapper.__getitem__
web2py.gluon.rocket.Headers.__getitem__" class="py-name" href="#" onclick="return doclink('link-1720', '__getitem__', 'link-1720');">__getitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3778"></a><tt class="py-lineno">3778</tt>  <tt class="py-line"> </tt>
<a name="Row.__call__"></a><div id="Row.__call__-def"><a name="L3779"></a><tt class="py-lineno">3779</tt> <a class="py-toggle" href="#" id="Row.__call__-toggle" onclick="return toggle('Row.__call__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__call__">__call__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__call__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__call__-expanded"><a name="L3780"></a><tt class="py-lineno">3780</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1721" class="py-name"><a title="web2py.gluon.compileapp.mybuiltin.__getitem__
web2py.gluon.dal.DAL.__getitem__
web2py.gluon.dal.Expression.__getitem__
web2py.gluon.dal.Reference.__getitem__
web2py.gluon.dal.Row.__getitem__
web2py.gluon.dal.Rows.__getitem__
web2py.gluon.dal.SQLCustomType.__getitem__
web2py.gluon.dal.Table.__getitem__
web2py.gluon.html.DIV.__getitem__
web2py.gluon.html.XML.__getitem__
web2py.gluon.html.__TAG__.__getitem__
web2py.gluon.languages.lazyT.__getitem__
web2py.gluon.rocket.FileWrapper.__getitem__
web2py.gluon.rocket.Headers.__getitem__" class="py-name" href="#" onclick="return doclink('link-1721', '__getitem__', 'link-1720');">__getitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3781"></a><tt class="py-lineno">3781</tt>  <tt class="py-line"> </tt>
<a name="Row.__setitem__"></a><div id="Row.__setitem__-def"><a name="L3782"></a><tt class="py-lineno">3782</tt> <a class="py-toggle" href="#" id="Row.__setitem__-toggle" onclick="return toggle('Row.__setitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__setitem__">__setitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__setitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__setitem__-expanded"><a name="L3783"></a><tt class="py-lineno">3783</tt>  <tt class="py-line">        <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1722" class="py-name" targets="Method web2py.gluon.compileapp.mybuiltin.__setitem__()=web2py.gluon.compileapp.mybuiltin-class.html#__setitem__,Method web2py.gluon.dal.DAL.__setitem__()=web2py.gluon.dal.DAL-class.html#__setitem__,Method web2py.gluon.dal.Reference.__setitem__()=web2py.gluon.dal.Reference-class.html#__setitem__,Method web2py.gluon.dal.Row.__setitem__()=web2py.gluon.dal.Row-class.html#__setitem__,Method web2py.gluon.dal.Table.__setitem__()=web2py.gluon.dal.Table-class.html#__setitem__,Method web2py.gluon.html.DIV.__setitem__()=web2py.gluon.html.DIV-class.html#__setitem__,Method web2py.gluon.rocket.Headers.__setitem__()=web2py.gluon.rocket.Headers-class.html#__setitem__"><a title="web2py.gluon.compileapp.mybuiltin.__setitem__
web2py.gluon.dal.DAL.__setitem__
web2py.gluon.dal.Reference.__setitem__
web2py.gluon.dal.Row.__setitem__
web2py.gluon.dal.Table.__setitem__
web2py.gluon.html.DIV.__setitem__
web2py.gluon.rocket.Headers.__setitem__" class="py-name" href="#" onclick="return doclink('link-1722', '__setitem__', 'link-1722');">__setitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3784"></a><tt class="py-lineno">3784</tt>  <tt class="py-line"> </tt>
<a name="Row.__getattr__"></a><div id="Row.__getattr__-def"><a name="L3785"></a><tt class="py-lineno">3785</tt> <a class="py-toggle" href="#" id="Row.__getattr__-toggle" onclick="return toggle('Row.__getattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__getattr__">__getattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__getattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__getattr__-expanded"><a name="L3786"></a><tt class="py-lineno">3786</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
</div><a name="L3787"></a><tt class="py-lineno">3787</tt>  <tt class="py-line"> </tt>
<a name="Row.__setattr__"></a><div id="Row.__setattr__-def"><a name="L3788"></a><tt class="py-lineno">3788</tt> <a class="py-toggle" href="#" id="Row.__setattr__-toggle" onclick="return toggle('Row.__setattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__setattr__">__setattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__setattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__setattr__-expanded"><a name="L3789"></a><tt class="py-lineno">3789</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
</div><a name="L3790"></a><tt class="py-lineno">3790</tt>  <tt class="py-line"> </tt>
<a name="Row.__repr__"></a><div id="Row.__repr__-def"><a name="L3791"></a><tt class="py-lineno">3791</tt> <a class="py-toggle" href="#" id="Row.__repr__-toggle" onclick="return toggle('Row.__repr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__repr__">__repr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__repr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__repr__-expanded"><a name="L3792"></a><tt class="py-lineno">3792</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'&lt;Row '</tt> <tt class="py-op">+</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1723" class="py-name" targets="Method web2py.gluon.dal.DAL.__repr__()=web2py.gluon.dal.DAL-class.html#__repr__,Method web2py.gluon.dal.GAEF.__repr__()=web2py.gluon.dal.GAEF-class.html#__repr__,Method web2py.gluon.dal.Row.__repr__()=web2py.gluon.dal.Row-class.html#__repr__,Method web2py.gluon.dal.Table.__repr__()=web2py.gluon.dal.Table-class.html#__repr__,Method web2py.gluon.languages.lazyT.__repr__()=web2py.gluon.languages.lazyT-class.html#__repr__,Method web2py.gluon.rocket.Headers.__repr__()=web2py.gluon.rocket.Headers-class.html#__repr__,Method web2py.gluon.storage.Storage.__repr__()=web2py.gluon.storage.Storage-class.html#__repr__,Method web2py.gluon.template.BlockNode.__repr__()=web2py.gluon.template.BlockNode-class.html#__repr__,Method web2py.gluon.template.SuperNode.__repr__()=web2py.gluon.template.SuperNode-class.html#__repr__"><a title="web2py.gluon.dal.DAL.__repr__
web2py.gluon.dal.GAEF.__repr__
web2py.gluon.dal.Row.__repr__
web2py.gluon.dal.Table.__repr__
web2py.gluon.languages.lazyT.__repr__
web2py.gluon.rocket.Headers.__repr__
web2py.gluon.storage.Storage.__repr__
web2py.gluon.template.BlockNode.__repr__
web2py.gluon.template.SuperNode.__repr__" class="py-name" href="#" onclick="return doclink('link-1723', '__repr__', 'link-1723');">__repr__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">'&gt;'</tt> </tt>
</div><a name="L3793"></a><tt class="py-lineno">3793</tt>  <tt class="py-line"> </tt>
<a name="Row.__int__"></a><div id="Row.__int__-def"><a name="L3794"></a><tt class="py-lineno">3794</tt> <a class="py-toggle" href="#" id="Row.__int__-toggle" onclick="return toggle('Row.__int__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__int__">__int__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__int__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__int__-expanded"><a name="L3795"></a><tt class="py-lineno">3795</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1724" class="py-name"><a title="web2py.gluon.compileapp.mybuiltin.__getitem__
web2py.gluon.dal.DAL.__getitem__
web2py.gluon.dal.Expression.__getitem__
web2py.gluon.dal.Reference.__getitem__
web2py.gluon.dal.Row.__getitem__
web2py.gluon.dal.Rows.__getitem__
web2py.gluon.dal.SQLCustomType.__getitem__
web2py.gluon.dal.Table.__getitem__
web2py.gluon.html.DIV.__getitem__
web2py.gluon.html.XML.__getitem__
web2py.gluon.html.__TAG__.__getitem__
web2py.gluon.languages.lazyT.__getitem__
web2py.gluon.rocket.FileWrapper.__getitem__
web2py.gluon.rocket.Headers.__getitem__" class="py-name" href="#" onclick="return doclink('link-1724', '__getitem__', 'link-1720');">__getitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-string">'id'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3796"></a><tt class="py-lineno">3796</tt>  <tt class="py-line"> </tt>
<a name="Row.__eq__"></a><div id="Row.__eq__-def"><a name="L3797"></a><tt class="py-lineno">3797</tt> <a class="py-toggle" href="#" id="Row.__eq__-toggle" onclick="return toggle('Row.__eq__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__eq__">__eq__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__eq__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__eq__-expanded"><a name="L3798"></a><tt class="py-lineno">3798</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3799"></a><tt class="py-lineno">3799</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1725" class="py-name" targets="Method web2py.gluon.dal.Row.as_dict()=web2py.gluon.dal.Row-class.html#as_dict,Method web2py.gluon.dal.Rows.as_dict()=web2py.gluon.dal.Rows-class.html#as_dict"><a title="web2py.gluon.dal.Row.as_dict
web2py.gluon.dal.Rows.as_dict" class="py-name" href="#" onclick="return doclink('link-1725', 'as_dict', 'link-1725');">as_dict</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">other</tt><tt class="py-op">.</tt><tt id="link-1726" class="py-name"><a title="web2py.gluon.dal.Row.as_dict
web2py.gluon.dal.Rows.as_dict" class="py-name" href="#" onclick="return doclink('link-1726', 'as_dict', 'link-1725');">as_dict</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3800"></a><tt class="py-lineno">3800</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt> <tt class="py-name">AttributeError</tt><tt class="py-op">:</tt> </tt>
<a name="L3801"></a><tt class="py-lineno">3801</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt>
</div><a name="L3802"></a><tt class="py-lineno">3802</tt>  <tt class="py-line"> </tt>
<a name="Row.__ne__"></a><div id="Row.__ne__-def"><a name="L3803"></a><tt class="py-lineno">3803</tt> <a class="py-toggle" href="#" id="Row.__ne__-toggle" onclick="return toggle('Row.__ne__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__ne__">__ne__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__ne__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__ne__-expanded"><a name="L3804"></a><tt class="py-lineno">3804</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-keyword">not</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt> <tt class="py-op">==</tt> <tt class="py-name">other</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3805"></a><tt class="py-lineno">3805</tt>  <tt class="py-line"> </tt>
<a name="Row.__copy__"></a><div id="Row.__copy__-def"><a name="L3806"></a><tt class="py-lineno">3806</tt> <a class="py-toggle" href="#" id="Row.__copy__-toggle" onclick="return toggle('Row.__copy__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#__copy__">__copy__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.__copy__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.__copy__-expanded"><a name="L3807"></a><tt class="py-lineno">3807</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1727" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1727', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3808"></a><tt class="py-lineno">3808</tt>  <tt class="py-line"> </tt>
<a name="Row.as_dict"></a><div id="Row.as_dict-def"><a name="L3809"></a><tt class="py-lineno">3809</tt> <a class="py-toggle" href="#" id="Row.as_dict-toggle" onclick="return toggle('Row.as_dict');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Row-class.html#as_dict">as_dict</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">datetime_to_str</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row.as_dict-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Row.as_dict-expanded"><a name="L3810"></a><tt class="py-lineno">3810</tt>  <tt class="py-line">        <tt class="py-name">SERIALIZABLE_TYPES</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">,</tt><tt class="py-name">unicode</tt><tt class="py-op">,</tt><tt class="py-name">int</tt><tt class="py-op">,</tt><tt class="py-name">long</tt><tt class="py-op">,</tt><tt class="py-name">float</tt><tt class="py-op">,</tt><tt class="py-name">bool</tt><tt class="py-op">,</tt><tt class="py-name">list</tt><tt class="py-op">)</tt> </tt>
<a name="L3811"></a><tt class="py-lineno">3811</tt>  <tt class="py-line">        <tt class="py-name">d</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
<a name="L3812"></a><tt class="py-lineno">3812</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt id="link-1728" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1728', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">d</tt><tt class="py-op">.</tt><tt id="link-1729" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1729', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3813"></a><tt class="py-lineno">3813</tt>  <tt class="py-line">            <tt class="py-name">v</tt><tt class="py-op">=</tt><tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1730" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1730', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> </tt>
<a name="L3814"></a><tt class="py-lineno">3814</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1731" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1731', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L3815"></a><tt class="py-lineno">3815</tt>  <tt class="py-line">                <tt class="py-keyword">continue</tt> </tt>
<a name="L3816"></a><tt class="py-lineno">3816</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt id="link-1732" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1732', 'Row', 'link-600');">Row</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3817"></a><tt class="py-lineno">3817</tt>  <tt class="py-line">                <tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1733" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1733', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">=</tt><tt class="py-name">v</tt><tt class="py-op">.</tt><tt id="link-1734" class="py-name"><a title="web2py.gluon.dal.Row.as_dict
web2py.gluon.dal.Rows.as_dict" class="py-name" href="#" onclick="return doclink('link-1734', 'as_dict', 'link-1725');">as_dict</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3818"></a><tt class="py-lineno">3818</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt id="link-1735" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-1735', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3819"></a><tt class="py-lineno">3819</tt>  <tt class="py-line">                <tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1736" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1736', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">=</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">)</tt> </tt>
<a name="L3820"></a><tt class="py-lineno">3820</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">decimal</tt><tt class="py-op">.</tt><tt class="py-name">Decimal</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3821"></a><tt class="py-lineno">3821</tt>  <tt class="py-line">                <tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1737" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1737', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">=</tt><tt class="py-name">float</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">)</tt> </tt>
<a name="L3822"></a><tt class="py-lineno">3822</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-1738" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1738', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1739" class="py-name"><a title="datetime.date" class="py-name" href="#" onclick="return doclink('link-1739', 'date', 'link-604');">date</a></tt><tt class="py-op">,</tt> <tt id="link-1740" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1740', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1741" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1741', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">,</tt> <tt id="link-1742" class="py-name"><a title="datetime.datetime" class="py-name" href="#" onclick="return doclink('link-1742', 'datetime', 'link-3');">datetime</a></tt><tt class="py-op">.</tt><tt id="link-1743" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-1743', 'time', 'link-4');">time</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3823"></a><tt class="py-lineno">3823</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">datetime_to_str</tt><tt class="py-op">:</tt> </tt>
<a name="L3824"></a><tt class="py-lineno">3824</tt>  <tt class="py-line">                    <tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1744" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1744', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">v</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'T'</tt><tt class="py-op">,</tt><tt class="py-string">' '</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt> </tt>
<a name="L3825"></a><tt class="py-lineno">3825</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">,</tt><tt class="py-name">SERIALIZABLE_TYPES</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3826"></a><tt class="py-lineno">3826</tt>  <tt class="py-line">                <tt class="py-keyword">del</tt> <tt class="py-name">d</tt><tt class="py-op">[</tt><tt id="link-1745" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1745', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> </tt>
<a name="L3827"></a><tt class="py-lineno">3827</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">d</tt> </tt>
</div></div><a name="L3828"></a><tt class="py-lineno">3828</tt>  <tt class="py-line"> </tt>
<a name="L3829"></a><tt class="py-lineno">3829</tt>  <tt class="py-line"> </tt>
<a name="Row_unpickler"></a><div id="Row_unpickler-def"><a name="L3830"></a><tt class="py-lineno">3830</tt> <a class="py-toggle" href="#" id="Row_unpickler-toggle" onclick="return toggle('Row_unpickler');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#Row_unpickler">Row_unpickler</a><tt class="py-op">(</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row_unpickler-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Row_unpickler-expanded"><a name="L3831"></a><tt class="py-lineno">3831</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt id="link-1746" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1746', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3832"></a><tt class="py-lineno">3832</tt>  <tt class="py-line"> </tt>
<a name="Row_pickler"></a><div id="Row_pickler-def"><a name="L3833"></a><tt class="py-lineno">3833</tt> <a class="py-toggle" href="#" id="Row_pickler-toggle" onclick="return toggle('Row_pickler');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#Row_pickler">Row_pickler</a><tt class="py-op">(</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Row_pickler-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Row_pickler-expanded"><a name="L3834"></a><tt class="py-lineno">3834</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt id="link-1747" class="py-name" targets="Function web2py.gluon.dal.Row_unpickler()=web2py.gluon.dal-module.html#Row_unpickler"><a title="web2py.gluon.dal.Row_unpickler" class="py-name" href="#" onclick="return doclink('link-1747', 'Row_unpickler', 'link-1747');">Row_unpickler</a></tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">.</tt><tt id="link-1748" class="py-name"><a title="web2py.gluon.dal.Row.as_dict
web2py.gluon.dal.Rows.as_dict" class="py-name" href="#" onclick="return doclink('link-1748', 'as_dict', 'link-1725');">as_dict</a></tt><tt class="py-op">(</tt><tt class="py-name">datetime_to_str</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3835"></a><tt class="py-lineno">3835</tt>  <tt class="py-line"> </tt>
<a name="L3836"></a><tt class="py-lineno">3836</tt>  <tt class="py-line"><tt class="py-name">copy_reg</tt><tt class="py-op">.</tt><tt class="py-name">pickle</tt><tt class="py-op">(</tt><tt id="link-1749" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1749', 'Row', 'link-600');">Row</a></tt><tt class="py-op">,</tt> <tt id="link-1750" class="py-name" targets="Function web2py.gluon.dal.Row_pickler()=web2py.gluon.dal-module.html#Row_pickler"><a title="web2py.gluon.dal.Row_pickler" class="py-name" href="#" onclick="return doclink('link-1750', 'Row_pickler', 'link-1750');">Row_pickler</a></tt><tt class="py-op">,</tt> <tt id="link-1751" class="py-name"><a title="web2py.gluon.dal.Row_unpickler" class="py-name" href="#" onclick="return doclink('link-1751', 'Row_unpickler', 'link-1747');">Row_unpickler</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3837"></a><tt class="py-lineno">3837</tt>  <tt class="py-line"> </tt>
<a name="L3838"></a><tt class="py-lineno">3838</tt>  <tt class="py-line"> </tt>
<a name="L3839"></a><tt class="py-lineno">3839</tt>  <tt class="py-line"><tt class="py-comment">################################################################################</tt> </tt>
<a name="L3840"></a><tt class="py-lineno">3840</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># Everything below should be independent on the specifics of the</tt> </tt>
<a name="L3841"></a><tt class="py-lineno">3841</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># database and should for RDBMs and some NoSQL databases</tt> </tt>
<a name="L3842"></a><tt class="py-lineno">3842</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">################################################################################</tt> </tt>
<a name="L3843"></a><tt class="py-lineno">3843</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="SQLCallableList"></a><div id="SQLCallableList-def"><a name="L3844"></a><tt class="py-lineno">3844</tt> <a class="py-toggle" href="#" id="SQLCallableList-toggle" onclick="return toggle('SQLCallableList');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCallableList-class.html">SQLCallableList</a><tt class="py-op">(</tt><tt class="py-base-class">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCallableList-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="SQLCallableList-expanded"><a name="SQLCallableList.__call__"></a><div id="SQLCallableList.__call__-def"><a name="L3845"></a><tt class="py-lineno">3845</tt> <a class="py-toggle" href="#" id="SQLCallableList.__call__-toggle" onclick="return toggle('SQLCallableList.__call__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCallableList-class.html#__call__">__call__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCallableList.__call__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLCallableList.__call__-expanded"><a name="L3846"></a><tt class="py-lineno">3846</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L3847"></a><tt class="py-lineno">3847</tt>  <tt class="py-line"> </tt>
<a name="L3848"></a><tt class="py-lineno">3848</tt>  <tt class="py-line"> </tt>
<a name="DAL"></a><div id="DAL-def"><a name="L3849"></a><tt class="py-lineno">3849</tt> <a class="py-toggle" href="#" id="DAL-toggle" onclick="return toggle('DAL');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html">DAL</a><tt class="py-op">(</tt><tt class="py-base-class">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="DAL-expanded"><a name="L3850"></a><tt class="py-lineno">3850</tt>  <tt class="py-line"> </tt>
<a name="L3851"></a><tt class="py-lineno">3851</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L3852"></a><tt class="py-lineno">3852</tt>  <tt class="py-line"><tt class="py-docstring">    an instance of this class represents a database connection</tt> </tt>
<a name="L3853"></a><tt class="py-lineno">3853</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L3854"></a><tt class="py-lineno">3854</tt>  <tt class="py-line"><tt class="py-docstring">    Example::</tt> </tt>
<a name="L3855"></a><tt class="py-lineno">3855</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L3856"></a><tt class="py-lineno">3856</tt>  <tt class="py-line"><tt class="py-docstring">       db = DAL('sqlite://test.db')</tt> </tt>
<a name="L3857"></a><tt class="py-lineno">3857</tt>  <tt class="py-line"><tt class="py-docstring">       db.define_table('tablename', Field('fieldname1'),</tt> </tt>
<a name="L3858"></a><tt class="py-lineno">3858</tt>  <tt class="py-line"><tt class="py-docstring">                                    Field('fieldname2'))</tt> </tt>
<a name="L3859"></a><tt class="py-lineno">3859</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L3860"></a><tt class="py-lineno">3860</tt>  <tt class="py-line"> </tt>
<a name="L3861"></a><tt class="py-lineno">3861</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="DAL.set_folder"></a><div id="DAL.set_folder-def"><a name="L3862"></a><tt class="py-lineno">3862</tt> <a class="py-toggle" href="#" id="DAL.set_folder-toggle" onclick="return toggle('DAL.set_folder');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#set_folder">set_folder</a><tt class="py-op">(</tt><tt class="py-param">folder</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.set_folder-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.set_folder-expanded"><a name="L3863"></a><tt class="py-lineno">3863</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L3864"></a><tt class="py-lineno">3864</tt>  <tt class="py-line"><tt class="py-docstring">        # ## this allows gluon to set a folder for this thread</tt> </tt>
<a name="L3865"></a><tt class="py-lineno">3865</tt>  <tt class="py-line"><tt class="py-docstring">        # ## &lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt; Should go away as new DAL replaces old sql.py</tt> </tt>
<a name="L3866"></a><tt class="py-lineno">3866</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L3867"></a><tt class="py-lineno">3867</tt>  <tt class="py-line">        <tt id="link-1752" class="py-name"><a title="web2py.gluon.dal.BaseAdapter" class="py-name" href="#" onclick="return doclink('link-1752', 'BaseAdapter', 'link-825');">BaseAdapter</a></tt><tt class="py-op">.</tt><tt id="link-1753" class="py-name" targets="Static Method web2py.gluon.dal.ConnectionPool.set_folder()=web2py.gluon.dal.ConnectionPool-class.html#set_folder,Static Method web2py.gluon.dal.DAL.set_folder()=web2py.gluon.dal.DAL-class.html#set_folder"><a title="web2py.gluon.dal.ConnectionPool.set_folder
web2py.gluon.dal.DAL.set_folder" class="py-name" href="#" onclick="return doclink('link-1753', 'set_folder', 'link-1753');">set_folder</a></tt><tt class="py-op">(</tt><tt class="py-name">folder</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3868"></a><tt class="py-lineno">3868</tt>  <tt class="py-line"> </tt>
<a name="L3869"></a><tt class="py-lineno">3869</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="DAL.distributed_transaction_begin"></a><div id="DAL.distributed_transaction_begin-def"><a name="L3870"></a><tt class="py-lineno">3870</tt> <a class="py-toggle" href="#" id="DAL.distributed_transaction_begin-toggle" onclick="return toggle('DAL.distributed_transaction_begin');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#distributed_transaction_begin">distributed_transaction_begin</a><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-param">instances</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.distributed_transaction_begin-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.distributed_transaction_begin-expanded"><a name="L3871"></a><tt class="py-lineno">3871</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1754" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1754', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3872"></a><tt class="py-lineno">3872</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> </tt>
<a name="L3873"></a><tt class="py-lineno">3873</tt>  <tt class="py-line">        <tt class="py-name">thread_key</tt> <tt class="py-op">=</tt> <tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-1755" class="py-name"><a title="web2py.gluon.rocket.Connection.socket" class="py-name" href="#" onclick="return doclink('link-1755', 'socket', 'link-6');">socket</a></tt><tt class="py-op">.</tt><tt class="py-name">gethostname</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">threading</tt><tt class="py-op">.</tt><tt class="py-name">currentThread</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3874"></a><tt class="py-lineno">3874</tt>  <tt class="py-line">        <tt id="link-1756" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1756', 'keys', 'link-269');">keys</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'%s.%i'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">thread_key</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1757" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1757', 'instances', 'link-124');">instances</a></tt><tt class="py-op">]</tt> </tt>
<a name="L3875"></a><tt class="py-lineno">3875</tt>  <tt class="py-line">        <tt id="link-1758" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1758', 'instances', 'link-124');">instances</a></tt> <tt class="py-op">=</tt> <tt class="py-name">enumerate</tt><tt class="py-op">(</tt><tt id="link-1759" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1759', 'instances', 'link-124');">instances</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3876"></a><tt class="py-lineno">3876</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1760" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1760', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3877"></a><tt class="py-lineno">3877</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1761" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-1761', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3878"></a><tt class="py-lineno">3878</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L3879"></a><tt class="py-lineno">3879</tt>  <tt class="py-line">                    <tt class="py-string">'distributed transaction not suported by %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_dbname</tt> </tt>
<a name="L3880"></a><tt class="py-lineno">3880</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1762" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1762', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3881"></a><tt class="py-lineno">3881</tt>  <tt class="py-line">            <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1763" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.distributed_transaction_begin()=web2py.gluon.dal.BaseAdapter-class.html#distributed_transaction_begin,Static Method web2py.gluon.dal.DAL.distributed_transaction_begin()=web2py.gluon.dal.DAL-class.html#distributed_transaction_begin,Method web2py.gluon.dal.MySQLAdapter.distributed_transaction_begin()=web2py.gluon.dal.MySQLAdapter-class.html#distributed_transaction_begin,Method web2py.gluon.dal.NoSQLAdapter.distributed_transaction_begin()=web2py.gluon.dal.NoSQLAdapter-class.html#distributed_transaction_begin,Method web2py.gluon.dal.PostgreSQLAdapter.distributed_transaction_begin()=web2py.gluon.dal.PostgreSQLAdapter-class.html#distributed_transaction_begin"><a title="web2py.gluon.dal.BaseAdapter.distributed_transaction_begin
web2py.gluon.dal.DAL.distributed_transaction_begin
web2py.gluon.dal.MySQLAdapter.distributed_transaction_begin
web2py.gluon.dal.NoSQLAdapter.distributed_transaction_begin
web2py.gluon.dal.PostgreSQLAdapter.distributed_transaction_begin" class="py-name" href="#" onclick="return doclink('link-1763', 'distributed_transaction_begin', 'link-1763');">distributed_transaction_begin</a></tt><tt class="py-op">(</tt><tt id="link-1764" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1764', 'keys', 'link-269');">keys</a></tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3882"></a><tt class="py-lineno">3882</tt>  <tt class="py-line"> </tt>
<a name="L3883"></a><tt class="py-lineno">3883</tt>  <tt class="py-line">    <tt class="py-decorator">@</tt><tt class="py-decorator">staticmethod</tt> </tt>
<a name="DAL.distributed_transaction_commit"></a><div id="DAL.distributed_transaction_commit-def"><a name="L3884"></a><tt class="py-lineno">3884</tt> <a class="py-toggle" href="#" id="DAL.distributed_transaction_commit-toggle" onclick="return toggle('DAL.distributed_transaction_commit');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#distributed_transaction_commit">distributed_transaction_commit</a><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-param">instances</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.distributed_transaction_commit-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.distributed_transaction_commit-expanded"><a name="L3885"></a><tt class="py-lineno">3885</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-1765" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1765', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3886"></a><tt class="py-lineno">3886</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> </tt>
<a name="L3887"></a><tt class="py-lineno">3887</tt>  <tt class="py-line">        <tt id="link-1766" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1766', 'instances', 'link-124');">instances</a></tt> <tt class="py-op">=</tt> <tt class="py-name">enumerate</tt><tt class="py-op">(</tt><tt id="link-1767" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1767', 'instances', 'link-124');">instances</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3888"></a><tt class="py-lineno">3888</tt>  <tt class="py-line">        <tt class="py-name">thread_key</tt> <tt class="py-op">=</tt> <tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-1768" class="py-name"><a title="web2py.gluon.rocket.Connection.socket" class="py-name" href="#" onclick="return doclink('link-1768', 'socket', 'link-6');">socket</a></tt><tt class="py-op">.</tt><tt class="py-name">gethostname</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">threading</tt><tt class="py-op">.</tt><tt class="py-name">currentThread</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3889"></a><tt class="py-lineno">3889</tt>  <tt class="py-line">        <tt id="link-1769" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1769', 'keys', 'link-269');">keys</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-string">'%s.%i'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">thread_key</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1770" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1770', 'instances', 'link-124');">instances</a></tt><tt class="py-op">]</tt> </tt>
<a name="L3890"></a><tt class="py-lineno">3890</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1771" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1771', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3891"></a><tt class="py-lineno">3891</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1772" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.support_distributed_transaction
web2py.gluon.dal.FireBirdAdapter.support_distributed_transaction
web2py.gluon.dal.MySQLAdapter.support_distributed_transaction
web2py.gluon.dal.PostgreSQLAdapter.support_distributed_transaction
web2py.gluon.dal.SAPDBAdapter.support_distributed_transaction" class="py-name" href="#" onclick="return doclink('link-1772', 'support_distributed_transaction', 'link-163');">support_distributed_transaction</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3892"></a><tt class="py-lineno">3892</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L3893"></a><tt class="py-lineno">3893</tt>  <tt class="py-line">                    <tt class="py-string">'distributed transaction not suported by %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_dbanme</tt> </tt>
<a name="L3894"></a><tt class="py-lineno">3894</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3895"></a><tt class="py-lineno">3895</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1773" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1773', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3896"></a><tt class="py-lineno">3896</tt>  <tt class="py-line">                <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1774" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.prepare
web2py.gluon.dal.MySQLAdapter.prepare
web2py.gluon.dal.NoSQLAdapter.prepare
web2py.gluon.dal.PostgreSQLAdapter.prepare" class="py-name" href="#" onclick="return doclink('link-1774', 'prepare', 'link-576');">prepare</a></tt><tt class="py-op">(</tt><tt id="link-1775" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1775', 'keys', 'link-269');">keys</a></tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3897"></a><tt class="py-lineno">3897</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L3898"></a><tt class="py-lineno">3898</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1776" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1776', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3899"></a><tt class="py-lineno">3899</tt>  <tt class="py-line">                <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1777" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.rollback_prepared()=web2py.gluon.dal.BaseAdapter-class.html#rollback_prepared,Method web2py.gluon.dal.MySQLAdapter.rollback_prepared()=web2py.gluon.dal.MySQLAdapter-class.html#rollback_prepared,Method web2py.gluon.dal.NoSQLAdapter.rollback_prepared()=web2py.gluon.dal.NoSQLAdapter-class.html#rollback_prepared,Method web2py.gluon.dal.PostgreSQLAdapter.rollback_prepared()=web2py.gluon.dal.PostgreSQLAdapter-class.html#rollback_prepared"><a title="web2py.gluon.dal.BaseAdapter.rollback_prepared
web2py.gluon.dal.MySQLAdapter.rollback_prepared
web2py.gluon.dal.NoSQLAdapter.rollback_prepared
web2py.gluon.dal.PostgreSQLAdapter.rollback_prepared" class="py-name" href="#" onclick="return doclink('link-1777', 'rollback_prepared', 'link-1777');">rollback_prepared</a></tt><tt class="py-op">(</tt><tt id="link-1778" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1778', 'keys', 'link-269');">keys</a></tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3900"></a><tt class="py-lineno">3900</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">'failure to commit distributed transaction'</tt> </tt>
<a name="L3901"></a><tt class="py-lineno">3901</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3902"></a><tt class="py-lineno">3902</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-name">db</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-1779" class="py-name"><a title="web2py.gluon.tools.PluginManager.instances" class="py-name" href="#" onclick="return doclink('link-1779', 'instances', 'link-124');">instances</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3903"></a><tt class="py-lineno">3903</tt>  <tt class="py-line">                <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1780" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.commit_prepared()=web2py.gluon.dal.BaseAdapter-class.html#commit_prepared,Method web2py.gluon.dal.MySQLAdapter.commit_prepared()=web2py.gluon.dal.MySQLAdapter-class.html#commit_prepared,Method web2py.gluon.dal.NoSQLAdapter.commit_prepared()=web2py.gluon.dal.NoSQLAdapter-class.html#commit_prepared,Method web2py.gluon.dal.PostgreSQLAdapter.commit_prepared()=web2py.gluon.dal.PostgreSQLAdapter-class.html#commit_prepared"><a title="web2py.gluon.dal.BaseAdapter.commit_prepared
web2py.gluon.dal.MySQLAdapter.commit_prepared
web2py.gluon.dal.NoSQLAdapter.commit_prepared
web2py.gluon.dal.PostgreSQLAdapter.commit_prepared" class="py-name" href="#" onclick="return doclink('link-1780', 'commit_prepared', 'link-1780');">commit_prepared</a></tt><tt class="py-op">(</tt><tt id="link-1781" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-1781', 'keys', 'link-269');">keys</a></tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L3904"></a><tt class="py-lineno">3904</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> </tt>
</div><a name="L3905"></a><tt class="py-lineno">3905</tt>  <tt class="py-line"> </tt>
<a name="L3906"></a><tt class="py-lineno">3906</tt>  <tt class="py-line"> </tt>
<a name="DAL.__init__"></a><div id="DAL.__init__-def"><a name="L3907"></a><tt class="py-lineno">3907</tt> <a class="py-toggle" href="#" id="DAL.__init__-toggle" onclick="return toggle('DAL.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">uri</tt><tt class="py-op">=</tt><tt class="py-string">'sqlite://dummy.db'</tt><tt class="py-op">,</tt> <tt class="py-param">pool_size</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-param">folder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L3908"></a><tt class="py-lineno">3908</tt>  <tt class="py-line">                 <tt class="py-param">db_codec</tt><tt class="py-op">=</tt><tt class="py-string">'UTF-8'</tt><tt class="py-op">,</tt> <tt class="py-param">check_reserved</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L3909"></a><tt class="py-lineno">3909</tt>  <tt class="py-line">                 <tt class="py-param">migrate</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L3910"></a><tt class="py-lineno">3910</tt>  <tt class="py-line">                 <tt class="py-param">migrate_enabled</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> <tt class="py-param">fake_migrate_all</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L3911"></a><tt class="py-lineno">3911</tt>  <tt class="py-line">                 <tt class="py-param">decode_credentials</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> <tt class="py-param">driver_args</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L3912"></a><tt class="py-lineno">3912</tt>  <tt class="py-line">                 <tt class="py-param">adapter_args</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> <tt class="py-param">attempts</tt><tt class="py-op">=</tt><tt class="py-number">5</tt><tt class="py-op">,</tt> <tt class="py-param">auto_import</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__init__-expanded"><a name="L3913"></a><tt class="py-lineno">3913</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L3914"></a><tt class="py-lineno">3914</tt>  <tt class="py-line"><tt class="py-docstring">        Creates a new Database Abstraction Layer instance.</tt> </tt>
<a name="L3915"></a><tt class="py-lineno">3915</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L3916"></a><tt class="py-lineno">3916</tt>  <tt class="py-line"><tt class="py-docstring">        Keyword arguments:</tt> </tt>
<a name="L3917"></a><tt class="py-lineno">3917</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L3918"></a><tt class="py-lineno">3918</tt>  <tt class="py-line"><tt class="py-docstring">        :uri: string that contains information for connecting to a database.</tt> </tt>
<a name="L3919"></a><tt class="py-lineno">3919</tt>  <tt class="py-line"><tt class="py-docstring">               (default: 'sqlite://dummy.db')</tt> </tt>
<a name="L3920"></a><tt class="py-lineno">3920</tt>  <tt class="py-line"><tt class="py-docstring">        :pool_size: How many open connections to make to the database object.</tt> </tt>
<a name="L3921"></a><tt class="py-lineno">3921</tt>  <tt class="py-line"><tt class="py-docstring">        :folder: &lt;please update me&gt;</tt> </tt>
<a name="L3922"></a><tt class="py-lineno">3922</tt>  <tt class="py-line"><tt class="py-docstring">        :db_codec: string encoding of the database (default: 'UTF-8')</tt> </tt>
<a name="L3923"></a><tt class="py-lineno">3923</tt>  <tt class="py-line"><tt class="py-docstring">        :check_reserved: list of adapters to check tablenames and column names</tt> </tt>
<a name="L3924"></a><tt class="py-lineno">3924</tt>  <tt class="py-line"><tt class="py-docstring">                         against sql reserved keywords. (Default None)</tt> </tt>
<a name="L3925"></a><tt class="py-lineno">3925</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L3926"></a><tt class="py-lineno">3926</tt>  <tt class="py-line"><tt class="py-docstring">        * 'common' List of sql keywords that are common to all database types</tt> </tt>
<a name="L3927"></a><tt class="py-lineno">3927</tt>  <tt class="py-line"><tt class="py-docstring">                such as "SELECT, INSERT". (recommended)</tt> </tt>
<a name="L3928"></a><tt class="py-lineno">3928</tt>  <tt class="py-line"><tt class="py-docstring">        * 'all' Checks against all known SQL keywords. (not recommended)</tt> </tt>
<a name="L3929"></a><tt class="py-lineno">3929</tt>  <tt class="py-line"><tt class="py-docstring">                &lt;adaptername&gt; Checks against the specific adapters list of keywords</tt> </tt>
<a name="L3930"></a><tt class="py-lineno">3930</tt>  <tt class="py-line"><tt class="py-docstring">                (recommended)</tt> </tt>
<a name="L3931"></a><tt class="py-lineno">3931</tt>  <tt class="py-line"><tt class="py-docstring">        * '&lt;adaptername&gt;_nonreserved' Checks against the specific adapters</tt> </tt>
<a name="L3932"></a><tt class="py-lineno">3932</tt>  <tt class="py-line"><tt class="py-docstring">                list of nonreserved keywords. (if available)</tt> </tt>
<a name="L3933"></a><tt class="py-lineno">3933</tt>  <tt class="py-line"><tt class="py-docstring">        :migrate (defaults to True) sets default migrate behavior for all tables</tt> </tt>
<a name="L3934"></a><tt class="py-lineno">3934</tt>  <tt class="py-line"><tt class="py-docstring">        :fake_migrate (defaults to False) sets default fake_migrate behavior for all tables</tt> </tt>
<a name="L3935"></a><tt class="py-lineno">3935</tt>  <tt class="py-line"><tt class="py-docstring">        :migrate_enabled (defaults to True). If set to False disables ALL migrations</tt> </tt>
<a name="L3936"></a><tt class="py-lineno">3936</tt>  <tt class="py-line"><tt class="py-docstring">        :fake_migrate_all (defaults to False). If sets to True fake migrates ALL tables</tt> </tt>
<a name="L3937"></a><tt class="py-lineno">3937</tt>  <tt class="py-line"><tt class="py-docstring">        :attempts (defaults to 5). Number of times to attempt connecting</tt> </tt>
<a name="L3938"></a><tt class="py-lineno">3938</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L3939"></a><tt class="py-lineno">3939</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">decode_credentials</tt><tt class="py-op">:</tt> </tt>
<a name="L3940"></a><tt class="py-lineno">3940</tt>  <tt class="py-line">            <tt class="py-name">credential_decoder</tt> <tt class="py-op">=</tt> <tt class="py-keyword">lambda</tt> <tt class="py-name">cred</tt><tt class="py-op">:</tt> <tt class="py-name">cred</tt> </tt>
<a name="L3941"></a><tt class="py-lineno">3941</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3942"></a><tt class="py-lineno">3942</tt>  <tt class="py-line">            <tt class="py-name">credential_decoder</tt> <tt class="py-op">=</tt> <tt class="py-keyword">lambda</tt> <tt class="py-name">cred</tt><tt class="py-op">:</tt> <tt class="py-name">urllib</tt><tt class="py-op">.</tt><tt class="py-name">unquote</tt><tt class="py-op">(</tt><tt class="py-name">cred</tt><tt class="py-op">)</tt> </tt>
<a name="L3943"></a><tt class="py-lineno">3943</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">folder</tt><tt class="py-op">:</tt> </tt>
<a name="L3944"></a><tt class="py-lineno">3944</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1782" class="py-name"><a title="web2py.gluon.dal.ConnectionPool.set_folder
web2py.gluon.dal.DAL.set_folder" class="py-name" href="#" onclick="return doclink('link-1782', 'set_folder', 'link-1753');">set_folder</a></tt><tt class="py-op">(</tt><tt class="py-name">folder</tt><tt class="py-op">)</tt> </tt>
<a name="L3945"></a><tt class="py-lineno">3945</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri</tt> <tt class="py-op">=</tt> <tt class="py-name">uri</tt> </tt>
<a name="L3946"></a><tt class="py-lineno">3946</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_pool_size</tt> <tt class="py-op">=</tt> <tt class="py-name">pool_size</tt> </tt>
<a name="L3947"></a><tt class="py-lineno">3947</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db_codec</tt> <tt class="py-op">=</tt> <tt class="py-name">db_codec</tt> </tt>
<a name="L3948"></a><tt class="py-lineno">3948</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_lastsql</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L3949"></a><tt class="py-lineno">3949</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_timings</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3950"></a><tt class="py-lineno">3950</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_pending_references</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L3951"></a><tt class="py-lineno">3951</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_request_tenant</tt> <tt class="py-op">=</tt> <tt class="py-string">'request_tenant'</tt> </tt>
<a name="L3952"></a><tt class="py-lineno">3952</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_common_fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L3953"></a><tt class="py-lineno">3953</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">attempts</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isdigit</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">attempts</tt> <tt class="py-op">&lt;</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L3954"></a><tt class="py-lineno">3954</tt>  <tt class="py-line">            <tt class="py-name">attempts</tt> <tt class="py-op">=</tt> <tt class="py-number">5</tt> </tt>
<a name="L3955"></a><tt class="py-lineno">3955</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">uri</tt><tt class="py-op">:</tt> </tt>
<a name="L3956"></a><tt class="py-lineno">3956</tt>  <tt class="py-line">            <tt class="py-name">uris</tt> <tt class="py-op">=</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">,</tt><tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt><tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">uri</tt> <tt class="py-keyword">or</tt> <tt class="py-op">[</tt><tt class="py-name">uri</tt><tt class="py-op">]</tt> </tt>
<a name="L3957"></a><tt class="py-lineno">3957</tt>  <tt class="py-line">            <tt id="link-1783" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-1783', 'error', 'link-884');">error</a></tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt>
<a name="L3958"></a><tt class="py-lineno">3958</tt>  <tt class="py-line">            <tt class="py-name">connected</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L3959"></a><tt class="py-lineno">3959</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt id="link-1784" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-1784', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-name">attempts</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3960"></a><tt class="py-lineno">3960</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">uri</tt> <tt class="py-keyword">in</tt> <tt class="py-name">uris</tt><tt class="py-op">:</tt> </tt>
<a name="L3961"></a><tt class="py-lineno">3961</tt>  <tt class="py-line">                    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L3962"></a><tt class="py-lineno">3962</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt id="link-1785" class="py-name"><a title="web2py.gluon.dal.is_jdbc" class="py-name" href="#" onclick="return doclink('link-1785', 'is_jdbc', 'link-93');">is_jdbc</a></tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">uri</tt><tt class="py-op">.</tt><tt id="link-1786" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1786', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'jdbc:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L3963"></a><tt class="py-lineno">3963</tt>  <tt class="py-line">                            <tt class="py-name">uri</tt> <tt class="py-op">=</tt> <tt class="py-string">'jdbc:'</tt><tt class="py-op">+</tt><tt class="py-name">uri</tt> </tt>
<a name="L3964"></a><tt class="py-lineno">3964</tt>  <tt class="py-line">                        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_dbname</tt> <tt class="py-op">=</tt> <tt id="link-1787" class="py-name"><a title="web2py.gluon.dal.regex_dbname" class="py-name" href="#" onclick="return doclink('link-1787', 'regex_dbname', 'link-28');">regex_dbname</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3965"></a><tt class="py-lineno">3965</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_dbname</tt> <tt class="py-keyword">in</tt> <tt id="link-1788" class="py-name"><a title="web2py.gluon.dal.ADAPTERS
web2py.gluon.reserved_sql_keywords.ADAPTERS" class="py-name" href="#" onclick="return doclink('link-1788', 'ADAPTERS', 'link-1589');">ADAPTERS</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3966"></a><tt class="py-lineno">3966</tt>  <tt class="py-line">                            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"Error in URI '%s' or database not supported"</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_dbname</tt> </tt>
<a name="L3967"></a><tt class="py-lineno">3967</tt>  <tt class="py-line">                        <tt class="py-comment"># notice that driver args or {} else driver_args defaults to {} global, not correct</tt> </tt>
<a name="L3968"></a><tt class="py-lineno">3968</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-name">args</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">uri</tt><tt class="py-op">,</tt><tt class="py-name">pool_size</tt><tt class="py-op">,</tt><tt class="py-name">folder</tt><tt class="py-op">,</tt><tt class="py-name">db_codec</tt><tt class="py-op">,</tt><tt class="py-name">credential_decoder</tt><tt class="py-op">,</tt><tt class="py-name">driver_args</tt> <tt class="py-keyword">or</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> <tt class="py-name">adapter_args</tt><tt class="py-op">)</tt> </tt>
<a name="L3969"></a><tt class="py-lineno">3969</tt>  <tt class="py-line">                        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt> <tt class="py-op">=</tt> <tt id="link-1789" class="py-name"><a title="web2py.gluon.dal.ADAPTERS
web2py.gluon.reserved_sql_keywords.ADAPTERS" class="py-name" href="#" onclick="return doclink('link-1789', 'ADAPTERS', 'link-1589');">ADAPTERS</a></tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_dbname</tt><tt class="py-op">]</tt><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-name">args</tt><tt class="py-op">)</tt> </tt>
<a name="L3970"></a><tt class="py-lineno">3970</tt>  <tt class="py-line">                        <tt class="py-name">connected</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L3971"></a><tt class="py-lineno">3971</tt>  <tt class="py-line">                        <tt class="py-keyword">break</tt> </tt>
<a name="L3972"></a><tt class="py-lineno">3972</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">:</tt> </tt>
<a name="L3973"></a><tt class="py-lineno">3973</tt>  <tt class="py-line">                        <tt class="py-keyword">raise</tt> </tt>
<a name="L3974"></a><tt class="py-lineno">3974</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt id="link-1790" class="py-name"><a title="exceptions.Exception" class="py-name" href="#" onclick="return doclink('link-1790', 'Exception', 'link-328');">Exception</a></tt><tt class="py-op">,</tt> <tt id="link-1791" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-1791', 'error', 'link-884');">error</a></tt><tt class="py-op">:</tt> </tt>
<a name="L3975"></a><tt class="py-lineno">3975</tt>  <tt class="py-line">                        <tt class="py-name">sys</tt><tt class="py-op">.</tt><tt class="py-name">stderr</tt><tt class="py-op">.</tt><tt id="link-1792" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-1792', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'DEBUG_c: Exception %r'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-op">(</tt><tt id="link-1793" class="py-name"><a title="exceptions.Exception" class="py-name" href="#" onclick="return doclink('link-1793', 'Exception', 'link-328');">Exception</a></tt><tt class="py-op">,</tt> <tt id="link-1794" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-1794', 'error', 'link-884');">error</a></tt><tt class="py-op">,</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L3976"></a><tt class="py-lineno">3976</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">connected</tt><tt class="py-op">:</tt> </tt>
<a name="L3977"></a><tt class="py-lineno">3977</tt>  <tt class="py-line">                    <tt class="py-keyword">break</tt> </tt>
<a name="L3978"></a><tt class="py-lineno">3978</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3979"></a><tt class="py-lineno">3979</tt>  <tt class="py-line">                    <tt id="link-1795" class="py-name"><a title="datetime.time" class="py-name" href="#" onclick="return doclink('link-1795', 'time', 'link-4');">time</a></tt><tt class="py-op">.</tt><tt class="py-name">sleep</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
<a name="L3980"></a><tt class="py-lineno">3980</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">connected</tt><tt class="py-op">:</tt> </tt>
<a name="L3981"></a><tt class="py-lineno">3981</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Failure to connect, tried %d times:\n%s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">attempts</tt><tt class="py-op">,</tt> <tt id="link-1796" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-1796', 'error', 'link-884');">error</a></tt><tt class="py-op">)</tt> </tt>
<a name="L3982"></a><tt class="py-lineno">3982</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L3983"></a><tt class="py-lineno">3983</tt>  <tt class="py-line">            <tt class="py-name">args</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-string">'None'</tt><tt class="py-op">,</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-name">folder</tt><tt class="py-op">,</tt><tt class="py-name">db_codec</tt><tt class="py-op">)</tt> </tt>
<a name="L3984"></a><tt class="py-lineno">3984</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt> <tt class="py-op">=</tt> <tt id="link-1797" class="py-name"><a title="web2py.gluon.dal.BaseAdapter" class="py-name" href="#" onclick="return doclink('link-1797', 'BaseAdapter', 'link-825');">BaseAdapter</a></tt><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-name">args</tt><tt class="py-op">)</tt> </tt>
<a name="L3985"></a><tt class="py-lineno">3985</tt>  <tt class="py-line">            <tt class="py-name">migrate</tt> <tt class="py-op">=</tt> <tt class="py-name">fake_migrate</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt>
<a name="L3986"></a><tt class="py-lineno">3986</tt>  <tt class="py-line">        <tt class="py-name">adapter</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt> </tt>
<a name="L3987"></a><tt class="py-lineno">3987</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri_hash</tt> <tt class="py-op">=</tt> <tt class="py-name">hashlib</tt><tt class="py-op">.</tt><tt class="py-name">md5</tt><tt class="py-op">(</tt><tt class="py-name">adapter</tt><tt class="py-op">.</tt><tt class="py-name">uri</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">hexdigest</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3988"></a><tt class="py-lineno">3988</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1798" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1798', 'tables', 'link-313');">tables</a></tt> <tt class="py-op">=</tt> <tt id="link-1799" class="py-name" targets="Class web2py.gluon.dal.SQLCallableList=web2py.gluon.dal.SQLCallableList-class.html"><a title="web2py.gluon.dal.SQLCallableList" class="py-name" href="#" onclick="return doclink('link-1799', 'SQLCallableList', 'link-1799');">SQLCallableList</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L3989"></a><tt class="py-lineno">3989</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">check_reserved</tt> <tt class="py-op">=</tt> <tt class="py-name">check_reserved</tt> </tt>
<a name="L3990"></a><tt class="py-lineno">3990</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">check_reserved</tt><tt class="py-op">:</tt> </tt>
<a name="L3991"></a><tt class="py-lineno">3991</tt>  <tt class="py-line">            <tt class="py-keyword">from</tt> <tt id="link-1800" class="py-name" targets="Module web2py.gluon.reserved_sql_keywords=web2py.gluon.reserved_sql_keywords-module.html"><a title="web2py.gluon.reserved_sql_keywords" class="py-name" href="#" onclick="return doclink('link-1800', 'reserved_sql_keywords', 'link-1800');">reserved_sql_keywords</a></tt> <tt class="py-keyword">import</tt> <tt id="link-1801" class="py-name"><a title="web2py.gluon.dal.ADAPTERS
web2py.gluon.reserved_sql_keywords.ADAPTERS" class="py-name" href="#" onclick="return doclink('link-1801', 'ADAPTERS', 'link-1589');">ADAPTERS</a></tt> <tt class="py-keyword">as</tt> <tt class="py-name">RSK</tt> </tt>
<a name="L3992"></a><tt class="py-lineno">3992</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">RSK</tt> <tt class="py-op">=</tt> <tt class="py-name">RSK</tt> </tt>
<a name="L3993"></a><tt class="py-lineno">3993</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_migrate</tt> <tt class="py-op">=</tt> <tt class="py-name">migrate</tt> </tt>
<a name="L3994"></a><tt class="py-lineno">3994</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_fake_migrate</tt> <tt class="py-op">=</tt> <tt class="py-name">fake_migrate</tt> </tt>
<a name="L3995"></a><tt class="py-lineno">3995</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_migrate_enabled</tt> <tt class="py-op">=</tt> <tt class="py-name">migrate_enabled</tt> </tt>
<a name="L3996"></a><tt class="py-lineno">3996</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_fake_migrate_all</tt> <tt class="py-op">=</tt> <tt class="py-name">fake_migrate_all</tt> </tt>
<a name="L3997"></a><tt class="py-lineno">3997</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">auto_import</tt><tt class="py-op">:</tt> </tt>
<a name="L3998"></a><tt class="py-lineno">3998</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1802" class="py-name" targets="Method web2py.gluon.dal.DAL.import_table_definitions()=web2py.gluon.dal.DAL-class.html#import_table_definitions"><a title="web2py.gluon.dal.DAL.import_table_definitions" class="py-name" href="#" onclick="return doclink('link-1802', 'import_table_definitions', 'link-1802');">import_table_definitions</a></tt><tt class="py-op">(</tt><tt class="py-name">adapter</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">)</tt> </tt>
</div><a name="L3999"></a><tt class="py-lineno">3999</tt>  <tt class="py-line"> </tt>
<a name="DAL.import_table_definitions"></a><div id="DAL.import_table_definitions-def"><a name="L4000"></a><tt class="py-lineno">4000</tt> <a class="py-toggle" href="#" id="DAL.import_table_definitions-toggle" onclick="return toggle('DAL.import_table_definitions');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#import_table_definitions">import_table_definitions</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">path</tt><tt class="py-op">,</tt><tt class="py-param">migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-param">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.import_table_definitions-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.import_table_definitions-expanded"><a name="L4001"></a><tt class="py-lineno">4001</tt>  <tt class="py-line">        <tt class="py-name">pattern</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-1803" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1803', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri_hash</tt><tt class="py-op">+</tt><tt class="py-string">'_*.table'</tt><tt class="py-op">)</tt> </tt>
<a name="L4002"></a><tt class="py-lineno">4002</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">filename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">glob</tt><tt class="py-op">.</tt><tt class="py-name">glob</tt><tt class="py-op">(</tt><tt class="py-name">pattern</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4003"></a><tt class="py-lineno">4003</tt>  <tt class="py-line">            <tt class="py-name">tfile</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1804" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_open
web2py.gluon.dal.CouchDBAdapter.file_open
web2py.gluon.dal.GoogleDatastoreAdapter.file_open
web2py.gluon.dal.UseDatabaseStoredFile.file_open" class="py-name" href="#" onclick="return doclink('link-1804', 'file_open', 'link-243');">file_open</a></tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-string">'r'</tt><tt class="py-op">)</tt> </tt>
<a name="L4004"></a><tt class="py-lineno">4004</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4005"></a><tt class="py-lineno">4005</tt>  <tt class="py-line">                <tt class="py-name">sql_fields</tt> <tt class="py-op">=</tt> <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt id="link-1805" class="py-name"><a title="web2py.gluon.restricted.RestrictedError.load
web2py.gluon.restricted.TicketStorage.load
web2py.gluon.rewrite.load" class="py-name" href="#" onclick="return doclink('link-1805', 'load', 'link-256');">load</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
<a name="L4006"></a><tt class="py-lineno">4006</tt>  <tt class="py-line">                <tt id="link-1806" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1806', 'name', 'link-119');">name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">filename</tt><tt class="py-op">[</tt><tt id="link-1807" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1807', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">pattern</tt><tt class="py-op">)</tt><tt class="py-op">-</tt><tt class="py-number">7</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">6</tt><tt class="py-op">]</tt> </tt>
<a name="L4007"></a><tt class="py-lineno">4007</tt>  <tt class="py-line">                <tt class="py-name">mf</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">[</tt><tt class="py-string">'sortable'</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt id="link-1808" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-1808', 'Field', 'link-430');">Field</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-name">type</tt><tt class="py-op">=</tt><tt class="py-name">value</tt><tt class="py-op">[</tt><tt class="py-string">'type'</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> \ </tt>
<a name="L4008"></a><tt class="py-lineno">4008</tt>  <tt class="py-line">                          <tt class="py-keyword">for</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt> <tt class="py-keyword">in</tt> <tt class="py-name">sql_fields</tt><tt class="py-op">.</tt><tt id="link-1809" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1809', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L4009"></a><tt class="py-lineno">4009</tt>  <tt class="py-line">                <tt class="py-name">mf</tt><tt class="py-op">.</tt><tt id="link-1810" class="py-name" targets="Method web2py.gluon.dal.Rows.sort()=web2py.gluon.dal.Rows-class.html#sort"><a title="web2py.gluon.dal.Rows.sort" class="py-name" href="#" onclick="return doclink('link-1810', 'sort', 'link-1810');">sort</a></tt><tt class="py-op">(</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-1811" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1811', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt> <tt class="py-name">cmp</tt><tt class="py-op">(</tt><tt class="py-name">a</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt id="link-1812" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-1812', 'b', 'link-188');">b</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4010"></a><tt class="py-lineno">4010</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1813" class="py-name" targets="Method web2py.gluon.dal.DAL.define_table()=web2py.gluon.dal.DAL-class.html#define_table"><a title="web2py.gluon.dal.DAL.define_table" class="py-name" href="#" onclick="return doclink('link-1813', 'define_table', 'link-1813');">define_table</a></tt><tt class="py-op">(</tt><tt id="link-1814" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1814', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-op">[</tt><tt class="py-name">item</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">mf</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
<a name="L4011"></a><tt class="py-lineno">4011</tt>  <tt class="py-line">                                  <tt class="py-op">**</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">migrate</tt><tt class="py-op">=</tt><tt class="py-name">migrate</tt><tt class="py-op">,</tt><tt class="py-name">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">fake_migrate</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4012"></a><tt class="py-lineno">4012</tt>  <tt class="py-line">            <tt class="py-keyword">finally</tt><tt class="py-op">:</tt> </tt>
<a name="L4013"></a><tt class="py-lineno">4013</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1815" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.file_close
web2py.gluon.dal.CouchDBAdapter.file_close
web2py.gluon.dal.GoogleDatastoreAdapter.file_close
web2py.gluon.dal.UseDatabaseStoredFile.file_close" class="py-name" href="#" onclick="return doclink('link-1815', 'file_close', 'link-252');">file_close</a></tt><tt class="py-op">(</tt><tt class="py-name">tfile</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4014"></a><tt class="py-lineno">4014</tt>  <tt class="py-line"> </tt>
<a name="DAL.check_reserved_keyword"></a><div id="DAL.check_reserved_keyword-def"><a name="L4015"></a><tt class="py-lineno">4015</tt> <a class="py-toggle" href="#" id="DAL.check_reserved_keyword-toggle" onclick="return toggle('DAL.check_reserved_keyword');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#check_reserved_keyword">check_reserved_keyword</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">name</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.check_reserved_keyword-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.check_reserved_keyword-expanded"><a name="L4016"></a><tt class="py-lineno">4016</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L4017"></a><tt class="py-lineno">4017</tt>  <tt class="py-line"><tt class="py-docstring">        Validates ``name`` against SQL keywords</tt> </tt>
<a name="L4018"></a><tt class="py-lineno">4018</tt>  <tt class="py-line"><tt class="py-docstring">        Uses self.check_reserve which is a list of</tt> </tt>
<a name="L4019"></a><tt class="py-lineno">4019</tt>  <tt class="py-line"><tt class="py-docstring">        operators to use.</tt> </tt>
<a name="L4020"></a><tt class="py-lineno">4020</tt>  <tt class="py-line"><tt class="py-docstring">        self.check_reserved</tt> </tt>
<a name="L4021"></a><tt class="py-lineno">4021</tt>  <tt class="py-line"><tt class="py-docstring">        ['common', 'postgres', 'mysql']</tt> </tt>
<a name="L4022"></a><tt class="py-lineno">4022</tt>  <tt class="py-line"><tt class="py-docstring">        self.check_reserved</tt> </tt>
<a name="L4023"></a><tt class="py-lineno">4023</tt>  <tt class="py-line"><tt class="py-docstring">        ['all']</tt> </tt>
<a name="L4024"></a><tt class="py-lineno">4024</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L4025"></a><tt class="py-lineno">4025</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">backend</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">check_reserved</tt><tt class="py-op">:</tt> </tt>
<a name="L4026"></a><tt class="py-lineno">4026</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-1816" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1816', 'name', 'link-119');">name</a></tt><tt class="py-op">.</tt><tt id="link-1817" class="py-name"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-1817', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">RSK</tt><tt class="py-op">[</tt><tt class="py-name">backend</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4027"></a><tt class="py-lineno">4027</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'invalid table/column name "%s" is a "%s" reserved SQL keyword'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-1818" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-1818', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">backend</tt><tt class="py-op">.</tt><tt id="link-1819" class="py-name"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-1819', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4028"></a><tt class="py-lineno">4028</tt>  <tt class="py-line"> </tt>
<a name="DAL.__contains__"></a><div id="DAL.__contains__-def"><a name="L4029"></a><tt class="py-lineno">4029</tt> <a class="py-toggle" href="#" id="DAL.__contains__-toggle" onclick="return toggle('DAL.__contains__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__contains__">__contains__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__contains__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__contains__-expanded"><a name="L4030"></a><tt class="py-lineno">4030</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1820" class="py-name"><a title="web2py.gluon.rocket.Headers.has_key" class="py-name" href="#" onclick="return doclink('link-1820', 'has_key', 'link-931');">has_key</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4031"></a><tt class="py-lineno">4031</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">True</tt> </tt>
<a name="L4032"></a><tt class="py-lineno">4032</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4033"></a><tt class="py-lineno">4033</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt>
</div><a name="L4034"></a><tt class="py-lineno">4034</tt>  <tt class="py-line"> </tt>
<a name="DAL.parse_as_rest"></a><div id="DAL.parse_as_rest-def"><a name="L4035"></a><tt class="py-lineno">4035</tt> <a class="py-toggle" href="#" id="DAL.parse_as_rest-toggle" onclick="return toggle('DAL.parse_as_rest');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#parse_as_rest">parse_as_rest</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">patterns</tt><tt class="py-op">,</tt><tt class="py-param">args</tt><tt class="py-op">,</tt><tt class="py-param">vars</tt><tt class="py-op">,</tt><tt class="py-param">query</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-param">nested_select</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.parse_as_rest-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.parse_as_rest-expanded"><a name="L4036"></a><tt class="py-lineno">4036</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L4037"></a><tt class="py-lineno">4037</tt>  <tt class="py-line"><tt class="py-docstring">        EXAMPLE:</tt> </tt>
<a name="L4038"></a><tt class="py-lineno">4038</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4039"></a><tt class="py-lineno">4039</tt>  <tt class="py-line"><tt class="py-docstring">db.define_table('person',Field('name'),Field('info'))</tt> </tt>
<a name="L4040"></a><tt class="py-lineno">4040</tt>  <tt class="py-line"><tt class="py-docstring">db.define_table('pet',Field('person',db.person),Field('name'),Field('info'))</tt> </tt>
<a name="L4041"></a><tt class="py-lineno">4041</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4042"></a><tt class="py-lineno">4042</tt>  <tt class="py-line"><tt class="py-docstring">@request.restful()</tt> </tt>
<a name="L4043"></a><tt class="py-lineno">4043</tt>  <tt class="py-line"><tt class="py-docstring">def index():</tt> </tt>
<a name="L4044"></a><tt class="py-lineno">4044</tt>  <tt class="py-line"><tt class="py-docstring">    def GET(*kargs,**kvars):</tt> </tt>
<a name="L4045"></a><tt class="py-lineno">4045</tt>  <tt class="py-line"><tt class="py-docstring">        patterns = [</tt> </tt>
<a name="L4046"></a><tt class="py-lineno">4046</tt>  <tt class="py-line"><tt class="py-docstring">            "/persons[person]",</tt> </tt>
<a name="L4047"></a><tt class="py-lineno">4047</tt>  <tt class="py-line"><tt class="py-docstring">            "/{person.name.startswith}",</tt> </tt>
<a name="L4048"></a><tt class="py-lineno">4048</tt>  <tt class="py-line"><tt class="py-docstring">            "/{person.name}/:field",</tt> </tt>
<a name="L4049"></a><tt class="py-lineno">4049</tt>  <tt class="py-line"><tt class="py-docstring">            "/{person.name}/pets[pet.person]",</tt> </tt>
<a name="L4050"></a><tt class="py-lineno">4050</tt>  <tt class="py-line"><tt class="py-docstring">            "/{person.name}/pet[pet.person]/{pet.name}",</tt> </tt>
<a name="L4051"></a><tt class="py-lineno">4051</tt>  <tt class="py-line"><tt class="py-docstring">            "/{person.name}/pet[pet.person]/{pet.name}/:field"</tt> </tt>
<a name="L4052"></a><tt class="py-lineno">4052</tt>  <tt class="py-line"><tt class="py-docstring">            ]</tt> </tt>
<a name="L4053"></a><tt class="py-lineno">4053</tt>  <tt class="py-line"><tt class="py-docstring">        parser = db.parse_as_rest(patterns,kargs,kvars)</tt> </tt>
<a name="L4054"></a><tt class="py-lineno">4054</tt>  <tt class="py-line"><tt class="py-docstring">        if parser.status == 200:</tt> </tt>
<a name="L4055"></a><tt class="py-lineno">4055</tt>  <tt class="py-line"><tt class="py-docstring">            return dict(content=parser.response)</tt> </tt>
<a name="L4056"></a><tt class="py-lineno">4056</tt>  <tt class="py-line"><tt class="py-docstring">        else:</tt> </tt>
<a name="L4057"></a><tt class="py-lineno">4057</tt>  <tt class="py-line"><tt class="py-docstring">            raise HTTP(parser.status,parser.error)</tt> </tt>
<a name="L4058"></a><tt class="py-lineno">4058</tt>  <tt class="py-line"><tt class="py-docstring">    def POST(table_name,**kvars):</tt> </tt>
<a name="L4059"></a><tt class="py-lineno">4059</tt>  <tt class="py-line"><tt class="py-docstring">        if table_name == 'person':</tt> </tt>
<a name="L4060"></a><tt class="py-lineno">4060</tt>  <tt class="py-line"><tt class="py-docstring">            return db.person.validate_and_insert(**kvars)</tt> </tt>
<a name="L4061"></a><tt class="py-lineno">4061</tt>  <tt class="py-line"><tt class="py-docstring">        elif table_name == 'pet':</tt> </tt>
<a name="L4062"></a><tt class="py-lineno">4062</tt>  <tt class="py-line"><tt class="py-docstring">            return db.pet.validate_and_insert(**kvars)</tt> </tt>
<a name="L4063"></a><tt class="py-lineno">4063</tt>  <tt class="py-line"><tt class="py-docstring">        else:</tt> </tt>
<a name="L4064"></a><tt class="py-lineno">4064</tt>  <tt class="py-line"><tt class="py-docstring">            raise HTTP(400)</tt> </tt>
<a name="L4065"></a><tt class="py-lineno">4065</tt>  <tt class="py-line"><tt class="py-docstring">    return locals()</tt> </tt>
<a name="L4066"></a><tt class="py-lineno">4066</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L4067"></a><tt class="py-lineno">4067</tt>  <tt class="py-line"> </tt>
<a name="L4068"></a><tt class="py-lineno">4068</tt>  <tt class="py-line">        <tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt> </tt>
<a name="L4069"></a><tt class="py-lineno">4069</tt>  <tt class="py-line">        <tt class="py-name">re1</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^{[^\.]+\.[^\.]+(\.(lt|gt|le|ge|eq|ne|contains|startswith|year|month|day|hour|minute|second))?(\.not)?}$'</tt><tt class="py-op">)</tt> </tt>
<a name="L4070"></a><tt class="py-lineno">4070</tt>  <tt class="py-line">        <tt class="py-name">re2</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'^.+\[.+\]$'</tt><tt class="py-op">)</tt> </tt>
<a name="L4071"></a><tt class="py-lineno">4071</tt>  <tt class="py-line"> </tt>
<a name="L4072"></a><tt class="py-lineno">4072</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">auto_table</tt><tt class="py-op">(</tt><tt class="py-param">table</tt><tt class="py-op">,</tt><tt class="py-param">base</tt><tt class="py-op">=</tt><tt class="py-string">''</tt><tt class="py-op">,</tt><tt class="py-param">depth</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4073"></a><tt class="py-lineno">4073</tt>  <tt class="py-line">            <tt class="py-name">patterns</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4074"></a><tt class="py-lineno">4074</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4075"></a><tt class="py-lineno">4075</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">base</tt><tt class="py-op">:</tt> </tt>
<a name="L4076"></a><tt class="py-lineno">4076</tt>  <tt class="py-line">                    <tt id="link-1821" class="py-name" targets="Variable web2py.gluon.html.A.tag=web2py.gluon.html.A-class.html#tag,Variable web2py.gluon.html.B.tag=web2py.gluon.html.B-class.html#tag,Variable web2py.gluon.html.BEAUTIFY.tag=web2py.gluon.html.BEAUTIFY-class.html#tag,Variable web2py.gluon.html.BODY.tag=web2py.gluon.html.BODY-class.html#tag,Variable web2py.gluon.html.BR.tag=web2py.gluon.html.BR-class.html#tag,Variable web2py.gluon.html.BUTTON.tag=web2py.gluon.html.BUTTON-class.html#tag,Variable web2py.gluon.html.CAT.tag=web2py.gluon.html.CAT-class.html#tag,Variable web2py.gluon.html.CENTER.tag=web2py.gluon.html.CENTER-class.html#tag,Variable web2py.gluon.html.COL.tag=web2py.gluon.html.COL-class.html#tag,Variable web2py.gluon.html.COLGROUP.tag=web2py.gluon.html.COLGROUP-class.html#tag,Variable web2py.gluon.html.DIV.tag=web2py.gluon.html.DIV-class.html#tag,Variable web2py.gluon.html.EM.tag=web2py.gluon.html.EM-class.html#tag,Variable web2py.gluon.html.EMBED.tag=web2py.gluon.html.EMBED-class.html#tag,Variable web2py.gluon.html.FIELDSET.tag=web2py.gluon.html.FIELDSET-class.html#tag,Variable web2py.gluon.html.FORM.tag=web2py.gluon.html.FORM-class.html#tag,Variable web2py.gluon.html.H1.tag=web2py.gluon.html.H1-class.html#tag,Variable web2py.gluon.html.H2.tag=web2py.gluon.html.H2-class.html#tag,Variable web2py.gluon.html.H3.tag=web2py.gluon.html.H3-class.html#tag,Variable web2py.gluon.html.H4.tag=web2py.gluon.html.H4-class.html#tag,Variable web2py.gluon.html.H5.tag=web2py.gluon.html.H5-class.html#tag,Variable web2py.gluon.html.H6.tag=web2py.gluon.html.H6-class.html#tag,Variable web2py.gluon.html.HEAD.tag=web2py.gluon.html.HEAD-class.html#tag,Variable web2py.gluon.html.HR.tag=web2py.gluon.html.HR-class.html#tag,Variable web2py.gluon.html.HTML.tag=web2py.gluon.html.HTML-class.html#tag,Variable web2py.gluon.html.I.tag=web2py.gluon.html.I-class.html#tag,Variable web2py.gluon.html.IFRAME.tag=web2py.gluon.html.IFRAME-class.html#tag,Variable web2py.gluon.html.IMG.tag=web2py.gluon.html.IMG-class.html#tag,Variable web2py.gluon.html.INPUT.tag=web2py.gluon.html.INPUT-class.html#tag,Variable web2py.gluon.html.LABEL.tag=web2py.gluon.html.LABEL-class.html#tag,Variable web2py.gluon.html.LEGEND.tag=web2py.gluon.html.LEGEND-class.html#tag,Variable web2py.gluon.html.LI.tag=web2py.gluon.html.LI-class.html#tag,Variable web2py.gluon.html.LINK.tag=web2py.gluon.html.LINK-class.html#tag,Variable web2py.gluon.html.MENU.tag=web2py.gluon.html.MENU-class.html#tag,Variable web2py.gluon.html.META.tag=web2py.gluon.html.META-class.html#tag,Variable web2py.gluon.html.OBJECT.tag=web2py.gluon.html.OBJECT-class.html#tag,Variable web2py.gluon.html.OL.tag=web2py.gluon.html.OL-class.html#tag,Variable web2py.gluon.html.OPTGROUP.tag=web2py.gluon.html.OPTGROUP-class.html#tag,Variable web2py.gluon.html.OPTION.tag=web2py.gluon.html.OPTION-class.html#tag,Variable web2py.gluon.html.P.tag=web2py.gluon.html.P-class.html#tag,Variable web2py.gluon.html.PRE.tag=web2py.gluon.html.PRE-class.html#tag,Variable web2py.gluon.html.SCRIPT.tag=web2py.gluon.html.SCRIPT-class.html#tag,Variable web2py.gluon.html.SELECT.tag=web2py.gluon.html.SELECT-class.html#tag,Variable web2py.gluon.html.SPAN.tag=web2py.gluon.html.SPAN-class.html#tag,Variable web2py.gluon.html.STYLE.tag=web2py.gluon.html.STYLE-class.html#tag,Variable web2py.gluon.html.TABLE.tag=web2py.gluon.html.TABLE-class.html#tag,Variable web2py.gluon.html.TBODY.tag=web2py.gluon.html.TBODY-class.html#tag,Variable web2py.gluon.html.TD.tag=web2py.gluon.html.TD-class.html#tag,Variable web2py.gluon.html.TEXTAREA.tag=web2py.gluon.html.TEXTAREA-class.html#tag,Variable web2py.gluon.html.TFOOT.tag=web2py.gluon.html.TFOOT-class.html#tag,Variable web2py.gluon.html.TH.tag=web2py.gluon.html.TH-class.html#tag,Variable web2py.gluon.html.THEAD.tag=web2py.gluon.html.THEAD-class.html#tag,Variable web2py.gluon.html.TITLE.tag=web2py.gluon.html.TITLE-class.html#tag,Variable web2py.gluon.html.TR.tag=web2py.gluon.html.TR-class.html#tag,Variable web2py.gluon.html.TT.tag=web2py.gluon.html.TT-class.html#tag,Variable web2py.gluon.html.UL.tag=web2py.gluon.html.UL-class.html#tag,Variable web2py.gluon.html.XHTML.tag=web2py.gluon.html.XHTML-class.html#tag"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1821', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'%s/%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">base</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">,</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4077"></a><tt class="py-lineno">4077</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4078"></a><tt class="py-lineno">4078</tt>  <tt class="py-line">                    <tt id="link-1822" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1822', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'/%s/%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">,</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">,</tt><tt class="py-string">'-'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4079"></a><tt class="py-lineno">4079</tt>  <tt class="py-line">                <tt class="py-name">f</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt> </tt>
<a name="L4080"></a><tt class="py-lineno">4080</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">readable</tt><tt class="py-op">:</tt> <tt class="py-keyword">continue</tt> </tt>
<a name="L4081"></a><tt class="py-lineno">4081</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'slug'</tt> <tt class="py-keyword">in</tt> <tt class="py-name">field</tt> <tt class="py-keyword">or</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1823" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1823', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4082"></a><tt class="py-lineno">4082</tt>  <tt class="py-line">                    <tt id="link-1824" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1824', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">+=</tt> <tt class="py-string">'/{%s.%s}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4083"></a><tt class="py-lineno">4083</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1825" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1825', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1826" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1826', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4084"></a><tt class="py-lineno">4084</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1827" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1827', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1828" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1828', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4085"></a><tt class="py-lineno">4085</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1829" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1829', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'boolean'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4086"></a><tt class="py-lineno">4086</tt>  <tt class="py-line">                    <tt id="link-1830" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1830', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">+=</tt> <tt class="py-string">'/{%s.%s}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4087"></a><tt class="py-lineno">4087</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1831" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1831', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1832" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1832', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4088"></a><tt class="py-lineno">4088</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1833" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1833', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1834" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1834', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4089"></a><tt class="py-lineno">4089</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1835" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1835', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'double'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1836" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1836', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'integer'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4090"></a><tt class="py-lineno">4090</tt>  <tt class="py-line">                    <tt id="link-1837" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1837', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">+=</tt> <tt class="py-string">'/{%s.%s.ge}/{%s.%s.lt}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">,</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4091"></a><tt class="py-lineno">4091</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1838" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1838', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1839" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1839', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4092"></a><tt class="py-lineno">4092</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1840" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1840', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1841" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1841', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4093"></a><tt class="py-lineno">4093</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-1842" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1842', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4094"></a><tt class="py-lineno">4094</tt>  <tt class="py-line">                    <tt id="link-1843" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1843', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">+=</tt> <tt class="py-string">'/{%s.%s.contains}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4095"></a><tt class="py-lineno">4095</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1844" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1844', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1845" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1845', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4096"></a><tt class="py-lineno">4096</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1846" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1846', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1847" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1847', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4097"></a><tt class="py-lineno">4097</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'date'</tt><tt class="py-op">,</tt><tt class="py-string">'datetime'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4098"></a><tt class="py-lineno">4098</tt>  <tt class="py-line">                    <tt id="link-1848" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1848', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt> <tt class="py-string">'/{%s.%s.year}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4099"></a><tt class="py-lineno">4099</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1849" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1849', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1850" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1850', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4100"></a><tt class="py-lineno">4100</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1851" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1851', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1852" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1852', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4101"></a><tt class="py-lineno">4101</tt>  <tt class="py-line">                    <tt id="link-1853" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1853', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt><tt class="py-string">'/{%s.%s.month}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4102"></a><tt class="py-lineno">4102</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1854" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1854', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1855" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1855', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4103"></a><tt class="py-lineno">4103</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1856" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1856', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1857" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1857', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4104"></a><tt class="py-lineno">4104</tt>  <tt class="py-line">                    <tt id="link-1858" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1858', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt><tt class="py-string">'/{%s.%s.day}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4105"></a><tt class="py-lineno">4105</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1859" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1859', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1860" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1860', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4106"></a><tt class="py-lineno">4106</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1861" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1861', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1862" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1862', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4107"></a><tt class="py-lineno">4107</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'datetime'</tt><tt class="py-op">,</tt><tt class="py-string">'time'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4108"></a><tt class="py-lineno">4108</tt>  <tt class="py-line">                    <tt id="link-1863" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1863', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt> <tt class="py-string">'/{%s.%s.hour}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4109"></a><tt class="py-lineno">4109</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1864" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1864', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1865" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1865', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4110"></a><tt class="py-lineno">4110</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1866" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1866', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1867" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1867', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4111"></a><tt class="py-lineno">4111</tt>  <tt class="py-line">                    <tt id="link-1868" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1868', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt><tt class="py-string">'/{%s.%s.minute}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4112"></a><tt class="py-lineno">4112</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1869" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1869', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1870" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1870', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4113"></a><tt class="py-lineno">4113</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1871" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1871', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1872" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1872', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4114"></a><tt class="py-lineno">4114</tt>  <tt class="py-line">                    <tt id="link-1873" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1873', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt><tt class="py-string">'/{%s.%s.second}'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4115"></a><tt class="py-lineno">4115</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1874" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1874', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1875" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1875', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4116"></a><tt class="py-lineno">4116</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1876" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1876', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1877" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1877', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+</tt><tt class="py-string">'/:field'</tt><tt class="py-op">)</tt> </tt>
<a name="L4117"></a><tt class="py-lineno">4117</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">depth</tt><tt class="py-op">&gt;</tt><tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L4118"></a><tt class="py-lineno">4118</tt>  <tt class="py-line">                    <tt class="py-keyword">for</tt> <tt class="py-name">rtable</tt><tt class="py-op">,</tt><tt class="py-name">rfield</tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt><tt class="py-op">:</tt> </tt>
<a name="L4119"></a><tt class="py-lineno">4119</tt>  <tt class="py-line">                        <tt id="link-1878" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1878', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">+=</tt><tt class="py-string">'/%s[%s.%s]'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">rtable</tt><tt class="py-op">,</tt><tt class="py-name">rtable</tt><tt class="py-op">,</tt><tt class="py-name">rfield</tt><tt class="py-op">)</tt> </tt>
<a name="L4120"></a><tt class="py-lineno">4120</tt>  <tt class="py-line">                        <tt class="py-name">patterns</tt><tt class="py-op">.</tt><tt id="link-1879" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1879', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-1880" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1880', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4121"></a><tt class="py-lineno">4121</tt>  <tt class="py-line">                        <tt class="py-name">patterns</tt> <tt class="py-op">+=</tt> <tt class="py-name">auto_table</tt><tt class="py-op">(</tt><tt class="py-name">rtable</tt><tt class="py-op">,</tt><tt class="py-name">base</tt><tt class="py-op">=</tt><tt id="link-1881" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1881', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">,</tt><tt class="py-name">depth</tt><tt class="py-op">=</tt><tt class="py-name">depth</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
<a name="L4122"></a><tt class="py-lineno">4122</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">patterns</tt> </tt>
</div><a name="L4123"></a><tt class="py-lineno">4123</tt>  <tt class="py-line"> </tt>
<a name="L4124"></a><tt class="py-lineno">4124</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">patterns</tt><tt class="py-op">==</tt><tt class="py-string">'auto'</tt><tt class="py-op">:</tt> </tt>
<a name="L4125"></a><tt class="py-lineno">4125</tt>  <tt class="py-line">            <tt class="py-name">patterns</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4126"></a><tt class="py-lineno">4126</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">table</tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-1882" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1882', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4127"></a><tt class="py-lineno">4127</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt id="link-1883" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1883', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'auth_'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4128"></a><tt class="py-lineno">4128</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt> <tt class="py-op">+=</tt> <tt class="py-name">auto_table</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">base</tt><tt class="py-op">=</tt><tt class="py-string">''</tt><tt class="py-op">,</tt><tt class="py-name">depth</tt><tt class="py-op">=</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
<a name="L4129"></a><tt class="py-lineno">4129</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4130"></a><tt class="py-lineno">4130</tt>  <tt class="py-line">            <tt class="py-name">i</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt>
<a name="L4131"></a><tt class="py-lineno">4131</tt>  <tt class="py-line">            <tt class="py-keyword">while</tt> <tt class="py-name">i</tt><tt class="py-op">&lt;</tt><tt id="link-1884" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1884', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">patterns</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4132"></a><tt class="py-lineno">4132</tt>  <tt class="py-line">                <tt class="py-name">pattern</tt> <tt class="py-op">=</tt> <tt class="py-name">patterns</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4133"></a><tt class="py-lineno">4133</tt>  <tt class="py-line">                <tt class="py-name">tokens</tt> <tt class="py-op">=</tt> <tt class="py-name">pattern</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'/'</tt><tt class="py-op">)</tt> </tt>
<a name="L4134"></a><tt class="py-lineno">4134</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1885" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1885', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">':auto'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">re2</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4135"></a><tt class="py-lineno">4135</tt>  <tt class="py-line">                    <tt class="py-name">new_patterns</tt> <tt class="py-op">=</tt> <tt class="py-name">auto_table</tt><tt class="py-op">(</tt><tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1886" class="py-name"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-1886', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'['</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-string">'/'</tt><tt class="py-op">.</tt><tt id="link-1887" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1887', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4136"></a><tt class="py-lineno">4136</tt>  <tt class="py-line">                    <tt class="py-name">patterns</tt> <tt class="py-op">=</tt> <tt class="py-name">patterns</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">+</tt><tt class="py-name">new_patterns</tt><tt class="py-op">+</tt><tt class="py-name">patterns</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L4137"></a><tt class="py-lineno">4137</tt>  <tt class="py-line">                    <tt class="py-name">i</tt> <tt class="py-op">+=</tt> <tt id="link-1888" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1888', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">new_patterns</tt><tt class="py-op">)</tt> </tt>
<a name="L4138"></a><tt class="py-lineno">4138</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4139"></a><tt class="py-lineno">4139</tt>  <tt class="py-line">                    <tt class="py-name">i</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
<a name="L4140"></a><tt class="py-lineno">4140</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-string">'/'</tt><tt class="py-op">.</tt><tt id="link-1889" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1889', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">args</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-string">'patterns'</tt><tt class="py-op">:</tt> </tt>
<a name="L4141"></a><tt class="py-lineno">4141</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-1890" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1890', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">200</tt><tt class="py-op">,</tt><tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-string">'list'</tt><tt class="py-op">,</tt> </tt>
<a name="L4142"></a><tt class="py-lineno">4142</tt>  <tt class="py-line">                        <tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">patterns</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4143"></a><tt class="py-lineno">4143</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">pattern</tt> <tt class="py-keyword">in</tt> <tt class="py-name">patterns</tt><tt class="py-op">:</tt> </tt>
<a name="L4144"></a><tt class="py-lineno">4144</tt>  <tt class="py-line">            <tt class="py-name">otable</tt><tt class="py-op">=</tt><tt class="py-name">table</tt><tt class="py-op">=</tt><tt class="py-name">None</tt> </tt>
<a name="L4145"></a><tt class="py-lineno">4145</tt>  <tt class="py-line">            <tt class="py-name">dbset</tt><tt class="py-op">=</tt><tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L4146"></a><tt class="py-lineno">4146</tt>  <tt class="py-line">            <tt class="py-name">i</tt><tt class="py-op">=</tt><tt class="py-number">0</tt> </tt>
<a name="L4147"></a><tt class="py-lineno">4147</tt>  <tt class="py-line">            <tt class="py-name">tags</tt> <tt class="py-op">=</tt> <tt class="py-name">pattern</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'/'</tt><tt class="py-op">)</tt> </tt>
<a name="L4148"></a><tt class="py-lineno">4148</tt>  <tt class="py-line">            <tt class="py-comment"># print pattern</tt> </tt>
<a name="L4149"></a><tt class="py-lineno">4149</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-keyword">if</tt> <tt id="link-1891" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1891', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tags</tt><tt class="py-op">)</tt><tt class="py-op">!=</tt><tt id="link-1892" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1892', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">args</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4150"></a><tt class="py-lineno">4150</tt>  <tt class="py-line">                <tt class="py-keyword">continue</tt> </tt>
<a name="L4151"></a><tt class="py-lineno">4151</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt id="link-1893" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1893', 'tag', 'link-1821');">tag</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">tags</tt><tt class="py-op">:</tt> </tt>
<a name="L4152"></a><tt class="py-lineno">4152</tt>  <tt class="py-line">                <tt class="py-comment"># print i, tag, args[i]</tt> </tt>
<a name="L4153"></a><tt class="py-lineno">4153</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-keyword">if</tt> <tt class="py-name">re1</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt id="link-1894" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1894', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4154"></a><tt class="py-lineno">4154</tt>  <tt class="py-line">                    <tt class="py-comment"># print 're1:'+tag</tt> </tt>
<a name="L4155"></a><tt class="py-lineno">4155</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-name">tokens</tt> <tt class="py-op">=</tt> <tt id="link-1895" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1895', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L4156"></a><tt class="py-lineno">4156</tt>  <tt class="py-line">                    <tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L4157"></a><tt class="py-lineno">4157</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">otable</tt> <tt class="py-keyword">or</tt> <tt class="py-name">table</tt> <tt class="py-op">==</tt> <tt class="py-name">otable</tt><tt class="py-op">:</tt> </tt>
<a name="L4158"></a><tt class="py-lineno">4158</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt id="link-1896" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1896', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tokens</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-number">2</tt> <tt class="py-keyword">or</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'eq'</tt><tt class="py-op">:</tt> </tt>
<a name="L4159"></a><tt class="py-lineno">4159</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4160"></a><tt class="py-lineno">4160</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'ne'</tt><tt class="py-op">:</tt> </tt>
<a name="L4161"></a><tt class="py-lineno">4161</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">!=</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4162"></a><tt class="py-lineno">4162</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'lt'</tt><tt class="py-op">:</tt> </tt>
<a name="L4163"></a><tt class="py-lineno">4163</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">&lt;</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4164"></a><tt class="py-lineno">4164</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'gt'</tt><tt class="py-op">:</tt> </tt>
<a name="L4165"></a><tt class="py-lineno">4165</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">&gt;</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4166"></a><tt class="py-lineno">4166</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'ge'</tt><tt class="py-op">:</tt> </tt>
<a name="L4167"></a><tt class="py-lineno">4167</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">&gt;=</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4168"></a><tt class="py-lineno">4168</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'le'</tt><tt class="py-op">:</tt> </tt>
<a name="L4169"></a><tt class="py-lineno">4169</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">&lt;=</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4170"></a><tt class="py-lineno">4170</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'year'</tt><tt class="py-op">:</tt> </tt>
<a name="L4171"></a><tt class="py-lineno">4171</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1897" class="py-name"><a title="web2py.gluon.dal.Expression.year" class="py-name" href="#" onclick="return doclink('link-1897', 'year', 'link-1164');">year</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4172"></a><tt class="py-lineno">4172</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'month'</tt><tt class="py-op">:</tt> </tt>
<a name="L4173"></a><tt class="py-lineno">4173</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1898" class="py-name"><a title="web2py.gluon.dal.Expression.month" class="py-name" href="#" onclick="return doclink('link-1898', 'month', 'link-1165');">month</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4174"></a><tt class="py-lineno">4174</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'day'</tt><tt class="py-op">:</tt> </tt>
<a name="L4175"></a><tt class="py-lineno">4175</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1899" class="py-name"><a title="web2py.gluon.dal.Expression.day" class="py-name" href="#" onclick="return doclink('link-1899', 'day', 'link-1166');">day</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4176"></a><tt class="py-lineno">4176</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'hour'</tt><tt class="py-op">:</tt> </tt>
<a name="L4177"></a><tt class="py-lineno">4177</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1900" class="py-name" targets="Method web2py.gluon.dal.Expression.hour()=web2py.gluon.dal.Expression-class.html#hour"><a title="web2py.gluon.dal.Expression.hour" class="py-name" href="#" onclick="return doclink('link-1900', 'hour', 'link-1900');">hour</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4178"></a><tt class="py-lineno">4178</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'minute'</tt><tt class="py-op">:</tt> </tt>
<a name="L4179"></a><tt class="py-lineno">4179</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1901" class="py-name" targets="Method web2py.gluon.dal.Expression.minutes()=web2py.gluon.dal.Expression-class.html#minutes"><a title="web2py.gluon.dal.Expression.minutes" class="py-name" href="#" onclick="return doclink('link-1901', 'minutes', 'link-1901');">minutes</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4180"></a><tt class="py-lineno">4180</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'second'</tt><tt class="py-op">:</tt> </tt>
<a name="L4181"></a><tt class="py-lineno">4181</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1902" class="py-name" targets="Method web2py.gluon.dal.Expression.seconds()=web2py.gluon.dal.Expression-class.html#seconds"><a title="web2py.gluon.dal.Expression.seconds" class="py-name" href="#" onclick="return doclink('link-1902', 'seconds', 'link-1902');">seconds</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4182"></a><tt class="py-lineno">4182</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'startswith'</tt><tt class="py-op">:</tt> </tt>
<a name="L4183"></a><tt class="py-lineno">4183</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1903" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1903', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L4184"></a><tt class="py-lineno">4184</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'contains'</tt><tt class="py-op">:</tt> </tt>
<a name="L4185"></a><tt class="py-lineno">4185</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1904" class="py-name" targets="Method web2py.gluon.dal.Expression.contains()=web2py.gluon.dal.Expression-class.html#contains"><a title="web2py.gluon.dal.Expression.contains" class="py-name" href="#" onclick="return doclink('link-1904', 'contains', 'link-1904');">contains</a></tt><tt class="py-op">(</tt><tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L4186"></a><tt class="py-lineno">4186</tt>  <tt class="py-line">                        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4187"></a><tt class="py-lineno">4187</tt>  <tt class="py-line">                            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"invalid pattern: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">pattern</tt> </tt>
<a name="L4188"></a><tt class="py-lineno">4188</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt id="link-1905" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1905', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tokens</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-number">4</tt> <tt class="py-keyword">and</tt> <tt class="py-name">tokens</tt><tt class="py-op">[</tt><tt class="py-number">3</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'not'</tt><tt class="py-op">:</tt> </tt>
<a name="L4189"></a><tt class="py-lineno">4189</tt>  <tt class="py-line">                            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">~</tt><tt class="py-name">query</tt> </tt>
<a name="L4190"></a><tt class="py-lineno">4190</tt>  <tt class="py-line">                        <tt class="py-keyword">elif</tt> <tt id="link-1906" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1906', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tokens</tt><tt class="py-op">)</tt><tt class="py-op">&gt;=</tt><tt class="py-number">4</tt><tt class="py-op">:</tt> </tt>
<a name="L4191"></a><tt class="py-lineno">4191</tt>  <tt class="py-line">                            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"invalid pattern: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">pattern</tt> </tt>
<a name="L4192"></a><tt class="py-lineno">4192</tt>  <tt class="py-line">                        <tt class="py-name">dbset</tt><tt class="py-op">=</tt><tt class="py-name">dbset</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L4193"></a><tt class="py-lineno">4193</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4194"></a><tt class="py-lineno">4194</tt>  <tt class="py-line">                        <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"missing relation in pattern: %s"</tt> <tt class="py-op">%</tt> <tt class="py-name">pattern</tt> </tt>
<a name="L4195"></a><tt class="py-lineno">4195</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt class="py-name">otable</tt> <tt class="py-keyword">and</tt> <tt class="py-name">re2</tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt id="link-1907" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1907', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt id="link-1908" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1908', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt id="link-1909" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1909', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">.</tt><tt id="link-1910" class="py-name"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-1910', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'['</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4196"></a><tt class="py-lineno">4196</tt>  <tt class="py-line">                    <tt class="py-comment"># print 're2:'+tag</tt> </tt>
<a name="L4197"></a><tt class="py-lineno">4197</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-name">ref</tt> <tt class="py-op">=</tt> <tt id="link-1911" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1911', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">[</tt><tt id="link-1912" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1912', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">.</tt><tt id="link-1913" class="py-name"><a title="web2py.gluon.dal.Rows.find" class="py-name" href="#" onclick="return doclink('link-1913', 'find', 'link-599');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'['</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L4198"></a><tt class="py-lineno">4198</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-string">'.'</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ref</tt><tt class="py-op">:</tt> </tt>
<a name="L4199"></a><tt class="py-lineno">4199</tt>  <tt class="py-line">                        <tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">ref</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L4200"></a><tt class="py-lineno">4200</tt>  <tt class="py-line">                        <tt class="py-comment"># print table,field</tt> </tt>
<a name="L4201"></a><tt class="py-lineno">4201</tt>  <tt class="py-line"><tt class="py-comment"></tt>                        <tt class="py-keyword">if</tt> <tt class="py-name">nested_select</tt><tt class="py-op">:</tt> </tt>
<a name="L4202"></a><tt class="py-lineno">4202</tt>  <tt class="py-line">                            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4203"></a><tt class="py-lineno">4203</tt>  <tt class="py-line">                                <tt class="py-name">dbset</tt><tt class="py-op">=</tt><tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1914" class="py-name"><a title="web2py.gluon.dal.Expression.belongs" class="py-name" href="#" onclick="return doclink('link-1914', 'belongs', 'link-468');">belongs</a></tt><tt class="py-op">(</tt><tt class="py-name">dbset</tt><tt class="py-op">.</tt><tt id="link-1915" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._select
web2py.gluon.dal.CouchDBAdapter._select
web2py.gluon.dal.NoSQLAdapter._select
web2py.gluon.dal.Set._select" class="py-name" href="#" onclick="return doclink('link-1915', '_select', 'link-536');">_select</a></tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">otable</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4204"></a><tt class="py-lineno">4204</tt>  <tt class="py-line">                            <tt class="py-keyword">except</tt> <tt class="py-name">ValueError</tt><tt class="py-op">:</tt> </tt>
<a name="L4205"></a><tt class="py-lineno">4205</tt>  <tt class="py-line">                                <tt class="py-keyword">return</tt> <tt id="link-1916" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1916', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-name">pattern</tt><tt class="py-op">,</tt> </tt>
<a name="L4206"></a><tt class="py-lineno">4206</tt>  <tt class="py-line">                                            <tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'invalid path'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4207"></a><tt class="py-lineno">4207</tt>  <tt class="py-line">                        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4208"></a><tt class="py-lineno">4208</tt>  <tt class="py-line">                            <tt id="link-1917" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1917', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">id</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">dbset</tt><tt class="py-op">.</tt><tt id="link-1918" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1918', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">otable</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L4209"></a><tt class="py-lineno">4209</tt>  <tt class="py-line">                            <tt class="py-name">dbset</tt><tt class="py-op">=</tt><tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1919" class="py-name"><a title="web2py.gluon.dal.Expression.belongs" class="py-name" href="#" onclick="return doclink('link-1919', 'belongs', 'link-468');">belongs</a></tt><tt class="py-op">(</tt><tt id="link-1920" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-1920', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4210"></a><tt class="py-lineno">4210</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4211"></a><tt class="py-lineno">4211</tt>  <tt class="py-line">                        <tt class="py-name">dbset</tt><tt class="py-op">=</tt><tt class="py-name">dbset</tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">ref</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L4212"></a><tt class="py-lineno">4212</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt id="link-1921" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1921', 'tag', 'link-1821');">tag</a></tt><tt class="py-op">==</tt><tt class="py-string">':field'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">:</tt> </tt>
<a name="L4213"></a><tt class="py-lineno">4213</tt>  <tt class="py-line">                    <tt class="py-comment"># # print 're3:'+tag</tt> </tt>
<a name="L4214"></a><tt class="py-lineno">4214</tt>  <tt class="py-line"><tt class="py-comment"></tt>                    <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L4215"></a><tt class="py-lineno">4215</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> <tt class="py-keyword">break</tt> </tt>
<a name="L4216"></a><tt class="py-lineno">4216</tt>  <tt class="py-line">                    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4217"></a><tt class="py-lineno">4217</tt>  <tt class="py-line">                        <tt class="py-name">item</tt> <tt class="py-op">=</tt>  <tt class="py-name">dbset</tt><tt class="py-op">.</tt><tt id="link-1922" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1922', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1923" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-1923', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4218"></a><tt class="py-lineno">4218</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt class="py-name">ValueError</tt><tt class="py-op">:</tt> </tt>
<a name="L4219"></a><tt class="py-lineno">4219</tt>  <tt class="py-line">                        <tt class="py-keyword">return</tt> <tt id="link-1924" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1924', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-name">pattern</tt><tt class="py-op">,</tt> </tt>
<a name="L4220"></a><tt class="py-lineno">4220</tt>  <tt class="py-line">                                    <tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'invalid path'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4221"></a><tt class="py-lineno">4221</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">item</tt><tt class="py-op">:</tt> </tt>
<a name="L4222"></a><tt class="py-lineno">4222</tt>  <tt class="py-line">                        <tt class="py-keyword">return</tt> <tt id="link-1925" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1925', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">404</tt><tt class="py-op">,</tt><tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-name">pattern</tt><tt class="py-op">,</tt> </tt>
<a name="L4223"></a><tt class="py-lineno">4223</tt>  <tt class="py-line">                                    <tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'record not found'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4224"></a><tt class="py-lineno">4224</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4225"></a><tt class="py-lineno">4225</tt>  <tt class="py-line">                        <tt class="py-keyword">return</tt> <tt id="link-1926" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1926', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">200</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">item</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
<a name="L4226"></a><tt class="py-lineno">4226</tt>  <tt class="py-line">                                    <tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-name">pattern</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4227"></a><tt class="py-lineno">4227</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt id="link-1927" class="py-name"><a title="web2py.gluon.html.A.tag
web2py.gluon.html.B.tag
web2py.gluon.html.BEAUTIFY.tag
web2py.gluon.html.BODY.tag
web2py.gluon.html.BR.tag
web2py.gluon.html.BUTTON.tag
web2py.gluon.html.CAT.tag
web2py.gluon.html.CENTER.tag
web2py.gluon.html.COL.tag
web2py.gluon.html.COLGROUP.tag
web2py.gluon.html.DIV.tag
web2py.gluon.html.EM.tag
web2py.gluon.html.EMBED.tag
web2py.gluon.html.FIELDSET.tag
web2py.gluon.html.FORM.tag
web2py.gluon.html.H1.tag
web2py.gluon.html.H2.tag
web2py.gluon.html.H3.tag
web2py.gluon.html.H4.tag
web2py.gluon.html.H5.tag
web2py.gluon.html.H6.tag
web2py.gluon.html.HEAD.tag
web2py.gluon.html.HR.tag
web2py.gluon.html.HTML.tag
web2py.gluon.html.I.tag
web2py.gluon.html.IFRAME.tag
web2py.gluon.html.IMG.tag
web2py.gluon.html.INPUT.tag
web2py.gluon.html.LABEL.tag
web2py.gluon.html.LEGEND.tag
web2py.gluon.html.LI.tag
web2py.gluon.html.LINK.tag
web2py.gluon.html.MENU.tag
web2py.gluon.html.META.tag
web2py.gluon.html.OBJECT.tag
web2py.gluon.html.OL.tag
web2py.gluon.html.OPTGROUP.tag
web2py.gluon.html.OPTION.tag
web2py.gluon.html.P.tag
web2py.gluon.html.PRE.tag
web2py.gluon.html.SCRIPT.tag
web2py.gluon.html.SELECT.tag
web2py.gluon.html.SPAN.tag
web2py.gluon.html.STYLE.tag
web2py.gluon.html.TABLE.tag
web2py.gluon.html.TBODY.tag
web2py.gluon.html.TD.tag
web2py.gluon.html.TEXTAREA.tag
web2py.gluon.html.TFOOT.tag
web2py.gluon.html.TH.tag
web2py.gluon.html.THEAD.tag
web2py.gluon.html.TITLE.tag
web2py.gluon.html.TR.tag
web2py.gluon.html.TT.tag
web2py.gluon.html.UL.tag
web2py.gluon.html.XHTML.tag" class="py-name" href="#" onclick="return doclink('link-1927', 'tag', 'link-1821');">tag</a></tt> <tt class="py-op">!=</tt> <tt class="py-name">args</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4228"></a><tt class="py-lineno">4228</tt>  <tt class="py-line">                    <tt class="py-keyword">break</tt> </tt>
<a name="L4229"></a><tt class="py-lineno">4229</tt>  <tt class="py-line">                <tt class="py-name">otable</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt> </tt>
<a name="L4230"></a><tt class="py-lineno">4230</tt>  <tt class="py-line">                <tt class="py-name">i</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
<a name="L4231"></a><tt class="py-lineno">4231</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">i</tt><tt class="py-op">==</tt><tt id="link-1928" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-1928', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">tags</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">:</tt> </tt>
<a name="L4232"></a><tt class="py-lineno">4232</tt>  <tt class="py-line">                    <tt class="py-name">otable</tt><tt class="py-op">,</tt><tt class="py-name">ofield</tt> <tt class="py-op">=</tt> <tt class="py-name">vars</tt><tt class="py-op">.</tt><tt id="link-1929" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1929', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'order'</tt><tt class="py-op">,</tt><tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
<a name="L4233"></a><tt class="py-lineno">4233</tt>  <tt class="py-line">                    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4234"></a><tt class="py-lineno">4234</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt class="py-name">otable</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'~'</tt><tt class="py-op">:</tt> <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt class="py-op">~</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">otable</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">ofield</tt><tt class="py-op">]</tt> </tt>
<a name="L4235"></a><tt class="py-lineno">4235</tt>  <tt class="py-line">                        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-name">orderby</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">otable</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">ofield</tt><tt class="py-op">]</tt> </tt>
<a name="L4236"></a><tt class="py-lineno">4236</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt class="py-name">KeyError</tt><tt class="py-op">:</tt> </tt>
<a name="L4237"></a><tt class="py-lineno">4237</tt>  <tt class="py-line">                        <tt class="py-keyword">return</tt> <tt id="link-1930" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1930', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'invalid orderby'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4238"></a><tt class="py-lineno">4238</tt>  <tt class="py-line">                    <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">field</tt> <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt> <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">readable</tt><tt class="py-op">]</tt> </tt>
<a name="L4239"></a><tt class="py-lineno">4239</tt>  <tt class="py-line">                    <tt id="link-1931" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-1931', 'count', 'link-1426');">count</a></tt> <tt class="py-op">=</tt> <tt class="py-name">dbset</tt><tt class="py-op">.</tt><tt id="link-1932" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-1932', 'count', 'link-1426');">count</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4240"></a><tt class="py-lineno">4240</tt>  <tt class="py-line">                    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4241"></a><tt class="py-lineno">4241</tt>  <tt class="py-line">                        <tt class="py-name">limits</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">vars</tt><tt class="py-op">.</tt><tt id="link-1933" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1933', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'min'</tt><tt class="py-op">,</tt><tt class="py-number">0</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">vars</tt><tt class="py-op">.</tt><tt id="link-1934" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1934', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'max'</tt><tt class="py-op">,</tt><tt class="py-number">1000</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4242"></a><tt class="py-lineno">4242</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt class="py-name">limits</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">&lt;</tt><tt class="py-number">0</tt> <tt class="py-keyword">or</tt> <tt class="py-name">limits</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">&lt;</tt><tt class="py-name">limits</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt class="py-name">ValueError</tt> </tt>
<a name="L4243"></a><tt class="py-lineno">4243</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt class="py-name">ValueError</tt><tt class="py-op">:</tt> </tt>
<a name="L4244"></a><tt class="py-lineno">4244</tt>  <tt class="py-line">                        <tt id="link-1935" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1935', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'invalid limits'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4245"></a><tt class="py-lineno">4245</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt id="link-1936" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-1936', 'count', 'link-1426');">count</a></tt> <tt class="py-op">&gt;</tt> <tt class="py-name">limits</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">-</tt><tt class="py-name">limits</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4246"></a><tt class="py-lineno">4246</tt>  <tt class="py-line">                        <tt id="link-1937" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1937', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'too many records'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4247"></a><tt class="py-lineno">4247</tt>  <tt class="py-line">                    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4248"></a><tt class="py-lineno">4248</tt>  <tt class="py-line">                        <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">dbset</tt><tt class="py-op">.</tt><tt id="link-1938" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1938', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-name">limits</tt><tt class="py-op">,</tt><tt class="py-name">orderby</tt><tt class="py-op">=</tt><tt class="py-name">orderby</tt><tt class="py-op">,</tt><tt class="py-op">*</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L4249"></a><tt class="py-lineno">4249</tt>  <tt class="py-line">                    <tt class="py-keyword">except</tt> <tt class="py-name">ValueError</tt><tt class="py-op">:</tt> </tt>
<a name="L4250"></a><tt class="py-lineno">4250</tt>  <tt class="py-line">                        <tt class="py-keyword">return</tt> <tt id="link-1939" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1939', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-name">pattern</tt><tt class="py-op">,</tt> </tt>
<a name="L4251"></a><tt class="py-lineno">4251</tt>  <tt class="py-line">                                    <tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'invalid path'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4252"></a><tt class="py-lineno">4252</tt>  <tt class="py-line">                    <tt class="py-keyword">return</tt> <tt id="link-1940" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1940', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">200</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">response</tt><tt class="py-op">,</tt><tt class="py-string">'pattern'</tt><tt class="py-op">:</tt><tt class="py-name">pattern</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
<a name="L4253"></a><tt class="py-lineno">4253</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1941" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-1941', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">{</tt><tt class="py-string">'status'</tt><tt class="py-op">:</tt><tt class="py-number">400</tt><tt class="py-op">,</tt><tt class="py-string">'error'</tt><tt class="py-op">:</tt><tt class="py-string">'no matching pattern'</tt><tt class="py-op">,</tt><tt class="py-string">'response'</tt><tt class="py-op">:</tt><tt class="py-name">None</tt><tt class="py-op">}</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4254"></a><tt class="py-lineno">4254</tt>  <tt class="py-line"> </tt>
<a name="L4255"></a><tt class="py-lineno">4255</tt>  <tt class="py-line"> </tt>
<a name="DAL.define_table"></a><div id="DAL.define_table-def"><a name="L4256"></a><tt class="py-lineno">4256</tt> <a class="py-toggle" href="#" id="DAL.define_table-toggle" onclick="return toggle('DAL.define_table');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#define_table">define_table</a><tt class="py-op">(</tt> </tt>
<a name="L4257"></a><tt class="py-lineno">4257</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L4258"></a><tt class="py-lineno">4258</tt>  <tt class="py-line">        <tt class="py-param">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L4259"></a><tt class="py-lineno">4259</tt>  <tt class="py-line">        <tt class="py-op">*</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt> </tt>
<a name="L4260"></a><tt class="py-lineno">4260</tt>  <tt class="py-line">        <tt class="py-op">**</tt><tt class="py-param">args</tt> </tt>
<a name="L4261"></a><tt class="py-lineno">4261</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.define_table-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.define_table-expanded"><a name="L4262"></a><tt class="py-lineno">4262</tt>  <tt class="py-line"> </tt>
<a name="L4263"></a><tt class="py-lineno">4263</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">args</tt><tt class="py-op">:</tt> </tt>
<a name="L4264"></a><tt class="py-lineno">4264</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-op">[</tt> </tt>
<a name="L4265"></a><tt class="py-lineno">4265</tt>  <tt class="py-line">                    <tt class="py-string">'migrate'</tt><tt class="py-op">,</tt> </tt>
<a name="L4266"></a><tt class="py-lineno">4266</tt>  <tt class="py-line">                    <tt class="py-string">'primarykey'</tt><tt class="py-op">,</tt> </tt>
<a name="L4267"></a><tt class="py-lineno">4267</tt>  <tt class="py-line">                    <tt class="py-string">'fake_migrate'</tt><tt class="py-op">,</tt> </tt>
<a name="L4268"></a><tt class="py-lineno">4268</tt>  <tt class="py-line">                    <tt class="py-string">'format'</tt><tt class="py-op">,</tt> </tt>
<a name="L4269"></a><tt class="py-lineno">4269</tt>  <tt class="py-line">                    <tt class="py-string">'trigger_name'</tt><tt class="py-op">,</tt> </tt>
<a name="L4270"></a><tt class="py-lineno">4270</tt>  <tt class="py-line">                    <tt class="py-string">'sequence_name'</tt><tt class="py-op">,</tt> </tt>
<a name="L4271"></a><tt class="py-lineno">4271</tt>  <tt class="py-line">                    <tt class="py-string">'polymodel'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4272"></a><tt class="py-lineno">4272</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'invalid table "%s" attribute: %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L4273"></a><tt class="py-lineno">4273</tt>  <tt class="py-line">        <tt class="py-name">migrate</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_migrate_enabled</tt> <tt class="py-keyword">and</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1942" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1942', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'migrate'</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_migrate</tt><tt class="py-op">)</tt> </tt>
<a name="L4274"></a><tt class="py-lineno">4274</tt>  <tt class="py-line">        <tt class="py-name">fake_migrate</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_fake_migrate_all</tt> <tt class="py-keyword">or</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1943" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1943', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'fake_migrate'</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_fake_migrate</tt><tt class="py-op">)</tt> </tt>
<a name="L4275"></a><tt class="py-lineno">4275</tt>  <tt class="py-line">        <tt class="py-name">format</tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1944" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1944', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'format'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L4276"></a><tt class="py-lineno">4276</tt>  <tt class="py-line">        <tt id="link-1945" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-1945', 'trigger_name', 'link-860');">trigger_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1946" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1946', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'trigger_name'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L4277"></a><tt class="py-lineno">4277</tt>  <tt class="py-line">        <tt id="link-1947" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-1947', 'sequence_name', 'link-821');">sequence_name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1948" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1948', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'sequence_name'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L4278"></a><tt class="py-lineno">4278</tt>  <tt class="py-line">        <tt class="py-name">primarykey</tt><tt class="py-op">=</tt><tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1949" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1949', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'primarykey'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L4279"></a><tt class="py-lineno">4279</tt>  <tt class="py-line">        <tt class="py-name">polymodel</tt><tt class="py-op">=</tt><tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-1950" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1950', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'polymodel'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L4280"></a><tt class="py-lineno">4280</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4281"></a><tt class="py-lineno">4281</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"missing table name"</tt> </tt>
<a name="L4282"></a><tt class="py-lineno">4282</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt id="link-1951" class="py-name" targets="Function web2py.gluon.dal.cleanup()=web2py.gluon.dal-module.html#cleanup"><a title="web2py.gluon.dal.cleanup" class="py-name" href="#" onclick="return doclink('link-1951', 'cleanup', 'link-1951');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4283"></a><tt class="py-lineno">4283</tt>  <tt class="py-line">        <tt class="py-name">lowertablename</tt> <tt class="py-op">=</tt> <tt class="py-name">tablename</tt><tt class="py-op">.</tt><tt id="link-1952" class="py-name"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-1952', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4284"></a><tt class="py-lineno">4284</tt>  <tt class="py-line"> </tt>
<a name="L4285"></a><tt class="py-lineno">4285</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">tablename</tt><tt class="py-op">.</tt><tt id="link-1953" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1953', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">lowertablename</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> \ </tt>
<a name="L4286"></a><tt class="py-lineno">4286</tt>  <tt class="py-line">                <tt id="link-1954" class="py-name"><a title="web2py.gluon.dal.regex_python_keywords" class="py-name" href="#" onclick="return doclink('link-1954', 'regex_python_keywords', 'link-33');">regex_python_keywords</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4287"></a><tt class="py-lineno">4287</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'invalid table name: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4288"></a><tt class="py-lineno">4288</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">lowertablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1955" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1955', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4289"></a><tt class="py-lineno">4289</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'table already defined: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4290"></a><tt class="py-lineno">4290</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">check_reserved</tt><tt class="py-op">:</tt> </tt>
<a name="L4291"></a><tt class="py-lineno">4291</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1956" class="py-name" targets="Method web2py.gluon.dal.DAL.check_reserved_keyword()=web2py.gluon.dal.DAL-class.html#check_reserved_keyword"><a title="web2py.gluon.dal.DAL.check_reserved_keyword" class="py-name" href="#" onclick="return doclink('link-1956', 'check_reserved_keyword', 'link-1956');">check_reserved_keyword</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4292"></a><tt class="py-lineno">4292</tt>  <tt class="py-line"> </tt>
<a name="L4293"></a><tt class="py-lineno">4293</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_common_fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4294"></a><tt class="py-lineno">4294</tt>  <tt class="py-line">            <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">f</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-op">[</tt><tt class="py-name">f</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_common_fields</tt><tt class="py-op">]</tt> </tt>
<a name="L4295"></a><tt class="py-lineno">4295</tt>  <tt class="py-line"> </tt>
<a name="L4296"></a><tt class="py-lineno">4296</tt>  <tt class="py-line">        <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-1957" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-1957', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt> </tt>
<a name="L4297"></a><tt class="py-lineno">4297</tt>  <tt class="py-line">                                    <tt class="py-op">**</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">primarykey</tt><tt class="py-op">=</tt><tt class="py-name">primarykey</tt><tt class="py-op">,</tt> </tt>
<a name="L4298"></a><tt class="py-lineno">4298</tt>  <tt class="py-line">                                    <tt id="link-1958" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-1958', 'trigger_name', 'link-860');">trigger_name</a></tt><tt class="py-op">=</tt><tt id="link-1959" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-1959', 'trigger_name', 'link-860');">trigger_name</a></tt><tt class="py-op">,</tt> </tt>
<a name="L4299"></a><tt class="py-lineno">4299</tt>  <tt class="py-line">                                    <tt id="link-1960" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-1960', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">=</tt><tt id="link-1961" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-1961', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4300"></a><tt class="py-lineno">4300</tt>  <tt class="py-line">        <tt class="py-comment"># db magic</tt> </tt>
<a name="L4301"></a><tt class="py-lineno">4301</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_uri</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-name">None</tt><tt class="py-op">,</tt><tt class="py-string">'None'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4302"></a><tt class="py-lineno">4302</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">t</tt> </tt>
<a name="L4303"></a><tt class="py-lineno">4303</tt>  <tt class="py-line"> </tt>
<a name="L4304"></a><tt class="py-lineno">4304</tt>  <tt class="py-line">        <tt class="py-name">t</tt><tt class="py-op">.</tt><tt id="link-1962" class="py-name" targets="Method web2py.gluon.dal.Table._create_references()=web2py.gluon.dal.Table-class.html#_create_references"><a title="web2py.gluon.dal.Table._create_references" class="py-name" href="#" onclick="return doclink('link-1962', '_create_references', 'link-1962');">_create_references</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4305"></a><tt class="py-lineno">4305</tt>  <tt class="py-line"> </tt>
<a name="L4306"></a><tt class="py-lineno">4306</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">migrate</tt> <tt class="py-keyword">or</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">dbengine</tt><tt class="py-op">==</tt><tt class="py-string">'google:datastore'</tt><tt class="py-op">:</tt> </tt>
<a name="L4307"></a><tt class="py-lineno">4307</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4308"></a><tt class="py-lineno">4308</tt>  <tt class="py-line">                <tt id="link-1963" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-1963', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-1964" class="py-name"><a title="web2py.gluon.newcron.Token.acquire" class="py-name" href="#" onclick="return doclink('link-1964', 'acquire', 'link-128');">acquire</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4309"></a><tt class="py-lineno">4309</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1965" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.create_table()=web2py.gluon.dal.BaseAdapter-class.html#create_table,Method web2py.gluon.dal.CouchDBAdapter.create_table()=web2py.gluon.dal.CouchDBAdapter-class.html#create_table,Method web2py.gluon.dal.GoogleDatastoreAdapter.create_table()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#create_table"><a title="web2py.gluon.dal.BaseAdapter.create_table
web2py.gluon.dal.CouchDBAdapter.create_table
web2py.gluon.dal.GoogleDatastoreAdapter.create_table" class="py-name" href="#" onclick="return doclink('link-1965', 'create_table', 'link-1965');">create_table</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt><tt class="py-name">migrate</tt><tt class="py-op">=</tt><tt class="py-name">migrate</tt><tt class="py-op">,</tt> </tt>
<a name="L4310"></a><tt class="py-lineno">4310</tt>  <tt class="py-line">                                           <tt class="py-name">fake_migrate</tt><tt class="py-op">=</tt><tt class="py-name">fake_migrate</tt><tt class="py-op">,</tt> </tt>
<a name="L4311"></a><tt class="py-lineno">4311</tt>  <tt class="py-line">                                           <tt class="py-name">polymodel</tt><tt class="py-op">=</tt><tt class="py-name">polymodel</tt><tt class="py-op">)</tt> </tt>
<a name="L4312"></a><tt class="py-lineno">4312</tt>  <tt class="py-line">            <tt class="py-keyword">finally</tt><tt class="py-op">:</tt> </tt>
<a name="L4313"></a><tt class="py-lineno">4313</tt>  <tt class="py-line">                <tt id="link-1966" class="py-name"><a title="web2py.gluon.dal.sql_locker" class="py-name" href="#" onclick="return doclink('link-1966', 'sql_locker', 'link-26');">sql_locker</a></tt><tt class="py-op">.</tt><tt id="link-1967" class="py-name"><a title="web2py.gluon.newcron.Token.release" class="py-name" href="#" onclick="return doclink('link-1967', 'release', 'link-134');">release</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4314"></a><tt class="py-lineno">4314</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4315"></a><tt class="py-lineno">4315</tt>  <tt class="py-line">            <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">_dbt</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4316"></a><tt class="py-lineno">4316</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1968" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1968', 'tables', 'link-313');">tables</a></tt><tt class="py-op">.</tt><tt id="link-1969" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-1969', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4317"></a><tt class="py-lineno">4317</tt>  <tt class="py-line">        <tt class="py-name">t</tt><tt class="py-op">.</tt><tt class="py-name">_format</tt> <tt class="py-op">=</tt> <tt class="py-name">format</tt> </tt>
<a name="L4318"></a><tt class="py-lineno">4318</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">t</tt> </tt>
</div><a name="L4319"></a><tt class="py-lineno">4319</tt>  <tt class="py-line"> </tt>
<a name="DAL.__iter__"></a><div id="DAL.__iter__-def"><a name="L4320"></a><tt class="py-lineno">4320</tt> <a class="py-toggle" href="#" id="DAL.__iter__-toggle" onclick="return toggle('DAL.__iter__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__iter__">__iter__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__iter__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__iter__-expanded"><a name="L4321"></a><tt class="py-lineno">4321</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1970" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1970', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4322"></a><tt class="py-lineno">4322</tt>  <tt class="py-line">            <tt class="py-keyword">yield</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
</div><a name="L4323"></a><tt class="py-lineno">4323</tt>  <tt class="py-line"> </tt>
<a name="DAL.__getitem__"></a><div id="DAL.__getitem__-def"><a name="L4324"></a><tt class="py-lineno">4324</tt> <a class="py-toggle" href="#" id="DAL.__getitem__-toggle" onclick="return toggle('DAL.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__getitem__-expanded"><a name="L4325"></a><tt class="py-lineno">4325</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1971" class="py-name"><a title="web2py.gluon.compileapp.mybuiltin.__getitem__
web2py.gluon.dal.DAL.__getitem__
web2py.gluon.dal.Expression.__getitem__
web2py.gluon.dal.Reference.__getitem__
web2py.gluon.dal.Row.__getitem__
web2py.gluon.dal.Rows.__getitem__
web2py.gluon.dal.SQLCustomType.__getitem__
web2py.gluon.dal.Table.__getitem__
web2py.gluon.html.DIV.__getitem__
web2py.gluon.html.XML.__getitem__
web2py.gluon.html.__TAG__.__getitem__
web2py.gluon.languages.lazyT.__getitem__
web2py.gluon.rocket.FileWrapper.__getitem__
web2py.gluon.rocket.Headers.__getitem__" class="py-name" href="#" onclick="return doclink('link-1971', '__getitem__', 'link-1720');">__getitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4326"></a><tt class="py-lineno">4326</tt>  <tt class="py-line"> </tt>
<a name="DAL.__setitem__"></a><div id="DAL.__setitem__-def"><a name="L4327"></a><tt class="py-lineno">4327</tt> <a class="py-toggle" href="#" id="DAL.__setitem__-toggle" onclick="return toggle('DAL.__setitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__setitem__">__setitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__setitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__setitem__-expanded"><a name="L4328"></a><tt class="py-lineno">4328</tt>  <tt class="py-line">        <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1972" class="py-name"><a title="web2py.gluon.compileapp.mybuiltin.__setitem__
web2py.gluon.dal.DAL.__setitem__
web2py.gluon.dal.Reference.__setitem__
web2py.gluon.dal.Row.__setitem__
web2py.gluon.dal.Table.__setitem__
web2py.gluon.html.DIV.__setitem__
web2py.gluon.rocket.Headers.__setitem__" class="py-name" href="#" onclick="return doclink('link-1972', '__setitem__', 'link-1722');">__setitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4329"></a><tt class="py-lineno">4329</tt>  <tt class="py-line"> </tt>
<a name="DAL.__getattr__"></a><div id="DAL.__getattr__-def"><a name="L4330"></a><tt class="py-lineno">4330</tt> <a class="py-toggle" href="#" id="DAL.__getattr__-toggle" onclick="return toggle('DAL.__getattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__getattr__">__getattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__getattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__getattr__-expanded"><a name="L4331"></a><tt class="py-lineno">4331</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
</div><a name="L4332"></a><tt class="py-lineno">4332</tt>  <tt class="py-line"> </tt>
<a name="DAL.__setattr__"></a><div id="DAL.__setattr__-def"><a name="L4333"></a><tt class="py-lineno">4333</tt> <a class="py-toggle" href="#" id="DAL.__setattr__-toggle" onclick="return toggle('DAL.__setattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__setattr__">__setattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__setattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__setattr__-expanded"><a name="L4334"></a><tt class="py-lineno">4334</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">!=</tt><tt class="py-string">'_'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">:</tt> </tt>
<a name="L4335"></a><tt class="py-lineno">4335</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L4336"></a><tt class="py-lineno">4336</tt>  <tt class="py-line">                <tt class="py-string">'Object %s exists and cannot be redefined'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
<a name="L4337"></a><tt class="py-lineno">4337</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
</div><a name="L4338"></a><tt class="py-lineno">4338</tt>  <tt class="py-line"> </tt>
<a name="DAL.__repr__"></a><div id="DAL.__repr__-def"><a name="L4339"></a><tt class="py-lineno">4339</tt> <a class="py-toggle" href="#" id="DAL.__repr__-toggle" onclick="return toggle('DAL.__repr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__repr__">__repr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__repr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__repr__-expanded"><a name="L4340"></a><tt class="py-lineno">4340</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'&lt;DAL '</tt> <tt class="py-op">+</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-1973" class="py-name"><a title="web2py.gluon.dal.DAL.__repr__
web2py.gluon.dal.GAEF.__repr__
web2py.gluon.dal.Row.__repr__
web2py.gluon.dal.Table.__repr__
web2py.gluon.languages.lazyT.__repr__
web2py.gluon.rocket.Headers.__repr__
web2py.gluon.storage.Storage.__repr__
web2py.gluon.template.BlockNode.__repr__
web2py.gluon.template.SuperNode.__repr__" class="py-name" href="#" onclick="return doclink('link-1973', '__repr__', 'link-1723');">__repr__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">'&gt;'</tt> </tt>
</div><a name="L4341"></a><tt class="py-lineno">4341</tt>  <tt class="py-line"> </tt>
<a name="DAL.__call__"></a><div id="DAL.__call__-def"><a name="L4342"></a><tt class="py-lineno">4342</tt> <a class="py-toggle" href="#" id="DAL.__call__-toggle" onclick="return toggle('DAL.__call__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#__call__">__call__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.__call__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.__call__-expanded"><a name="L4343"></a><tt class="py-lineno">4343</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1974" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-1974', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4344"></a><tt class="py-lineno">4344</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">&gt;</tt><tt class="py-number">0</tt> </tt>
<a name="L4345"></a><tt class="py-lineno">4345</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-1975" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-1975', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4346"></a><tt class="py-lineno">4346</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">!=</tt><tt class="py-name">None</tt> </tt>
<a name="L4347"></a><tt class="py-lineno">4347</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-1976" class="py-name"><a title="web2py.gluon.dal.Set" class="py-name" href="#" onclick="return doclink('link-1976', 'Set', 'link-676');">Set</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4348"></a><tt class="py-lineno">4348</tt>  <tt class="py-line"> </tt>
<a name="DAL.commit"></a><div id="DAL.commit-def"><a name="L4349"></a><tt class="py-lineno">4349</tt> <a class="py-toggle" href="#" id="DAL.commit-toggle" onclick="return toggle('DAL.commit');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#commit">commit</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.commit-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.commit-expanded"><a name="L4350"></a><tt class="py-lineno">4350</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1977" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.commit
web2py.gluon.dal.DAL.commit
web2py.gluon.dal.NoSQLAdapter.commit" class="py-name" href="#" onclick="return doclink('link-1977', 'commit', 'link-250');">commit</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4351"></a><tt class="py-lineno">4351</tt>  <tt class="py-line"> </tt>
<a name="DAL.rollback"></a><div id="DAL.rollback-def"><a name="L4352"></a><tt class="py-lineno">4352</tt> <a class="py-toggle" href="#" id="DAL.rollback-toggle" onclick="return toggle('DAL.rollback');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#rollback">rollback</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.rollback-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.rollback-expanded"><a name="L4353"></a><tt class="py-lineno">4353</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1978" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.rollback
web2py.gluon.dal.DAL.rollback
web2py.gluon.dal.NoSQLAdapter.rollback" class="py-name" href="#" onclick="return doclink('link-1978', 'rollback', 'link-574');">rollback</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4354"></a><tt class="py-lineno">4354</tt>  <tt class="py-line"> </tt>
<a name="DAL.executesql"></a><div id="DAL.executesql-def"><a name="L4355"></a><tt class="py-lineno">4355</tt> <a class="py-toggle" href="#" id="DAL.executesql-toggle" onclick="return toggle('DAL.executesql');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#executesql">executesql</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">,</tt> <tt class="py-param">placeholders</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-param">as_dict</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.executesql-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.executesql-expanded"><a name="L4356"></a><tt class="py-lineno">4356</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L4357"></a><tt class="py-lineno">4357</tt>  <tt class="py-line"><tt class="py-docstring">        placeholders is optional and will always be None when using DAL</tt> </tt>
<a name="L4358"></a><tt class="py-lineno">4358</tt>  <tt class="py-line"><tt class="py-docstring">        if using raw SQL with placeholders, placeholders may be</tt> </tt>
<a name="L4359"></a><tt class="py-lineno">4359</tt>  <tt class="py-line"><tt class="py-docstring">        a sequence of values to be substituted in</tt> </tt>
<a name="L4360"></a><tt class="py-lineno">4360</tt>  <tt class="py-line"><tt class="py-docstring">        or, *if supported by the DB driver*, a dictionary with keys</tt> </tt>
<a name="L4361"></a><tt class="py-lineno">4361</tt>  <tt class="py-line"><tt class="py-docstring">        matching named placeholders in your SQL.</tt> </tt>
<a name="L4362"></a><tt class="py-lineno">4362</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4363"></a><tt class="py-lineno">4363</tt>  <tt class="py-line"><tt class="py-docstring">        Added 2009-12-05 "as_dict" optional argument. Will always be</tt> </tt>
<a name="L4364"></a><tt class="py-lineno">4364</tt>  <tt class="py-line"><tt class="py-docstring">        None when using DAL. If using raw SQL can be set to True</tt> </tt>
<a name="L4365"></a><tt class="py-lineno">4365</tt>  <tt class="py-line"><tt class="py-docstring">        and the results cursor returned by the DB driver will be</tt> </tt>
<a name="L4366"></a><tt class="py-lineno">4366</tt>  <tt class="py-line"><tt class="py-docstring">        converted to a sequence of dictionaries keyed with the db</tt> </tt>
<a name="L4367"></a><tt class="py-lineno">4367</tt>  <tt class="py-line"><tt class="py-docstring">        field names. Tested with SQLite but should work with any database</tt> </tt>
<a name="L4368"></a><tt class="py-lineno">4368</tt>  <tt class="py-line"><tt class="py-docstring">        since the cursor.description used to get field names is part of the</tt> </tt>
<a name="L4369"></a><tt class="py-lineno">4369</tt>  <tt class="py-line"><tt class="py-docstring">        Python dbi 2.0 specs. Results returned with as_dict = True are</tt> </tt>
<a name="L4370"></a><tt class="py-lineno">4370</tt>  <tt class="py-line"><tt class="py-docstring">        the same as those returned when applying .to_list() to a DAL query.</tt> </tt>
<a name="L4371"></a><tt class="py-lineno">4371</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4372"></a><tt class="py-lineno">4372</tt>  <tt class="py-line"><tt class="py-docstring">        [{field1: value1, field2: value2}, {field1: value1b, field2: value2b}]</tt> </tt>
<a name="L4373"></a><tt class="py-lineno">4373</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4374"></a><tt class="py-lineno">4374</tt>  <tt class="py-line"><tt class="py-docstring">        --bmeredyk</tt> </tt>
<a name="L4375"></a><tt class="py-lineno">4375</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L4376"></a><tt class="py-lineno">4376</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">placeholders</tt><tt class="py-op">:</tt> </tt>
<a name="L4377"></a><tt class="py-lineno">4377</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1979" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1979', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt> <tt class="py-name">placeholders</tt><tt class="py-op">)</tt> </tt>
<a name="L4378"></a><tt class="py-lineno">4378</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4379"></a><tt class="py-lineno">4379</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-1980" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.execute
web2py.gluon.dal.DB2Adapter.execute
web2py.gluon.dal.InformixAdapter.execute
web2py.gluon.dal.JDBCSQLiteAdapter.execute
web2py.gluon.dal.MSSQL2Adapter.execute
web2py.gluon.dal.NoSQLAdapter.execute
web2py.gluon.dal.OracleAdapter.execute" class="py-name" href="#" onclick="return doclink('link-1980', 'execute', 'link-284');">execute</a></tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L4380"></a><tt class="py-lineno">4380</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-1981" class="py-name"><a title="web2py.gluon.dal.Row.as_dict
web2py.gluon.dal.Rows.as_dict" class="py-name" href="#" onclick="return doclink('link-1981', 'as_dict', 'link-1725');">as_dict</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4381"></a><tt class="py-lineno">4381</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">,</tt><tt class="py-string">'description'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4382"></a><tt class="py-lineno">4382</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"database does not support executesql(...,as_dict=True)"</tt> </tt>
<a name="L4383"></a><tt class="py-lineno">4383</tt>  <tt class="py-line">            <tt class="py-comment"># Non-DAL legacy db query, converts cursor results to dict.</tt> </tt>
<a name="L4384"></a><tt class="py-lineno">4384</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-comment"># sequence of 7-item sequences. each sequence tells about a column.</tt> </tt>
<a name="L4385"></a><tt class="py-lineno">4385</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-comment"># first item is always the field name according to Python Database API specs</tt> </tt>
<a name="L4386"></a><tt class="py-lineno">4386</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">columns</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">description</tt> </tt>
<a name="L4387"></a><tt class="py-lineno">4387</tt>  <tt class="py-line">            <tt class="py-comment"># reduce the column info down to just the field names</tt> </tt>
<a name="L4388"></a><tt class="py-lineno">4388</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">columns</tt><tt class="py-op">]</tt> </tt>
<a name="L4389"></a><tt class="py-lineno">4389</tt>  <tt class="py-line">            <tt class="py-comment"># will hold our finished resultset in a list</tt> </tt>
<a name="L4390"></a><tt class="py-lineno">4390</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchall</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4391"></a><tt class="py-lineno">4391</tt>  <tt class="py-line">            <tt class="py-comment"># convert the list for each row into a dictionary so it's</tt> </tt>
<a name="L4392"></a><tt class="py-lineno">4392</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-comment"># easier to work with. row['field_name'] rather than row[0]</tt> </tt>
<a name="L4393"></a><tt class="py-lineno">4393</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-keyword">return</tt> <tt class="py-op">[</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">zip</tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt><tt class="py-name">row</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">row</tt> <tt class="py-keyword">in</tt> <tt class="py-name">data</tt><tt class="py-op">]</tt> </tt>
<a name="L4394"></a><tt class="py-lineno">4394</tt>  <tt class="py-line">        <tt class="py-comment"># see if any results returned from database</tt> </tt>
<a name="L4395"></a><tt class="py-lineno">4395</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4396"></a><tt class="py-lineno">4396</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">cursor</tt><tt class="py-op">.</tt><tt class="py-name">fetchall</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4397"></a><tt class="py-lineno">4397</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L4398"></a><tt class="py-lineno">4398</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L4399"></a><tt class="py-lineno">4399</tt>  <tt class="py-line"> </tt>
<a name="DAL._update_referenced_by"></a><div id="DAL._update_referenced_by-def"><a name="L4400"></a><tt class="py-lineno">4400</tt> <a class="py-toggle" href="#" id="DAL._update_referenced_by-toggle" onclick="return toggle('DAL._update_referenced_by');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#_update_referenced_by">_update_referenced_by</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL._update_referenced_by-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL._update_referenced_by-expanded"><a name="L4401"></a><tt class="py-lineno">4401</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1982" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1982', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4402"></a><tt class="py-lineno">4402</tt>  <tt class="py-line">            <tt class="py-name">by</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt> </tt>
<a name="L4403"></a><tt class="py-lineno">4403</tt>  <tt class="py-line">            <tt class="py-name">by</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">item</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">by</tt> <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">item</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">other</tt><tt class="py-op">]</tt> </tt>
</div><a name="L4404"></a><tt class="py-lineno">4404</tt>  <tt class="py-line"> </tt>
<a name="DAL.export_to_csv_file"></a><div id="DAL.export_to_csv_file-def"><a name="L4405"></a><tt class="py-lineno">4405</tt> <a class="py-toggle" href="#" id="DAL.export_to_csv_file-toggle" onclick="return toggle('DAL.export_to_csv_file');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#export_to_csv_file">export_to_csv_file</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ofile</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-param">args</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">kwargs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.export_to_csv_file-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.export_to_csv_file-expanded"><a name="L4406"></a><tt class="py-lineno">4406</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">table</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1983" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1983', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4407"></a><tt class="py-lineno">4407</tt>  <tt class="py-line">            <tt class="py-name">ofile</tt><tt class="py-op">.</tt><tt id="link-1984" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-1984', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'TABLE %s\r\n'</tt> <tt class="py-op">%</tt> <tt class="py-name">table</tt><tt class="py-op">)</tt> </tt>
<a name="L4408"></a><tt class="py-lineno">4408</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">&gt;</tt> <tt class="py-number">0</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1985" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-1985', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-1986" class="py-name" targets="Method web2py.gluon.dal.DAL.export_to_csv_file()=web2py.gluon.dal.DAL-class.html#export_to_csv_file,Method web2py.gluon.dal.Rows.export_to_csv_file()=web2py.gluon.dal.Rows-class.html#export_to_csv_file"><a title="web2py.gluon.dal.DAL.export_to_csv_file
web2py.gluon.dal.Rows.export_to_csv_file" class="py-name" href="#" onclick="return doclink('link-1986', 'export_to_csv_file', 'link-1986');">export_to_csv_file</a></tt><tt class="py-op">(</tt><tt class="py-name">ofile</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-name">args</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-name">kwargs</tt><tt class="py-op">)</tt> </tt>
<a name="L4409"></a><tt class="py-lineno">4409</tt>  <tt class="py-line">            <tt class="py-name">ofile</tt><tt class="py-op">.</tt><tt id="link-1987" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-1987', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'\r\n\r\n'</tt><tt class="py-op">)</tt> </tt>
<a name="L4410"></a><tt class="py-lineno">4410</tt>  <tt class="py-line">        <tt class="py-name">ofile</tt><tt class="py-op">.</tt><tt id="link-1988" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.write
web2py.gluon.debug.Pipe.write
web2py.gluon.globals.Response.write
web2py.gluon.rocket.WSGIWorker.write
web2py.gluon.widget.IO.write" class="py-name" href="#" onclick="return doclink('link-1988', 'write', 'link-245');">write</a></tt><tt class="py-op">(</tt><tt class="py-string">'END'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4411"></a><tt class="py-lineno">4411</tt>  <tt class="py-line"> </tt>
<a name="DAL.import_from_csv_file"></a><div id="DAL.import_from_csv_file-def"><a name="L4412"></a><tt class="py-lineno">4412</tt> <a class="py-toggle" href="#" id="DAL.import_from_csv_file-toggle" onclick="return toggle('DAL.import_from_csv_file');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.DAL-class.html#import_from_csv_file">import_from_csv_file</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ifile</tt><tt class="py-op">,</tt> <tt class="py-param">id_map</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">,</tt> <tt class="py-param">null</tt><tt class="py-op">=</tt><tt class="py-string">'&lt;NULL&gt;'</tt><tt class="py-op">,</tt> </tt>
<a name="L4413"></a><tt class="py-lineno">4413</tt>  <tt class="py-line">                             <tt class="py-param">unique</tt><tt class="py-op">=</tt><tt class="py-string">'uuid'</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-param">args</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">kwargs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="DAL.import_from_csv_file-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="DAL.import_from_csv_file-expanded"><a name="L4414"></a><tt class="py-lineno">4414</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">line</tt> <tt class="py-keyword">in</tt> <tt class="py-name">ifile</tt><tt class="py-op">:</tt> </tt>
<a name="L4415"></a><tt class="py-lineno">4415</tt>  <tt class="py-line">            <tt class="py-name">line</tt> <tt class="py-op">=</tt> <tt class="py-name">line</tt><tt class="py-op">.</tt><tt id="link-1989" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-1989', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4416"></a><tt class="py-lineno">4416</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">line</tt><tt class="py-op">:</tt> </tt>
<a name="L4417"></a><tt class="py-lineno">4417</tt>  <tt class="py-line">                <tt class="py-keyword">continue</tt> </tt>
<a name="L4418"></a><tt class="py-lineno">4418</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">line</tt> <tt class="py-op">==</tt> <tt class="py-string">'END'</tt><tt class="py-op">:</tt> </tt>
<a name="L4419"></a><tt class="py-lineno">4419</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> </tt>
<a name="L4420"></a><tt class="py-lineno">4420</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">line</tt><tt class="py-op">.</tt><tt id="link-1990" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1990', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'TABLE '</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-number">6</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1991" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-1991', 'tables', 'link-313');">tables</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4421"></a><tt class="py-lineno">4421</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'invalid file format'</tt> </tt>
<a name="L4422"></a><tt class="py-lineno">4422</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4423"></a><tt class="py-lineno">4423</tt>  <tt class="py-line">                <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-number">6</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L4424"></a><tt class="py-lineno">4424</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-1992" class="py-name" targets="Method web2py.gluon.dal.DAL.import_from_csv_file()=web2py.gluon.dal.DAL-class.html#import_from_csv_file,Method web2py.gluon.dal.Table.import_from_csv_file()=web2py.gluon.dal.Table-class.html#import_from_csv_file"><a title="web2py.gluon.dal.DAL.import_from_csv_file
web2py.gluon.dal.Table.import_from_csv_file" class="py-name" href="#" onclick="return doclink('link-1992', 'import_from_csv_file', 'link-1992');">import_from_csv_file</a></tt><tt class="py-op">(</tt><tt class="py-name">ifile</tt><tt class="py-op">,</tt> <tt class="py-name">id_map</tt><tt class="py-op">,</tt> <tt class="py-name">null</tt><tt class="py-op">,</tt> </tt>
<a name="L4425"></a><tt class="py-lineno">4425</tt>  <tt class="py-line">                                                     <tt class="py-name">unique</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-name">args</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-name">kwargs</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L4426"></a><tt class="py-lineno">4426</tt>  <tt class="py-line"> </tt>
<a name="L4427"></a><tt class="py-lineno">4427</tt>  <tt class="py-line"> </tt>
<a name="SQLALL"></a><div id="SQLALL-def"><a name="L4428"></a><tt class="py-lineno">4428</tt> <a class="py-toggle" href="#" id="SQLALL-toggle" onclick="return toggle('SQLALL');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLALL-class.html">SQLALL</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLALL-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="SQLALL-expanded"><a name="L4429"></a><tt class="py-lineno">4429</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L4430"></a><tt class="py-lineno">4430</tt>  <tt class="py-line"><tt class="py-docstring">    Helper class providing a comma-separated string having all the field names</tt> </tt>
<a name="L4431"></a><tt class="py-lineno">4431</tt>  <tt class="py-line"><tt class="py-docstring">    (prefixed by table name and '.')</tt> </tt>
<a name="L4432"></a><tt class="py-lineno">4432</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4433"></a><tt class="py-lineno">4433</tt>  <tt class="py-line"><tt class="py-docstring">    normally only called from within gluon.sql</tt> </tt>
<a name="L4434"></a><tt class="py-lineno">4434</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L4435"></a><tt class="py-lineno">4435</tt>  <tt class="py-line"> </tt>
<a name="SQLALL.__init__"></a><div id="SQLALL.__init__-def"><a name="L4436"></a><tt class="py-lineno">4436</tt> <a class="py-toggle" href="#" id="SQLALL.__init__-toggle" onclick="return toggle('SQLALL.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLALL-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">table</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLALL.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLALL.__init__-expanded"><a name="L4437"></a><tt class="py-lineno">4437</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt> </tt>
</div><a name="L4438"></a><tt class="py-lineno">4438</tt>  <tt class="py-line"> </tt>
<a name="SQLALL.__str__"></a><div id="SQLALL.__str__-def"><a name="L4439"></a><tt class="py-lineno">4439</tt> <a class="py-toggle" href="#" id="SQLALL.__str__-toggle" onclick="return toggle('SQLALL.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLALL-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLALL.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLALL.__str__-expanded"><a name="L4440"></a><tt class="py-lineno">4440</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-1993" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-1993', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L4441"></a><tt class="py-lineno">4441</tt>  <tt class="py-line"> </tt>
<a name="L4442"></a><tt class="py-lineno">4442</tt>  <tt class="py-line"> </tt>
<a name="Reference"></a><div id="Reference-def"><a name="L4443"></a><tt class="py-lineno">4443</tt> <a class="py-toggle" href="#" id="Reference-toggle" onclick="return toggle('Reference');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Reference-class.html">Reference</a><tt class="py-op">(</tt><tt class="py-base-class">int</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Reference-expanded"><a name="L4444"></a><tt class="py-lineno">4444</tt>  <tt class="py-line"> </tt>
<a name="Reference.__allocate"></a><div id="Reference.__allocate-def"><a name="L4445"></a><tt class="py-lineno">4445</tt> <a class="py-toggle" href="#" id="Reference.__allocate-toggle" onclick="return toggle('Reference.__allocate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Reference-class.html#__allocate">__allocate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference.__allocate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Reference.__allocate-expanded"><a name="L4446"></a><tt class="py-lineno">4446</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">:</tt> </tt>
<a name="L4447"></a><tt class="py-lineno">4447</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_table</tt><tt class="py-op">[</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L4448"></a><tt class="py-lineno">4448</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">:</tt> </tt>
<a name="L4449"></a><tt class="py-lineno">4449</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"Using a recursive select but encountered a broken reference: %s %d"</tt><tt class="py-op">%</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_table</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4450"></a><tt class="py-lineno">4450</tt>  <tt class="py-line"> </tt>
<a name="Reference.__getattr__"></a><div id="Reference.__getattr__-def"><a name="L4451"></a><tt class="py-lineno">4451</tt> <a class="py-toggle" href="#" id="Reference.__getattr__-toggle" onclick="return toggle('Reference.__getattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Reference-class.html#__getattr__">__getattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference.__getattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Reference.__getattr__-expanded"><a name="L4452"></a><tt class="py-lineno">4452</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-op">==</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L4453"></a><tt class="py-lineno">4453</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
<a name="L4454"></a><tt class="py-lineno">4454</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1994" class="py-name" targets="Method web2py.gluon.dal.Reference.__allocate()=web2py.gluon.dal.Reference-class.html#__allocate"><a title="web2py.gluon.dal.Reference.__allocate" class="py-name" href="#" onclick="return doclink('link-1994', '__allocate', 'link-1994');">__allocate</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4455"></a><tt class="py-lineno">4455</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">.</tt><tt id="link-1995" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-1995', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4456"></a><tt class="py-lineno">4456</tt>  <tt class="py-line"> </tt>
<a name="Reference.__setattr__"></a><div id="Reference.__setattr__-def"><a name="L4457"></a><tt class="py-lineno">4457</tt> <a class="py-toggle" href="#" id="Reference.__setattr__-toggle" onclick="return toggle('Reference.__setattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Reference-class.html#__setattr__">__setattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference.__setattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Reference.__setattr__-expanded"><a name="L4458"></a><tt class="py-lineno">4458</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-1996" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-1996', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4459"></a><tt class="py-lineno">4459</tt>  <tt class="py-line">            <tt class="py-name">int</tt><tt class="py-op">.</tt><tt id="link-1997" class="py-name" targets="Method web2py.gluon.dal.DAL.__setattr__()=web2py.gluon.dal.DAL-class.html#__setattr__,Method web2py.gluon.dal.Reference.__setattr__()=web2py.gluon.dal.Reference-class.html#__setattr__,Method web2py.gluon.dal.Row.__setattr__()=web2py.gluon.dal.Row-class.html#__setattr__,Method web2py.gluon.dal.Table.__setattr__()=web2py.gluon.dal.Table-class.html#__setattr__,Method web2py.gluon.storage.Messages.__setattr__()=web2py.gluon.storage.Messages-class.html#__setattr__,Method web2py.gluon.storage.Settings.__setattr__()=web2py.gluon.storage.Settings-class.html#__setattr__,Method web2py.gluon.storage.Storage.__setattr__()=web2py.gluon.storage.Storage-class.html#__setattr__"><a title="web2py.gluon.dal.DAL.__setattr__
web2py.gluon.dal.Reference.__setattr__
web2py.gluon.dal.Row.__setattr__
web2py.gluon.dal.Table.__setattr__
web2py.gluon.storage.Messages.__setattr__
web2py.gluon.storage.Settings.__setattr__
web2py.gluon.storage.Storage.__setattr__" class="py-name" href="#" onclick="return doclink('link-1997', '__setattr__', 'link-1997');">__setattr__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4460"></a><tt class="py-lineno">4460</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> </tt>
<a name="L4461"></a><tt class="py-lineno">4461</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1998" class="py-name"><a title="web2py.gluon.dal.Reference.__allocate" class="py-name" href="#" onclick="return doclink('link-1998', '__allocate', 'link-1994');">__allocate</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4462"></a><tt class="py-lineno">4462</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt>  <tt class="py-name">value</tt> </tt>
</div><a name="L4463"></a><tt class="py-lineno">4463</tt>  <tt class="py-line"> </tt>
<a name="Reference.__getitem__"></a><div id="Reference.__getitem__-def"><a name="L4464"></a><tt class="py-lineno">4464</tt> <a class="py-toggle" href="#" id="Reference.__getitem__-toggle" onclick="return toggle('Reference.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Reference-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Reference.__getitem__-expanded"><a name="L4465"></a><tt class="py-lineno">4465</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-op">==</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L4466"></a><tt class="py-lineno">4466</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
<a name="L4467"></a><tt class="py-lineno">4467</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-1999" class="py-name"><a title="web2py.gluon.dal.Reference.__allocate" class="py-name" href="#" onclick="return doclink('link-1999', '__allocate', 'link-1994');">__allocate</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4468"></a><tt class="py-lineno">4468</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">.</tt><tt id="link-2000" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2000', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4469"></a><tt class="py-lineno">4469</tt>  <tt class="py-line"> </tt>
<a name="Reference.__setitem__"></a><div id="Reference.__setitem__-def"><a name="L4470"></a><tt class="py-lineno">4470</tt> <a class="py-toggle" href="#" id="Reference.__setitem__-toggle" onclick="return toggle('Reference.__setitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Reference-class.html#__setitem__">__setitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">,</tt><tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference.__setitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Reference.__setitem__-expanded"><a name="L4471"></a><tt class="py-lineno">4471</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2001" class="py-name"><a title="web2py.gluon.dal.Reference.__allocate" class="py-name" href="#" onclick="return doclink('link-2001', '__allocate', 'link-1994');">__allocate</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4472"></a><tt class="py-lineno">4472</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_record</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
</div></div><a name="L4473"></a><tt class="py-lineno">4473</tt>  <tt class="py-line"> </tt>
<a name="L4474"></a><tt class="py-lineno">4474</tt>  <tt class="py-line"> </tt>
<a name="Reference_unpickler"></a><div id="Reference_unpickler-def"><a name="L4475"></a><tt class="py-lineno">4475</tt> <a class="py-toggle" href="#" id="Reference_unpickler-toggle" onclick="return toggle('Reference_unpickler');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#Reference_unpickler">Reference_unpickler</a><tt class="py-op">(</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference_unpickler-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Reference_unpickler-expanded"><a name="L4476"></a><tt class="py-lineno">4476</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">marshal</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4477"></a><tt class="py-lineno">4477</tt>  <tt class="py-line"> </tt>
<a name="Reference_pickler"></a><div id="Reference_pickler-def"><a name="L4478"></a><tt class="py-lineno">4478</tt> <a class="py-toggle" href="#" id="Reference_pickler-toggle" onclick="return toggle('Reference_pickler');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#Reference_pickler">Reference_pickler</a><tt class="py-op">(</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Reference_pickler-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Reference_pickler-expanded"><a name="L4479"></a><tt class="py-lineno">4479</tt>  <tt class="py-line">    <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4480"></a><tt class="py-lineno">4480</tt>  <tt class="py-line">        <tt class="py-name">marshal_dump</tt> <tt class="py-op">=</tt> <tt class="py-name">marshal</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4481"></a><tt class="py-lineno">4481</tt>  <tt class="py-line">    <tt class="py-keyword">except</tt> <tt class="py-name">AttributeError</tt><tt class="py-op">:</tt> </tt>
<a name="L4482"></a><tt class="py-lineno">4482</tt>  <tt class="py-line">        <tt class="py-name">marshal_dump</tt> <tt class="py-op">=</tt> <tt class="py-string">'i%s'</tt> <tt class="py-op">%</tt> <tt class="py-name">struct</tt><tt class="py-op">.</tt><tt class="py-name">pack</tt><tt class="py-op">(</tt><tt class="py-string">'&lt;i'</tt><tt class="py-op">,</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4483"></a><tt class="py-lineno">4483</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt id="link-2002" class="py-name" targets="Function web2py.gluon.dal.Reference_unpickler()=web2py.gluon.dal-module.html#Reference_unpickler"><a title="web2py.gluon.dal.Reference_unpickler" class="py-name" href="#" onclick="return doclink('link-2002', 'Reference_unpickler', 'link-2002');">Reference_unpickler</a></tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">marshal_dump</tt><tt class="py-op">,</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4484"></a><tt class="py-lineno">4484</tt>  <tt class="py-line"> </tt>
<a name="L4485"></a><tt class="py-lineno">4485</tt>  <tt class="py-line"><tt class="py-name">copy_reg</tt><tt class="py-op">.</tt><tt class="py-name">pickle</tt><tt class="py-op">(</tt><tt id="link-2003" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-2003', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">,</tt> <tt id="link-2004" class="py-name" targets="Function web2py.gluon.dal.Reference_pickler()=web2py.gluon.dal-module.html#Reference_pickler"><a title="web2py.gluon.dal.Reference_pickler" class="py-name" href="#" onclick="return doclink('link-2004', 'Reference_pickler', 'link-2004');">Reference_pickler</a></tt><tt class="py-op">,</tt> <tt id="link-2005" class="py-name"><a title="web2py.gluon.dal.Reference_unpickler" class="py-name" href="#" onclick="return doclink('link-2005', 'Reference_unpickler', 'link-2002');">Reference_unpickler</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4486"></a><tt class="py-lineno">4486</tt>  <tt class="py-line"> </tt>
<a name="L4487"></a><tt class="py-lineno">4487</tt>  <tt class="py-line"> </tt>
<a name="Table"></a><div id="Table-def"><a name="L4488"></a><tt class="py-lineno">4488</tt> <a class="py-toggle" href="#" id="Table-toggle" onclick="return toggle('Table');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html">Table</a><tt class="py-op">(</tt><tt class="py-base-class">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Table-expanded"><a name="L4489"></a><tt class="py-lineno">4489</tt>  <tt class="py-line"> </tt>
<a name="L4490"></a><tt class="py-lineno">4490</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L4491"></a><tt class="py-lineno">4491</tt>  <tt class="py-line"><tt class="py-docstring">    an instance of this class represents a database table</tt> </tt>
<a name="L4492"></a><tt class="py-lineno">4492</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4493"></a><tt class="py-lineno">4493</tt>  <tt class="py-line"><tt class="py-docstring">    Example::</tt> </tt>
<a name="L4494"></a><tt class="py-lineno">4494</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4495"></a><tt class="py-lineno">4495</tt>  <tt class="py-line"><tt class="py-docstring">        db = DAL(...)</tt> </tt>
<a name="L4496"></a><tt class="py-lineno">4496</tt>  <tt class="py-line"><tt class="py-docstring">        db.define_table('users', Field('name'))</tt> </tt>
<a name="L4497"></a><tt class="py-lineno">4497</tt>  <tt class="py-line"><tt class="py-docstring">        db.users.insert(name='me') # print db.users._insert(...) to see SQL</tt> </tt>
<a name="L4498"></a><tt class="py-lineno">4498</tt>  <tt class="py-line"><tt class="py-docstring">        db.users.drop()</tt> </tt>
<a name="L4499"></a><tt class="py-lineno">4499</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L4500"></a><tt class="py-lineno">4500</tt>  <tt class="py-line"> </tt>
<a name="Table.__init__"></a><div id="Table.__init__-def"><a name="L4501"></a><tt class="py-lineno">4501</tt> <a class="py-toggle" href="#" id="Table.__init__-toggle" onclick="return toggle('Table.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__init__">__init__</a><tt class="py-op">(</tt> </tt>
<a name="L4502"></a><tt class="py-lineno">4502</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L4503"></a><tt class="py-lineno">4503</tt>  <tt class="py-line">        <tt class="py-param">db</tt><tt class="py-op">,</tt> </tt>
<a name="L4504"></a><tt class="py-lineno">4504</tt>  <tt class="py-line">        <tt class="py-param">tablename</tt><tt class="py-op">,</tt> </tt>
<a name="L4505"></a><tt class="py-lineno">4505</tt>  <tt class="py-line">        <tt class="py-op">*</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt> </tt>
<a name="L4506"></a><tt class="py-lineno">4506</tt>  <tt class="py-line">        <tt class="py-op">**</tt><tt class="py-param">args</tt> </tt>
<a name="L4507"></a><tt class="py-lineno">4507</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__init__-expanded"><a name="L4508"></a><tt class="py-lineno">4508</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L4509"></a><tt class="py-lineno">4509</tt>  <tt class="py-line"><tt class="py-docstring">        Initializes the table and performs checking on the provided fields.</tt> </tt>
<a name="L4510"></a><tt class="py-lineno">4510</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4511"></a><tt class="py-lineno">4511</tt>  <tt class="py-line"><tt class="py-docstring">        Each table will have automatically an 'id'.</tt> </tt>
<a name="L4512"></a><tt class="py-lineno">4512</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4513"></a><tt class="py-lineno">4513</tt>  <tt class="py-line"><tt class="py-docstring">        If a field is of type Table, the fields (excluding 'id') from that table</tt> </tt>
<a name="L4514"></a><tt class="py-lineno">4514</tt>  <tt class="py-line"><tt class="py-docstring">        will be used instead.</tt> </tt>
<a name="L4515"></a><tt class="py-lineno">4515</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L4516"></a><tt class="py-lineno">4516</tt>  <tt class="py-line"><tt class="py-docstring">        :raises SyntaxError: when a supplied field is of incorrect type.</tt> </tt>
<a name="L4517"></a><tt class="py-lineno">4517</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L4518"></a><tt class="py-lineno">4518</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4519"></a><tt class="py-lineno">4519</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_sequence_name</tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-2006" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2006', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'sequence_name'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> \ </tt>
<a name="L4520"></a><tt class="py-lineno">4520</tt>  <tt class="py-line">            <tt class="py-name">db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2007" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.sequence_name
web2py.gluon.dal.FireBirdAdapter.sequence_name
web2py.gluon.dal.OracleAdapter.sequence_name
web2py.gluon.dal.PostgreSQLAdapter.sequence_name
web2py.gluon.dal.SAPDBAdapter.sequence_name" class="py-name" href="#" onclick="return doclink('link-2007', 'sequence_name', 'link-821');">sequence_name</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4521"></a><tt class="py-lineno">4521</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_trigger_name</tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-2008" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2008', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'trigger_name'</tt><tt class="py-op">,</tt><tt class="py-name">None</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> \ </tt>
<a name="L4522"></a><tt class="py-lineno">4522</tt>  <tt class="py-line">            <tt class="py-name">db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2009" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.trigger_name
web2py.gluon.dal.FireBirdAdapter.trigger_name
web2py.gluon.dal.OracleAdapter.trigger_name" class="py-name" href="#" onclick="return doclink('link-2009', 'trigger_name', 'link-860');">trigger_name</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4523"></a><tt class="py-lineno">4523</tt>  <tt class="py-line"> </tt>
<a name="L4524"></a><tt class="py-lineno">4524</tt>  <tt class="py-line">        <tt class="py-name">primarykey</tt> <tt class="py-op">=</tt> <tt class="py-name">args</tt><tt class="py-op">.</tt><tt id="link-2010" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2010', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'primarykey'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L4525"></a><tt class="py-lineno">4525</tt>  <tt class="py-line">        <tt class="py-name">fieldnames</tt><tt class="py-op">,</tt><tt class="py-name">newfields</tt><tt class="py-op">=</tt><tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4526"></a><tt class="py-lineno">4526</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">primarykey</tt><tt class="py-op">:</tt> </tt>
<a name="L4527"></a><tt class="py-lineno">4527</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">primarykey</tt><tt class="py-op">,</tt><tt class="py-name">list</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4528"></a><tt class="py-lineno">4528</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L4529"></a><tt class="py-lineno">4529</tt>  <tt class="py-line">                    <tt class="py-string">"primarykey must be a list of fields from table '%s'"</tt> \ </tt>
<a name="L4530"></a><tt class="py-lineno">4530</tt>  <tt class="py-line">                    <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4531"></a><tt class="py-lineno">4531</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt> <tt class="py-op">=</tt> <tt class="py-name">primarykey</tt>             </tt>
<a name="L4532"></a><tt class="py-lineno">4532</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-op">[</tt><tt class="py-name">f</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">,</tt><tt id="link-2011" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2011', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4533"></a><tt class="py-lineno">4533</tt>  <tt class="py-line">            <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt id="link-2012" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2012', 'Field', 'link-430');">Field</a></tt><tt class="py-op">(</tt><tt class="py-string">'id'</tt><tt class="py-op">,</tt> <tt class="py-string">'id'</tt><tt class="py-op">)</tt> </tt>
<a name="L4534"></a><tt class="py-lineno">4534</tt>  <tt class="py-line">            <tt class="py-name">newfields</tt><tt class="py-op">.</tt><tt id="link-2013" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2013', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4535"></a><tt class="py-lineno">4535</tt>  <tt class="py-line">            <tt class="py-name">fieldnames</tt><tt class="py-op">.</tt><tt class="py-name">add</tt><tt class="py-op">(</tt><tt class="py-string">'id'</tt><tt class="py-op">)</tt> </tt>
<a name="L4536"></a><tt class="py-lineno">4536</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt> </tt>
<a name="L4537"></a><tt class="py-lineno">4537</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4538"></a><tt class="py-lineno">4538</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-2014" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2014', 'Field', 'link-430');">Field</a></tt><tt class="py-op">,</tt> <tt id="link-2015" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2015', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4539"></a><tt class="py-lineno">4539</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L4540"></a><tt class="py-lineno">4540</tt>  <tt class="py-line">                    <tt class="py-string">'define_table argument is not a Field or Table: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">field</tt> </tt>
<a name="L4541"></a><tt class="py-lineno">4541</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt> <tt id="link-2016" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2016', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2017" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2017', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">fieldnames</tt><tt class="py-op">:</tt> </tt>
<a name="L4542"></a><tt class="py-lineno">4542</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt> <tt class="py-string">'_db'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4543"></a><tt class="py-lineno">4543</tt>  <tt class="py-line">                    <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4544"></a><tt class="py-lineno">4544</tt>  <tt class="py-line">                <tt class="py-name">newfields</tt><tt class="py-op">.</tt><tt id="link-2018" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2018', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4545"></a><tt class="py-lineno">4545</tt>  <tt class="py-line">                <tt class="py-name">fieldnames</tt><tt class="py-op">.</tt><tt class="py-name">add</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2019" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2019', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4546"></a><tt class="py-lineno">4546</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L4547"></a><tt class="py-lineno">4547</tt>  <tt class="py-line">                    <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt> </tt>
<a name="L4548"></a><tt class="py-lineno">4548</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt> <tt id="link-2020" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2020', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4549"></a><tt class="py-lineno">4549</tt>  <tt class="py-line">                <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt> </tt>
<a name="L4550"></a><tt class="py-lineno">4550</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">:</tt> </tt>
<a name="L4551"></a><tt class="py-lineno">4551</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2021" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2021', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">fieldnames</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L4552"></a><tt class="py-lineno">4552</tt>  <tt class="py-line">                        <tt class="py-name">newfields</tt><tt class="py-op">.</tt><tt id="link-2022" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2022', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4553"></a><tt class="py-lineno">4553</tt>  <tt class="py-line">                        <tt class="py-name">fieldnames</tt><tt class="py-op">.</tt><tt class="py-name">add</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2023" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2023', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4554"></a><tt class="py-lineno">4554</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4555"></a><tt class="py-lineno">4555</tt>  <tt class="py-line">                <tt class="py-comment"># let's ignore new fields with duplicated names!!!</tt> </tt>
<a name="L4556"></a><tt class="py-lineno">4556</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-keyword">pass</tt> </tt>
<a name="L4557"></a><tt class="py-lineno">4557</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">newfields</tt> </tt>
<a name="L4558"></a><tt class="py-lineno">4558</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L4559"></a><tt class="py-lineno">4559</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4560"></a><tt class="py-lineno">4560</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt id="link-2024" class="py-name"><a title="web2py.gluon.dal.SQLCallableList" class="py-name" href="#" onclick="return doclink('link-2024', 'SQLCallableList', 'link-1799');">SQLCallableList</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4561"></a><tt class="py-lineno">4561</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">virtualfields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4562"></a><tt class="py-lineno">4562</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L4563"></a><tt class="py-lineno">4563</tt>  <tt class="py-line"> </tt>
<a name="L4564"></a><tt class="py-lineno">4564</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2025" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.uploads_in_blob
web2py.gluon.dal.CouchDBAdapter.uploads_in_blob
web2py.gluon.dal.GoogleDatastoreAdapter.uploads_in_blob
web2py.gluon.dal.MongoDBAdapter.uploads_in_blob" class="py-name" href="#" onclick="return doclink('link-2025', 'uploads_in_blob', 'link-164');">uploads_in_blob</a></tt><tt class="py-op">==</tt><tt class="py-name">True</tt><tt class="py-op">:</tt> </tt>
<a name="L4565"></a><tt class="py-lineno">4565</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4566"></a><tt class="py-lineno">4566</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">,</tt> <tt id="link-2026" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2026', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">==</tt> <tt class="py-string">'upload'</tt>\ </tt>
<a name="L4567"></a><tt class="py-lineno">4567</tt>  <tt class="py-line">                        <tt class="py-keyword">and</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> <tt class="py-keyword">is</tt> <tt class="py-name">True</tt><tt class="py-op">:</tt> </tt>
<a name="L4568"></a><tt class="py-lineno">4568</tt>  <tt class="py-line">                    <tt class="py-name">tmp</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> <tt class="py-op">=</tt> <tt class="py-string">'%s_blob'</tt> <tt class="py-op">%</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2027" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2027', 'name', 'link-119');">name</a></tt> </tt>
<a name="L4569"></a><tt class="py-lineno">4569</tt>  <tt class="py-line">                    <tt class="py-name">fields</tt><tt class="py-op">.</tt><tt id="link-2028" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2028', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt id="link-2029" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2029', 'Field', 'link-430');">Field</a></tt><tt class="py-op">(</tt><tt class="py-name">tmp</tt><tt class="py-op">,</tt> <tt class="py-string">'blob'</tt><tt class="py-op">,</tt> <tt class="py-name">default</tt><tt class="py-op">=</tt><tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4570"></a><tt class="py-lineno">4570</tt>  <tt class="py-line"> </tt>
<a name="L4571"></a><tt class="py-lineno">4571</tt>  <tt class="py-line">        <tt class="py-name">lower_fieldnames</tt> <tt class="py-op">=</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4572"></a><tt class="py-lineno">4572</tt>  <tt class="py-line">        <tt class="py-name">reserved</tt> <tt class="py-op">=</tt> <tt class="py-name">dir</tt><tt class="py-op">(</tt><tt id="link-2030" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2030', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-op">[</tt><tt class="py-string">'fields'</tt><tt class="py-op">]</tt>  </tt>
<a name="L4573"></a><tt class="py-lineno">4573</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">field</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4574"></a><tt class="py-lineno">4574</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">check_reserved</tt><tt class="py-op">:</tt> </tt>
<a name="L4575"></a><tt class="py-lineno">4575</tt>  <tt class="py-line">                <tt class="py-name">db</tt><tt class="py-op">.</tt><tt id="link-2031" class="py-name"><a title="web2py.gluon.dal.DAL.check_reserved_keyword" class="py-name" href="#" onclick="return doclink('link-2031', 'check_reserved_keyword', 'link-1956');">check_reserved_keyword</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2032" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2032', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4576"></a><tt class="py-lineno">4576</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2033" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2033', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">reserved</tt><tt class="py-op">:</tt> </tt>
<a name="L4577"></a><tt class="py-lineno">4577</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"field name %s not allowed"</tt> <tt class="py-op">%</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2034" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2034', 'name', 'link-119');">name</a></tt> </tt>
<a name="L4578"></a><tt class="py-lineno">4578</tt>  <tt class="py-line"> </tt>
<a name="L4579"></a><tt class="py-lineno">4579</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2035" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2035', 'name', 'link-119');">name</a></tt><tt class="py-op">.</tt><tt id="link-2036" class="py-name"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-2036', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">lower_fieldnames</tt><tt class="py-op">:</tt> </tt>
<a name="L4580"></a><tt class="py-lineno">4580</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"duplicate field %s in table %s"</tt> \ </tt>
<a name="L4581"></a><tt class="py-lineno">4581</tt>  <tt class="py-line">                    <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2037" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2037', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4582"></a><tt class="py-lineno">4582</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4583"></a><tt class="py-lineno">4583</tt>  <tt class="py-line">                <tt class="py-name">lower_fieldnames</tt><tt class="py-op">.</tt><tt class="py-name">add</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2038" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2038', 'name', 'link-119');">name</a></tt><tt class="py-op">.</tt><tt id="link-2039" class="py-name"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-2039', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4584"></a><tt class="py-lineno">4584</tt>  <tt class="py-line"> </tt>
<a name="L4585"></a><tt class="py-lineno">4585</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">.</tt><tt id="link-2040" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2040', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2041" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2041', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4586"></a><tt class="py-lineno">4586</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2042" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2042', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt> </tt>
<a name="L4587"></a><tt class="py-lineno">4587</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">==</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L4588"></a><tt class="py-lineno">4588</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-string">'id'</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt> </tt>
<a name="L4589"></a><tt class="py-lineno">4589</tt>  <tt class="py-line">            <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4590"></a><tt class="py-lineno">4590</tt>  <tt class="py-line">            <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">_table</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt> </tt>
<a name="L4591"></a><tt class="py-lineno">4591</tt>  <tt class="py-line">            <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt> </tt>
<a name="L4592"></a><tt class="py-lineno">4592</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">!=</tt><tt class="py-string">'text'</tt> <tt class="py-keyword">and</tt> \ </tt>
<a name="L4593"></a><tt class="py-lineno">4593</tt>  <tt class="py-line">                    <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2043" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.maxcharlength
web2py.gluon.dal.MySQLAdapter.maxcharlength" class="py-name" href="#" onclick="return doclink('link-2043', 'maxcharlength', 'link-160');">maxcharlength</a></tt> <tt class="py-op">&lt;</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">length</tt><tt class="py-op">:</tt> </tt>
<a name="L4594"></a><tt class="py-lineno">4594</tt>  <tt class="py-line">                <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">length</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2044" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.maxcharlength
web2py.gluon.dal.MySQLAdapter.maxcharlength" class="py-name" href="#" onclick="return doclink('link-2044', 'maxcharlength', 'link-160');">maxcharlength</a></tt> </tt>
<a name="L4595"></a><tt class="py-lineno">4595</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2045" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2045', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">==</tt> <tt id="link-2046" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2046', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4596"></a><tt class="py-lineno">4596</tt>  <tt class="py-line">                <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2047" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2047', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt id="link-2048" class="py-name" targets="Function web2py.gluon.dal.sqlhtml_validators()=web2py.gluon.dal-module.html#sqlhtml_validators"><a title="web2py.gluon.dal.sqlhtml_validators" class="py-name" href="#" onclick="return doclink('link-2048', 'sqlhtml_validators', 'link-2048');">sqlhtml_validators</a></tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">)</tt> </tt>
<a name="L4597"></a><tt class="py-lineno">4597</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ALL</tt> <tt class="py-op">=</tt> <tt id="link-2049" class="py-name"><a title="web2py.gluon.dal.SQLALL" class="py-name" href="#" onclick="return doclink('link-2049', 'SQLALL', 'link-439');">SQLALL</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
<a name="L4598"></a><tt class="py-lineno">4598</tt>  <tt class="py-line"> </tt>
<a name="L4599"></a><tt class="py-lineno">4599</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4600"></a><tt class="py-lineno">4600</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt id="link-2050" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2050', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">:</tt> </tt>
<a name="L4601"></a><tt class="py-lineno">4601</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt id="link-2051" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2051', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4602"></a><tt class="py-lineno">4602</tt>  <tt class="py-line">                    <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L4603"></a><tt class="py-lineno">4603</tt>  <tt class="py-line">                        <tt class="py-string">"primarykey must be a list of fields from table '%s "</tt> <tt class="py-op">%</tt> <tt class="py-name">tablename</tt> </tt>
<a name="L4604"></a><tt class="py-lineno">4604</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4605"></a><tt class="py-lineno">4605</tt>  <tt class="py-line">                    <tt class="py-name">self</tt><tt class="py-op">[</tt><tt id="link-2052" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2052', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
</div><a name="L4606"></a><tt class="py-lineno">4606</tt>  <tt class="py-line"> </tt>
<a name="Table._validate"></a><div id="Table._validate-def"><a name="L4607"></a><tt class="py-lineno">4607</tt> <a class="py-toggle" href="#" id="Table._validate-toggle" onclick="return toggle('Table._validate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_validate">_validate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">vars</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._validate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._validate-expanded"><a name="L4608"></a><tt class="py-lineno">4608</tt>  <tt class="py-line">        <tt class="py-name">errors</tt> <tt class="py-op">=</tt> <tt id="link-2053" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2053', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4609"></a><tt class="py-lineno">4609</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-name">value</tt> <tt class="py-keyword">in</tt> <tt class="py-name">vars</tt><tt class="py-op">.</tt><tt id="link-2054" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2054', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4610"></a><tt class="py-lineno">4610</tt>  <tt class="py-line">            <tt class="py-name">value</tt><tt class="py-op">,</tt><tt id="link-2055" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-2055', 'error', 'link-884');">error</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2056" class="py-name"><a title="web2py.gluon.dal.Field.validate
web2py.gluon.dal.GAEDecimalProperty.validate
web2py.gluon.html.FORM.validate" class="py-name" href="#" onclick="return doclink('link-2056', 'validate', 'link-118');">validate</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4611"></a><tt class="py-lineno">4611</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-2057" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-2057', 'error', 'link-884');">error</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4612"></a><tt class="py-lineno">4612</tt>  <tt class="py-line">                <tt class="py-name">errors</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-2058" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-2058', 'error', 'link-884');">error</a></tt> </tt>
<a name="L4613"></a><tt class="py-lineno">4613</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">errors</tt> </tt>
</div><a name="L4614"></a><tt class="py-lineno">4614</tt>  <tt class="py-line"> </tt>
<a name="Table._create_references"></a><div id="Table._create_references-def"><a name="L4615"></a><tt class="py-lineno">4615</tt> <a class="py-toggle" href="#" id="Table._create_references-toggle" onclick="return toggle('Table._create_references');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_create_references">_create_references</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._create_references-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._create_references-expanded"><a name="L4616"></a><tt class="py-lineno">4616</tt>  <tt class="py-line">        <tt class="py-name">pr</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_pending_references</tt> </tt>
<a name="L4617"></a><tt class="py-lineno">4617</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4618"></a><tt class="py-lineno">4618</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">fieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4619"></a><tt class="py-lineno">4619</tt>  <tt class="py-line">            <tt class="py-name">field</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> </tt>
<a name="L4620"></a><tt class="py-lineno">4620</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">10</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'reference '</tt><tt class="py-op">:</tt> </tt>
<a name="L4621"></a><tt class="py-lineno">4621</tt>  <tt class="py-line">                <tt class="py-name">ref</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2059" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-2059', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4622"></a><tt class="py-lineno">4622</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ref</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4623"></a><tt class="py-lineno">4623</tt>  <tt class="py-line">                    <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Table: reference to nothing: %s'</tt> <tt class="py-op">%</tt><tt class="py-name">ref</tt> </tt>
<a name="L4624"></a><tt class="py-lineno">4624</tt>  <tt class="py-line">                <tt class="py-name">refs</tt> <tt class="py-op">=</tt> <tt class="py-name">ref</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L4625"></a><tt class="py-lineno">4625</tt>  <tt class="py-line">                <tt class="py-name">rtablename</tt> <tt class="py-op">=</tt> <tt class="py-name">refs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L4626"></a><tt class="py-lineno">4626</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">rtablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">:</tt> </tt>
<a name="L4627"></a><tt class="py-lineno">4627</tt>  <tt class="py-line">                    <tt class="py-name">pr</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">pr</tt><tt class="py-op">.</tt><tt id="link-2060" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2060', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">rtablename</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt> </tt>
<a name="L4628"></a><tt class="py-lineno">4628</tt>  <tt class="py-line">                    <tt class="py-keyword">continue</tt> </tt>
<a name="L4629"></a><tt class="py-lineno">4629</tt>  <tt class="py-line">                <tt class="py-name">rtable</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">rtablename</tt><tt class="py-op">]</tt> </tt>
<a name="L4630"></a><tt class="py-lineno">4630</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt id="link-2061" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2061', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">refs</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-number">2</tt><tt class="py-op">:</tt> </tt>
<a name="L4631"></a><tt class="py-lineno">4631</tt>  <tt class="py-line">                    <tt class="py-name">rfieldname</tt> <tt class="py-op">=</tt> <tt class="py-name">refs</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
<a name="L4632"></a><tt class="py-lineno">4632</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">rtable</tt><tt class="py-op">,</tt><tt class="py-string">'_primarykey'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4633"></a><tt class="py-lineno">4633</tt>  <tt class="py-line">                        <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt>\ </tt>
<a name="L4634"></a><tt class="py-lineno">4634</tt>  <tt class="py-line">                            <tt class="py-string">'keyed tables can only reference other keyed tables (for now)'</tt> </tt>
<a name="L4635"></a><tt class="py-lineno">4635</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">rfieldname</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">rtable</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4636"></a><tt class="py-lineno">4636</tt>  <tt class="py-line">                        <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt>\ </tt>
<a name="L4637"></a><tt class="py-lineno">4637</tt>  <tt class="py-line">                            <tt class="py-string">"invalid field '%s' for referenced table '%s' in table '%s'"</tt> \ </tt>
<a name="L4638"></a><tt class="py-lineno">4638</tt>  <tt class="py-line">                            <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">rfieldname</tt><tt class="py-op">,</tt> <tt class="py-name">rtablename</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4639"></a><tt class="py-lineno">4639</tt>  <tt class="py-line">                <tt class="py-name">rtable</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt><tt class="py-op">.</tt><tt id="link-2062" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2062', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2063" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2063', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4640"></a><tt class="py-lineno">4640</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">referee</tt> <tt class="py-keyword">in</tt> <tt class="py-name">pr</tt><tt class="py-op">.</tt><tt id="link-2064" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2064', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4641"></a><tt class="py-lineno">4641</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_referenced_by</tt><tt class="py-op">.</tt><tt id="link-2065" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2065', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">referee</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt><tt class="py-name">referee</tt><tt class="py-op">.</tt><tt id="link-2066" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2066', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4642"></a><tt class="py-lineno">4642</tt>  <tt class="py-line"> </tt>
<a name="Table._filter_fields"></a><div id="Table._filter_fields-def"><a name="L4643"></a><tt class="py-lineno">4643</tt> <a class="py-toggle" href="#" id="Table._filter_fields-toggle" onclick="return toggle('Table._filter_fields');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_filter_fields">_filter_fields</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">record</tt><tt class="py-op">,</tt> <tt class="py-param">id</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._filter_fields-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._filter_fields-expanded"><a name="L4644"></a><tt class="py-lineno">4644</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">(</tt><tt id="link-2067" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2067', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt> <tt class="py-name">v</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt id="link-2068" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2068', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt> <tt class="py-name">v</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">record</tt><tt class="py-op">.</tt><tt id="link-2069" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2069', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">if</tt> <tt id="link-2070" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2070', 'k', 'link-189');">k</a></tt> </tt>
<a name="L4645"></a><tt class="py-lineno">4645</tt>  <tt class="py-line">                     <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt> <tt class="py-keyword">and</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt id="link-2071" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2071', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">!=</tt><tt class="py-string">'id'</tt> <tt class="py-keyword">or</tt> <tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4646"></a><tt class="py-lineno">4646</tt>  <tt class="py-line"> </tt>
<a name="Table._build_query"></a><div id="Table._build_query-def"><a name="L4647"></a><tt class="py-lineno">4647</tt> <a class="py-toggle" href="#" id="Table._build_query-toggle" onclick="return toggle('Table._build_query');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_build_query">_build_query</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._build_query-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._build_query-expanded"><a name="L4648"></a><tt class="py-lineno">4648</tt>  <tt class="py-line">        <tt class="py-docstring">""" for keyed table only """</tt> </tt>
<a name="L4649"></a><tt class="py-lineno">4649</tt>  <tt class="py-line">        <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4650"></a><tt class="py-lineno">4650</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt id="link-2072" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2072', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">key</tt><tt class="py-op">.</tt><tt class="py-name">iteritems</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4651"></a><tt class="py-lineno">4651</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-2073" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2073', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">:</tt> </tt>
<a name="L4652"></a><tt class="py-lineno">4652</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L4653"></a><tt class="py-lineno">4653</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt> <tt class="py-op">&amp;</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt id="link-2074" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2074', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">v</tt><tt class="py-op">)</tt> </tt>
<a name="L4654"></a><tt class="py-lineno">4654</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4655"></a><tt class="py-lineno">4655</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt id="link-2075" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2075', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">v</tt><tt class="py-op">)</tt> </tt>
<a name="L4656"></a><tt class="py-lineno">4656</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4657"></a><tt class="py-lineno">4657</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> \ </tt>
<a name="L4658"></a><tt class="py-lineno">4658</tt>  <tt class="py-line">                <tt class="py-string">'Field %s is not part of the primary key of %s'</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L4659"></a><tt class="py-lineno">4659</tt>  <tt class="py-line">                <tt class="py-op">(</tt><tt id="link-2076" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2076', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4660"></a><tt class="py-lineno">4660</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">query</tt> </tt>
</div><a name="L4661"></a><tt class="py-lineno">4661</tt>  <tt class="py-line"> </tt>
<a name="Table.__getitem__"></a><div id="Table.__getitem__-def"><a name="L4662"></a><tt class="py-lineno">4662</tt> <a class="py-toggle" href="#" id="Table.__getitem__-toggle" onclick="return toggle('Table.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__getitem__-expanded"><a name="L4663"></a><tt class="py-lineno">4663</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">key</tt><tt class="py-op">:</tt> </tt>
<a name="L4664"></a><tt class="py-lineno">4664</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L4665"></a><tt class="py-lineno">4665</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4666"></a><tt class="py-lineno">4666</tt>  <tt class="py-line">            <tt class="py-string">""" for keyed table """</tt> </tt>
<a name="L4667"></a><tt class="py-lineno">4667</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2077" class="py-name" targets="Method web2py.gluon.dal.Table._build_query()=web2py.gluon.dal.Table-class.html#_build_query"><a title="web2py.gluon.dal.Table._build_query" class="py-name" href="#" onclick="return doclink('link-2077', '_build_query', 'link-2077');">_build_query</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L4668"></a><tt class="py-lineno">4668</tt>  <tt class="py-line">            <tt id="link-2078" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2078', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2079" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2079', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4669"></a><tt class="py-lineno">4669</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-2080" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2080', 'rows', 'link-539');">rows</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4670"></a><tt class="py-lineno">4670</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt id="link-2081" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2081', 'rows', 'link-539');">rows</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L4671"></a><tt class="py-lineno">4671</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L4672"></a><tt class="py-lineno">4672</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isdigit</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4673"></a><tt class="py-lineno">4673</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">==</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2082" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2082', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2083" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2083', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4674"></a><tt class="py-lineno">4674</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">key</tt><tt class="py-op">:</tt> </tt>
<a name="L4675"></a><tt class="py-lineno">4675</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-2084" class="py-name"><a title="web2py.gluon.compileapp.mybuiltin.__getitem__
web2py.gluon.dal.DAL.__getitem__
web2py.gluon.dal.Expression.__getitem__
web2py.gluon.dal.Reference.__getitem__
web2py.gluon.dal.Row.__getitem__
web2py.gluon.dal.Rows.__getitem__
web2py.gluon.dal.SQLCustomType.__getitem__
web2py.gluon.dal.Table.__getitem__
web2py.gluon.html.DIV.__getitem__
web2py.gluon.html.XML.__getitem__
web2py.gluon.html.__TAG__.__getitem__
web2py.gluon.languages.lazyT.__getitem__
web2py.gluon.rocket.FileWrapper.__getitem__
web2py.gluon.rocket.Headers.__getitem__" class="py-name" href="#" onclick="return doclink('link-2084', '__getitem__', 'link-1720');">__getitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4676"></a><tt class="py-lineno">4676</tt>  <tt class="py-line"> </tt>
<a name="Table.__call__"></a><div id="Table.__call__-def"><a name="L4677"></a><tt class="py-lineno">4677</tt> <a class="py-toggle" href="#" id="Table.__call__-toggle" onclick="return toggle('Table.__call__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__call__">__call__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">=</tt><tt id="link-2085" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2085', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">kwargs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__call__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__call__-expanded"><a name="L4678"></a><tt class="py-lineno">4678</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt><tt class="py-op">!=</tt><tt id="link-2086" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2086', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4679"></a><tt class="py-lineno">4679</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt id="link-2087" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2087', 'Query', 'link-432');">Query</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4680"></a><tt class="py-lineno">4680</tt>  <tt class="py-line">                <tt class="py-name">record</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2088" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2088', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2089" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2089', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4681"></a><tt class="py-lineno">4681</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isdigit</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4682"></a><tt class="py-lineno">4682</tt>  <tt class="py-line">                <tt class="py-name">record</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4683"></a><tt class="py-lineno">4683</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4684"></a><tt class="py-lineno">4684</tt>  <tt class="py-line">                <tt class="py-name">record</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">==</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2090" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2090', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2091" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2091', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4685"></a><tt class="py-lineno">4685</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">record</tt><tt class="py-op">:</tt> </tt>
<a name="L4686"></a><tt class="py-lineno">4686</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt id="link-2092" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2092', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2093" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2093', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4687"></a><tt class="py-lineno">4687</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">record</tt><tt class="py-op">[</tt><tt id="link-2094" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2094', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">!=</tt><tt class="py-name">v</tt><tt class="py-op">:</tt> <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L4688"></a><tt class="py-lineno">4688</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">record</tt> </tt>
<a name="L4689"></a><tt class="py-lineno">4689</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">kwargs</tt><tt class="py-op">:</tt> </tt>
<a name="L4690"></a><tt class="py-lineno">4690</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">reduce</tt><tt class="py-op">(</tt><tt class="py-keyword">lambda</tt> <tt class="py-name">a</tt><tt class="py-op">,</tt><tt id="link-2095" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-2095', 'b', 'link-188');">b</a></tt><tt class="py-op">:</tt><tt class="py-name">a</tt><tt class="py-op">&amp;</tt><tt id="link-2096" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-2096', 'b', 'link-188');">b</a></tt><tt class="py-op">,</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt id="link-2097" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2097', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-name">v</tt> <tt class="py-keyword">for</tt> <tt id="link-2098" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2098', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2099" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2099', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L4691"></a><tt class="py-lineno">4691</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2100" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2100', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2101" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2101', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4692"></a><tt class="py-lineno">4692</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4693"></a><tt class="py-lineno">4693</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L4694"></a><tt class="py-lineno">4694</tt>  <tt class="py-line"> </tt>
<a name="Table.__setitem__"></a><div id="Table.__setitem__-def"><a name="L4695"></a><tt class="py-lineno">4695</tt> <a class="py-toggle" href="#" id="Table.__setitem__-toggle" onclick="return toggle('Table.__setitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__setitem__">__setitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__setitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__setitem__-expanded"><a name="L4696"></a><tt class="py-lineno">4696</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">dict</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4697"></a><tt class="py-lineno">4697</tt>  <tt class="py-line">            <tt class="py-string">""" option for keyed table """</tt> </tt>
<a name="L4698"></a><tt class="py-lineno">4698</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-2102" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2102', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-name">set</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4699"></a><tt class="py-lineno">4699</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2103" class="py-name" targets="Method web2py.gluon.dal.Table._filter_fields()=web2py.gluon.dal.Table-class.html#_filter_fields"><a title="web2py.gluon.dal.Table._filter_fields" class="py-name" href="#" onclick="return doclink('link-2103', '_filter_fields', 'link-2103');">_filter_fields</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4700"></a><tt class="py-lineno">4700</tt>  <tt class="py-line">                <tt class="py-name">kv</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L4701"></a><tt class="py-lineno">4701</tt>  <tt class="py-line">                <tt class="py-name">kv</tt><tt class="py-op">.</tt><tt id="link-2104" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2104', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4702"></a><tt class="py-lineno">4702</tt>  <tt class="py-line">                <tt class="py-name">kv</tt><tt class="py-op">.</tt><tt id="link-2105" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2105', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L4703"></a><tt class="py-lineno">4703</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2106" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2106', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">kv</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4704"></a><tt class="py-lineno">4704</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2107" class="py-name"><a title="web2py.gluon.dal.Table._build_query" class="py-name" href="#" onclick="return doclink('link-2107', '_build_query', 'link-2077');">_build_query</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L4705"></a><tt class="py-lineno">4705</tt>  <tt class="py-line">                    <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2108" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2108', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2109" class="py-name"><a title="web2py.gluon.dal.Table._filter_fields" class="py-name" href="#" onclick="return doclink('link-2109', '_filter_fields', 'link-2103');">_filter_fields</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4706"></a><tt class="py-lineno">4706</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4707"></a><tt class="py-lineno">4707</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt>\ </tt>
<a name="L4708"></a><tt class="py-lineno">4708</tt>  <tt class="py-line">                    <tt class="py-string">'key must have all fields from primary key: %s'</tt><tt class="py-op">%</tt>\ </tt>
<a name="L4709"></a><tt class="py-lineno">4709</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_primarykey</tt><tt class="py-op">)</tt> </tt>
<a name="L4710"></a><tt class="py-lineno">4710</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isdigit</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4711"></a><tt class="py-lineno">4711</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-op">==</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L4712"></a><tt class="py-lineno">4712</tt>  <tt class="py-line">                <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2110" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2110', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2111" class="py-name"><a title="web2py.gluon.dal.Table._filter_fields" class="py-name" href="#" onclick="return doclink('link-2111', '_filter_fields', 'link-2103');">_filter_fields</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4713"></a><tt class="py-lineno">4713</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">==</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt>\ </tt>
<a name="L4714"></a><tt class="py-lineno">4714</tt>  <tt class="py-line">                    <tt class="py-op">.</tt><tt id="link-2112" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2112', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2113" class="py-name"><a title="web2py.gluon.dal.Table._filter_fields" class="py-name" href="#" onclick="return doclink('link-2113', '_filter_fields', 'link-2103');">_filter_fields</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4715"></a><tt class="py-lineno">4715</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'No such record: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
<a name="L4716"></a><tt class="py-lineno">4716</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4717"></a><tt class="py-lineno">4717</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4718"></a><tt class="py-lineno">4718</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt>\ </tt>
<a name="L4719"></a><tt class="py-lineno">4719</tt>  <tt class="py-line">                    <tt class="py-string">'value must be a dictionary: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">value</tt> </tt>
<a name="L4720"></a><tt class="py-lineno">4720</tt>  <tt class="py-line">            <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-2114" class="py-name"><a title="web2py.gluon.compileapp.mybuiltin.__setitem__
web2py.gluon.dal.DAL.__setitem__
web2py.gluon.dal.Reference.__setitem__
web2py.gluon.dal.Row.__setitem__
web2py.gluon.dal.Table.__setitem__
web2py.gluon.html.DIV.__setitem__
web2py.gluon.rocket.Headers.__setitem__" class="py-name" href="#" onclick="return doclink('link-2114', '__setitem__', 'link-1722');">__setitem__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4721"></a><tt class="py-lineno">4721</tt>  <tt class="py-line"> </tt>
<a name="Table.__delitem__"></a><div id="Table.__delitem__-def"><a name="L4722"></a><tt class="py-lineno">4722</tt> <a class="py-toggle" href="#" id="Table.__delitem__-toggle" onclick="return toggle('Table.__delitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__delitem__">__delitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__delitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__delitem__-expanded"><a name="L4723"></a><tt class="py-lineno">4723</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt> <tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4724"></a><tt class="py-lineno">4724</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2115" class="py-name"><a title="web2py.gluon.dal.Table._build_query" class="py-name" href="#" onclick="return doclink('link-2115', '_build_query', 'link-2077');">_build_query</a></tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L4725"></a><tt class="py-lineno">4725</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2116" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-2116', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4726"></a><tt class="py-lineno">4726</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'No such record: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
<a name="L4727"></a><tt class="py-lineno">4727</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">isdigit</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt> <tt class="py-op">==</tt> <tt class="py-name">key</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2117" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-2117', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4728"></a><tt class="py-lineno">4728</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'No such record: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
</div><a name="L4729"></a><tt class="py-lineno">4729</tt>  <tt class="py-line"> </tt>
<a name="Table.__getattr__"></a><div id="Table.__getattr__-def"><a name="L4730"></a><tt class="py-lineno">4730</tt> <a class="py-toggle" href="#" id="Table.__getattr__-toggle" onclick="return toggle('Table.__getattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__getattr__">__getattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__getattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__getattr__-expanded"><a name="L4731"></a><tt class="py-lineno">4731</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> </tt>
</div><a name="L4732"></a><tt class="py-lineno">4732</tt>  <tt class="py-line"> </tt>
<a name="Table.__setattr__"></a><div id="Table.__setattr__-def"><a name="L4733"></a><tt class="py-lineno">4733</tt> <a class="py-toggle" href="#" id="Table.__setattr__-toggle" onclick="return toggle('Table.__setattr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__setattr__">__setattr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__setattr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__setattr__-expanded"><a name="L4734"></a><tt class="py-lineno">4734</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">:</tt> </tt>
<a name="L4735"></a><tt class="py-lineno">4735</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Object exists and cannot be redefined: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">key</tt> </tt>
<a name="L4736"></a><tt class="py-lineno">4736</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">value</tt> </tt>
</div><a name="L4737"></a><tt class="py-lineno">4737</tt>  <tt class="py-line"> </tt>
<a name="Table.__iter__"></a><div id="Table.__iter__-def"><a name="L4738"></a><tt class="py-lineno">4738</tt> <a class="py-toggle" href="#" id="Table.__iter__-toggle" onclick="return toggle('Table.__iter__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__iter__">__iter__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__iter__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__iter__-expanded"><a name="L4739"></a><tt class="py-lineno">4739</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">fieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4740"></a><tt class="py-lineno">4740</tt>  <tt class="py-line">            <tt class="py-keyword">yield</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> </tt>
</div><a name="L4741"></a><tt class="py-lineno">4741</tt>  <tt class="py-line"> </tt>
<a name="Table.__repr__"></a><div id="Table.__repr__-def"><a name="L4742"></a><tt class="py-lineno">4742</tt> <a class="py-toggle" href="#" id="Table.__repr__-toggle" onclick="return toggle('Table.__repr__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__repr__">__repr__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__repr__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__repr__-expanded"><a name="L4743"></a><tt class="py-lineno">4743</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-string">'&lt;Table '</tt> <tt class="py-op">+</tt> <tt class="py-name">dict</tt><tt class="py-op">.</tt><tt id="link-2118" class="py-name"><a title="web2py.gluon.dal.DAL.__repr__
web2py.gluon.dal.GAEF.__repr__
web2py.gluon.dal.Row.__repr__
web2py.gluon.dal.Table.__repr__
web2py.gluon.languages.lazyT.__repr__
web2py.gluon.rocket.Headers.__repr__
web2py.gluon.storage.Storage.__repr__
web2py.gluon.template.BlockNode.__repr__
web2py.gluon.template.SuperNode.__repr__" class="py-name" href="#" onclick="return doclink('link-2118', '__repr__', 'link-1723');">__repr__</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> <tt class="py-op">+</tt> <tt class="py-string">'&gt;'</tt> </tt>
</div><a name="L4744"></a><tt class="py-lineno">4744</tt>  <tt class="py-line"> </tt>
<a name="Table.__str__"></a><div id="Table.__str__-def"><a name="L4745"></a><tt class="py-lineno">4745</tt> <a class="py-toggle" href="#" id="Table.__str__-toggle" onclick="return toggle('Table.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.__str__-expanded"><a name="L4746"></a><tt class="py-lineno">4746</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2119" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2119', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'_ot'</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4747"></a><tt class="py-lineno">4747</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'%s AS %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_ot</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">)</tt> </tt>
<a name="L4748"></a><tt class="py-lineno">4748</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
</div><a name="L4749"></a><tt class="py-lineno">4749</tt>  <tt class="py-line"> </tt>
<a name="Table._drop"></a><div id="Table._drop-def"><a name="L4750"></a><tt class="py-lineno">4750</tt> <a class="py-toggle" href="#" id="Table._drop-toggle" onclick="return toggle('Table._drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_drop">_drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._drop-expanded"><a name="L4751"></a><tt class="py-lineno">4751</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2120" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._drop
web2py.gluon.dal.FireBirdAdapter._drop
web2py.gluon.dal.MySQLAdapter._drop
web2py.gluon.dal.OracleAdapter._drop
web2py.gluon.dal.Table._drop" class="py-name" href="#" onclick="return doclink('link-2120', '_drop', 'link-309');">_drop</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4752"></a><tt class="py-lineno">4752</tt>  <tt class="py-line"> </tt>
<a name="Table.drop"></a><div id="Table.drop-def"><a name="L4753"></a><tt class="py-lineno">4753</tt> <a class="py-toggle" href="#" id="Table.drop-toggle" onclick="return toggle('Table.drop');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#drop">drop</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.drop-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.drop-expanded"><a name="L4754"></a><tt class="py-lineno">4754</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2121" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.drop()=web2py.gluon.dal.BaseAdapter-class.html#drop,Method web2py.gluon.dal.NoSQLAdapter.drop()=web2py.gluon.dal.NoSQLAdapter-class.html#drop,Method web2py.gluon.dal.Table.drop()=web2py.gluon.dal.Table-class.html#drop"><a title="web2py.gluon.dal.BaseAdapter.drop
web2py.gluon.dal.NoSQLAdapter.drop
web2py.gluon.dal.Table.drop" class="py-name" href="#" onclick="return doclink('link-2121', 'drop', 'link-2121');">drop</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4755"></a><tt class="py-lineno">4755</tt>  <tt class="py-line"> </tt>
<a name="Table._listify"></a><div id="Table._listify-def"><a name="L4756"></a><tt class="py-lineno">4756</tt> <a class="py-toggle" href="#" id="Table._listify-toggle" onclick="return toggle('Table._listify');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_listify">_listify</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt><tt class="py-param">update</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._listify-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._listify-expanded"><a name="L4757"></a><tt class="py-lineno">4757</tt>  <tt class="py-line">        <tt class="py-name">new_fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4758"></a><tt class="py-lineno">4758</tt>  <tt class="py-line">        <tt class="py-name">new_fields_names</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4759"></a><tt class="py-lineno">4759</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt id="link-2122" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2122', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4760"></a><tt class="py-lineno">4760</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2123" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2123', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L4761"></a><tt class="py-lineno">4761</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt id="link-2124" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2124', 'name', 'link-119');">name</a></tt> <tt class="py-op">!=</tt> <tt class="py-string">'id'</tt><tt class="py-op">:</tt> </tt>
<a name="L4762"></a><tt class="py-lineno">4762</tt>  <tt class="py-line">                    <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Field %s does not belong to the table'</tt> <tt class="py-op">%</tt> <tt id="link-2125" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2125', 'name', 'link-119');">name</a></tt> </tt>
<a name="L4763"></a><tt class="py-lineno">4763</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4764"></a><tt class="py-lineno">4764</tt>  <tt class="py-line">                <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-2126" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2126', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt id="link-2127" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2127', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">[</tt><tt id="link-2128" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2128', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4765"></a><tt class="py-lineno">4765</tt>  <tt class="py-line">                <tt class="py-name">new_fields_names</tt><tt class="py-op">.</tt><tt id="link-2129" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2129', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt id="link-2130" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2130', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4766"></a><tt class="py-lineno">4766</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">ofield</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">:</tt> </tt>
<a name="L4767"></a><tt class="py-lineno">4767</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt id="link-2131" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2131', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">new_fields_names</tt><tt class="py-op">:</tt> </tt>
<a name="L4768"></a><tt class="py-lineno">4768</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2132" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2132', 'update', 'link-507');">update</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt class="py-name">default</tt><tt class="py-op">!=</tt><tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L4769"></a><tt class="py-lineno">4769</tt>  <tt class="py-line">                    <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-2133" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2133', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">ofield</tt><tt class="py-op">,</tt><tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt class="py-name">default</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4770"></a><tt class="py-lineno">4770</tt>  <tt class="py-line">                <tt class="py-keyword">elif</tt> <tt id="link-2134" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2134', 'update', 'link-507');">update</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt id="link-2135" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2135', 'update', 'link-507');">update</a></tt><tt class="py-op">!=</tt><tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L4771"></a><tt class="py-lineno">4771</tt>  <tt class="py-line">                    <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-2136" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2136', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">ofield</tt><tt class="py-op">,</tt><tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt id="link-2137" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2137', 'update', 'link-507');">update</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4772"></a><tt class="py-lineno">4772</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">ofield</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">:</tt> </tt>
<a name="L4773"></a><tt class="py-lineno">4773</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt id="link-2138" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2138', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">new_fields_names</tt> <tt class="py-keyword">and</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt class="py-name">compute</tt><tt class="py-op">:</tt> </tt>
<a name="L4774"></a><tt class="py-lineno">4774</tt>  <tt class="py-line">                <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4775"></a><tt class="py-lineno">4775</tt>  <tt class="py-line">                    <tt class="py-name">new_fields</tt><tt class="py-op">.</tt><tt id="link-2139" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2139', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">ofield</tt><tt class="py-op">,</tt><tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt class="py-name">compute</tt><tt class="py-op">(</tt><tt id="link-2140" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2140', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4776"></a><tt class="py-lineno">4776</tt>  <tt class="py-line">                <tt class="py-keyword">except</tt> <tt class="py-name">KeyError</tt><tt class="py-op">:</tt> </tt>
<a name="L4777"></a><tt class="py-lineno">4777</tt>  <tt class="py-line">                    <tt class="py-keyword">pass</tt> </tt>
<a name="L4778"></a><tt class="py-lineno">4778</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2141" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2141', 'update', 'link-507');">update</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt class="py-name">required</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt id="link-2142" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2142', 'name', 'link-119');">name</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">new_fields_names</tt><tt class="py-op">:</tt> </tt>
<a name="L4779"></a><tt class="py-lineno">4779</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt><tt class="py-string">'Table: missing required field: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">ofield</tt><tt class="py-op">.</tt><tt id="link-2143" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2143', 'name', 'link-119');">name</a></tt> </tt>
<a name="L4780"></a><tt class="py-lineno">4780</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">new_fields</tt> </tt>
</div><a name="L4781"></a><tt class="py-lineno">4781</tt>  <tt class="py-line"> </tt>
<a name="Table._insert"></a><div id="Table._insert-def"><a name="L4782"></a><tt class="py-lineno">4782</tt> <a class="py-toggle" href="#" id="Table._insert-toggle" onclick="return toggle('Table._insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_insert">_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._insert-expanded"><a name="L4783"></a><tt class="py-lineno">4783</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2144" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._insert
web2py.gluon.dal.NoSQLAdapter._insert
web2py.gluon.dal.Table._insert
web2py.gluon.template.Content._insert" class="py-name" href="#" onclick="return doclink('link-2144', '_insert', 'link-326');">_insert</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2145" class="py-name" targets="Method web2py.gluon.dal.Table._listify()=web2py.gluon.dal.Table-class.html#_listify"><a title="web2py.gluon.dal.Table._listify" class="py-name" href="#" onclick="return doclink('link-2145', '_listify', 'link-2145');">_listify</a></tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4784"></a><tt class="py-lineno">4784</tt>  <tt class="py-line"> </tt>
<a name="Table.insert"></a><div id="Table.insert-def"><a name="L4785"></a><tt class="py-lineno">4785</tt> <a class="py-toggle" href="#" id="Table.insert-toggle" onclick="return toggle('Table.insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#insert">insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.insert-expanded"><a name="L4786"></a><tt class="py-lineno">4786</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2146" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2146', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2147" class="py-name"><a title="web2py.gluon.dal.Table._listify" class="py-name" href="#" onclick="return doclink('link-2147', '_listify', 'link-2145');">_listify</a></tt><tt class="py-op">(</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4787"></a><tt class="py-lineno">4787</tt>  <tt class="py-line"> </tt>
<a name="Table.validate_and_insert"></a><div id="Table.validate_and_insert-def"><a name="L4788"></a><tt class="py-lineno">4788</tt> <a class="py-toggle" href="#" id="Table.validate_and_insert-toggle" onclick="return toggle('Table.validate_and_insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#validate_and_insert">validate_and_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.validate_and_insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.validate_and_insert-expanded"><a name="L4789"></a><tt class="py-lineno">4789</tt>  <tt class="py-line">        <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt id="link-2148" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2148', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4790"></a><tt class="py-lineno">4790</tt>  <tt class="py-line">        <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">errors</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2149" class="py-name" targets="Method web2py.gluon.dal.Table._validate()=web2py.gluon.dal.Table-class.html#_validate,Method web2py.gluon.html.DIV._validate()=web2py.gluon.html.DIV-class.html#_validate,Method web2py.gluon.html.INPUT._validate()=web2py.gluon.html.INPUT-class.html#_validate,Method web2py.gluon.tools.Recaptcha._validate()=web2py.gluon.tools.Recaptcha-class.html#_validate"><a title="web2py.gluon.dal.Table._validate
web2py.gluon.html.DIV._validate
web2py.gluon.html.INPUT._validate
web2py.gluon.tools.Recaptcha._validate" class="py-name" href="#" onclick="return doclink('link-2149', '_validate', 'link-2149');">_validate</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L4791"></a><tt class="py-lineno">4791</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">errors</tt><tt class="py-op">:</tt> </tt>
<a name="L4792"></a><tt class="py-lineno">4792</tt>  <tt class="py-line">            <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2150" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2150', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L4793"></a><tt class="py-lineno">4793</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4794"></a><tt class="py-lineno">4794</tt>  <tt class="py-line">            <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">id</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4795"></a><tt class="py-lineno">4795</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">response</tt> </tt>
</div><a name="L4796"></a><tt class="py-lineno">4796</tt>  <tt class="py-line"> </tt>
<a name="Table.update_or_insert"></a><div id="Table.update_or_insert-def"><a name="L4797"></a><tt class="py-lineno">4797</tt> <a class="py-toggle" href="#" id="Table.update_or_insert-toggle" onclick="return toggle('Table.update_or_insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#update_or_insert">update_or_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">key</tt><tt class="py-op">=</tt><tt id="link-2151" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2151', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">values</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.update_or_insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.update_or_insert-expanded"><a name="L4798"></a><tt class="py-lineno">4798</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">key</tt><tt class="py-op">==</tt><tt id="link-2152" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2152', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">:</tt> </tt>
<a name="L4799"></a><tt class="py-lineno">4799</tt>  <tt class="py-line">            <tt class="py-name">record</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt id="link-2153" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-2153', 'values', 'link-321');">values</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4800"></a><tt class="py-lineno">4800</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4801"></a><tt class="py-lineno">4801</tt>  <tt class="py-line">            <tt class="py-name">record</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">)</tt> </tt>
<a name="L4802"></a><tt class="py-lineno">4802</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">record</tt><tt class="py-op">:</tt> </tt>
<a name="L4803"></a><tt class="py-lineno">4803</tt>  <tt class="py-line">            <tt class="py-name">record</tt><tt class="py-op">.</tt><tt id="link-2154" class="py-name"><a title="web2py.gluon.dal.update_record" class="py-name" href="#" onclick="return doclink('link-2154', 'update_record', 'link-672');">update_record</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt id="link-2155" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-2155', 'values', 'link-321');">values</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4804"></a><tt class="py-lineno">4804</tt>  <tt class="py-line">            <tt class="py-name">newid</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4805"></a><tt class="py-lineno">4805</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4806"></a><tt class="py-lineno">4806</tt>  <tt class="py-line">            <tt class="py-name">newid</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2156" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2156', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt id="link-2157" class="py-name"><a title="web2py.gluon.rocket.Headers.values" class="py-name" href="#" onclick="return doclink('link-2157', 'values', 'link-321');">values</a></tt><tt class="py-op">)</tt> </tt>
<a name="L4807"></a><tt class="py-lineno">4807</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">newid</tt> </tt>
</div><a name="L4808"></a><tt class="py-lineno">4808</tt>  <tt class="py-line"> </tt>
<a name="Table.bulk_insert"></a><div id="Table.bulk_insert-def"><a name="L4809"></a><tt class="py-lineno">4809</tt> <a class="py-toggle" href="#" id="Table.bulk_insert-toggle" onclick="return toggle('Table.bulk_insert');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#bulk_insert">bulk_insert</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">items</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.bulk_insert-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.bulk_insert-expanded"><a name="L4810"></a><tt class="py-lineno">4810</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L4811"></a><tt class="py-lineno">4811</tt>  <tt class="py-line"><tt class="py-docstring">        here items is a list of dictionaries</tt> </tt>
<a name="L4812"></a><tt class="py-lineno">4812</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L4813"></a><tt class="py-lineno">4813</tt>  <tt class="py-line">        <tt id="link-2158" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2158', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2159" class="py-name"><a title="web2py.gluon.dal.Table._listify" class="py-name" href="#" onclick="return doclink('link-2159', '_listify', 'link-2145');">_listify</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-2160" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2160', 'items', 'link-266');">items</a></tt><tt class="py-op">]</tt> </tt>
<a name="L4814"></a><tt class="py-lineno">4814</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2161" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.bulk_insert()=web2py.gluon.dal.BaseAdapter-class.html#bulk_insert,Method web2py.gluon.dal.GoogleDatastoreAdapter.bulk_insert()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#bulk_insert,Method web2py.gluon.dal.Table.bulk_insert()=web2py.gluon.dal.Table-class.html#bulk_insert"><a title="web2py.gluon.dal.BaseAdapter.bulk_insert
web2py.gluon.dal.GoogleDatastoreAdapter.bulk_insert
web2py.gluon.dal.Table.bulk_insert" class="py-name" href="#" onclick="return doclink('link-2161', 'bulk_insert', 'link-2161');">bulk_insert</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt id="link-2162" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2162', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L4815"></a><tt class="py-lineno">4815</tt>  <tt class="py-line"> </tt>
<a name="Table._truncate"></a><div id="Table._truncate-def"><a name="L4816"></a><tt class="py-lineno">4816</tt> <a class="py-toggle" href="#" id="Table._truncate-toggle" onclick="return toggle('Table._truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#_truncate">_truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table._truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table._truncate-expanded"><a name="L4817"></a><tt class="py-lineno">4817</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2163" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._truncate
web2py.gluon.dal.FireBirdAdapter._truncate
web2py.gluon.dal.SQLiteAdapter._truncate
web2py.gluon.dal.Table._truncate" class="py-name" href="#" onclick="return doclink('link-2163', '_truncate', 'link-445');">_truncate</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4818"></a><tt class="py-lineno">4818</tt>  <tt class="py-line"> </tt>
<a name="Table.truncate"></a><div id="Table.truncate-def"><a name="L4819"></a><tt class="py-lineno">4819</tt> <a class="py-toggle" href="#" id="Table.truncate-toggle" onclick="return toggle('Table.truncate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#truncate">truncate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.truncate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.truncate-expanded"><a name="L4820"></a><tt class="py-lineno">4820</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2164" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.truncate()=web2py.gluon.dal.BaseAdapter-class.html#truncate,Method web2py.gluon.dal.GoogleDatastoreAdapter.truncate()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#truncate,Method web2py.gluon.dal.Table.truncate()=web2py.gluon.dal.Table-class.html#truncate"><a title="web2py.gluon.dal.BaseAdapter.truncate
web2py.gluon.dal.GoogleDatastoreAdapter.truncate
web2py.gluon.dal.Table.truncate" class="py-name" href="#" onclick="return doclink('link-2164', 'truncate', 'link-2164');">truncate</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">mode</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4821"></a><tt class="py-lineno">4821</tt>  <tt class="py-line"> </tt>
<a name="Table.import_from_csv_file"></a><div id="Table.import_from_csv_file-def"><a name="L4822"></a><tt class="py-lineno">4822</tt> <a class="py-toggle" href="#" id="Table.import_from_csv_file-toggle" onclick="return toggle('Table.import_from_csv_file');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#import_from_csv_file">import_from_csv_file</a><tt class="py-op">(</tt> </tt>
<a name="L4823"></a><tt class="py-lineno">4823</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L4824"></a><tt class="py-lineno">4824</tt>  <tt class="py-line">        <tt class="py-param">csvfile</tt><tt class="py-op">,</tt> </tt>
<a name="L4825"></a><tt class="py-lineno">4825</tt>  <tt class="py-line">        <tt class="py-param">id_map</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L4826"></a><tt class="py-lineno">4826</tt>  <tt class="py-line">        <tt class="py-param">null</tt><tt class="py-op">=</tt><tt class="py-string">'&lt;NULL&gt;'</tt><tt class="py-op">,</tt> </tt>
<a name="L4827"></a><tt class="py-lineno">4827</tt>  <tt class="py-line">        <tt class="py-param">unique</tt><tt class="py-op">=</tt><tt class="py-string">'uuid'</tt><tt class="py-op">,</tt> </tt>
<a name="L4828"></a><tt class="py-lineno">4828</tt>  <tt class="py-line">        <tt class="py-op">*</tt><tt class="py-param">args</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">kwargs</tt> </tt>
<a name="L4829"></a><tt class="py-lineno">4829</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.import_from_csv_file-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.import_from_csv_file-expanded"><a name="L4830"></a><tt class="py-lineno">4830</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L4831"></a><tt class="py-lineno">4831</tt>  <tt class="py-line"><tt class="py-docstring">        import records from csv file. Column headers must have same names as</tt> </tt>
<a name="L4832"></a><tt class="py-lineno">4832</tt>  <tt class="py-line"><tt class="py-docstring">        table fields. field 'id' is ignored. If column names read 'table.file'</tt> </tt>
<a name="L4833"></a><tt class="py-lineno">4833</tt>  <tt class="py-line"><tt class="py-docstring">        the 'table.' prefix is ignored.</tt> </tt>
<a name="L4834"></a><tt class="py-lineno">4834</tt>  <tt class="py-line"><tt class="py-docstring">        'unique' argument is a field which must be unique</tt> </tt>
<a name="L4835"></a><tt class="py-lineno">4835</tt>  <tt class="py-line"><tt class="py-docstring">        (typically a uuid field)</tt> </tt>
<a name="L4836"></a><tt class="py-lineno">4836</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L4837"></a><tt class="py-lineno">4837</tt>  <tt class="py-line"> </tt>
<a name="L4838"></a><tt class="py-lineno">4838</tt>  <tt class="py-line">        <tt class="py-name">delimiter</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2165" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2165', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'delimiter'</tt><tt class="py-op">,</tt> <tt class="py-string">','</tt><tt class="py-op">)</tt> </tt>
<a name="L4839"></a><tt class="py-lineno">4839</tt>  <tt class="py-line">        <tt class="py-name">quotechar</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2166" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2166', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'quotechar'</tt><tt class="py-op">,</tt> <tt class="py-string">'"'</tt><tt class="py-op">)</tt> </tt>
<a name="L4840"></a><tt class="py-lineno">4840</tt>  <tt class="py-line">        <tt class="py-name">quoting</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2167" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2167', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'quoting'</tt><tt class="py-op">,</tt> <tt id="link-2168" class="py-name"><a title="web2py.gluon.serializers.csv
web2py.gluon.tools.Service.csv" class="py-name" href="#" onclick="return doclink('link-2168', 'csv', 'link-5');">csv</a></tt><tt class="py-op">.</tt><tt class="py-name">QUOTE_MINIMAL</tt><tt class="py-op">)</tt> </tt>
<a name="L4841"></a><tt class="py-lineno">4841</tt>  <tt class="py-line"> </tt>
<a name="L4842"></a><tt class="py-lineno">4842</tt>  <tt class="py-line">        <tt class="py-name">reader</tt> <tt class="py-op">=</tt> <tt id="link-2169" class="py-name"><a title="web2py.gluon.serializers.csv
web2py.gluon.tools.Service.csv" class="py-name" href="#" onclick="return doclink('link-2169', 'csv', 'link-5');">csv</a></tt><tt class="py-op">.</tt><tt class="py-name">reader</tt><tt class="py-op">(</tt><tt class="py-name">csvfile</tt><tt class="py-op">,</tt> <tt class="py-name">delimiter</tt><tt class="py-op">=</tt><tt class="py-name">delimiter</tt><tt class="py-op">,</tt> <tt class="py-name">quotechar</tt><tt class="py-op">=</tt><tt class="py-name">quotechar</tt><tt class="py-op">,</tt> <tt class="py-name">quoting</tt><tt class="py-op">=</tt><tt class="py-name">quoting</tt><tt class="py-op">)</tt> </tt>
<a name="L4843"></a><tt class="py-lineno">4843</tt>  <tt class="py-line">        <tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4844"></a><tt class="py-lineno">4844</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">id_map</tt><tt class="py-op">,</tt> <tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4845"></a><tt class="py-lineno">4845</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">id_map</tt><tt class="py-op">:</tt> </tt>
<a name="L4846"></a><tt class="py-lineno">4846</tt>  <tt class="py-line">                <tt class="py-name">id_map</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt>
<a name="L4847"></a><tt class="py-lineno">4847</tt>  <tt class="py-line">            <tt class="py-name">id_map_self</tt> <tt class="py-op">=</tt> <tt class="py-name">id_map</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L4848"></a><tt class="py-lineno">4848</tt>  <tt class="py-line"> </tt>
<a name="L4849"></a><tt class="py-lineno">4849</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">fix</tt><tt class="py-op">(</tt><tt class="py-param">field</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">,</tt> <tt class="py-param">id_map</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4850"></a><tt class="py-lineno">4850</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">value</tt> <tt class="py-op">==</tt> <tt class="py-name">null</tt><tt class="py-op">:</tt> </tt>
<a name="L4851"></a><tt class="py-lineno">4851</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4852"></a><tt class="py-lineno">4852</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'blob'</tt><tt class="py-op">:</tt> </tt>
<a name="L4853"></a><tt class="py-lineno">4853</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b64decode</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4854"></a><tt class="py-lineno">4854</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'double'</tt><tt class="py-op">:</tt> </tt>
<a name="L4855"></a><tt class="py-lineno">4855</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt id="link-2170" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-2170', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4856"></a><tt class="py-lineno">4856</tt>  <tt class="py-line">                    <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4857"></a><tt class="py-lineno">4857</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4858"></a><tt class="py-lineno">4858</tt>  <tt class="py-line">                    <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">float</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4859"></a><tt class="py-lineno">4859</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'integer'</tt><tt class="py-op">:</tt> </tt>
<a name="L4860"></a><tt class="py-lineno">4860</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt id="link-2171" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-2171', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4861"></a><tt class="py-lineno">4861</tt>  <tt class="py-line">                    <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L4862"></a><tt class="py-lineno">4862</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4863"></a><tt class="py-lineno">4863</tt>  <tt class="py-line">                    <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4864"></a><tt class="py-lineno">4864</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-2172" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2172', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:string'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4865"></a><tt class="py-lineno">4865</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt id="link-2173" class="py-name"><a title="web2py.gluon.dal.bar_decode_string" class="py-name" href="#" onclick="return doclink('link-2173', 'bar_decode_string', 'link-670');">bar_decode_string</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4866"></a><tt class="py-lineno">4866</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-2174" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2174', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4867"></a><tt class="py-lineno">4867</tt>  <tt class="py-line">                <tt class="py-name">ref_table</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">10</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2175" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-2175', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4868"></a><tt class="py-lineno">4868</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">id_map</tt><tt class="py-op">[</tt><tt class="py-name">ref_table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">v</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> \ </tt>
<a name="L4869"></a><tt class="py-lineno">4869</tt>  <tt class="py-line">                             <tt class="py-keyword">for</tt> <tt class="py-name">v</tt> <tt class="py-keyword">in</tt> <tt id="link-2176" class="py-name"><a title="web2py.gluon.dal.bar_decode_string" class="py-name" href="#" onclick="return doclink('link-2176', 'bar_decode_string', 'link-670');">bar_decode_string</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L4870"></a><tt class="py-lineno">4870</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-2177" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2177', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4871"></a><tt class="py-lineno">4871</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt id="link-2178" class="py-name"><a title="web2py.gluon.dal.bar_decode_integer" class="py-name" href="#" onclick="return doclink('link-2178', 'bar_decode_integer', 'link-666');">bar_decode_integer</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L4872"></a><tt class="py-lineno">4872</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">id_map</tt> <tt class="py-keyword">and</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-2179" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2179', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'reference'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4873"></a><tt class="py-lineno">4873</tt>  <tt class="py-line">                <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L4874"></a><tt class="py-lineno">4874</tt>  <tt class="py-line">                    <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">id_map</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">[</tt><tt class="py-number">9</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2180" class="py-name"><a title="web2py.gluon.sanitizer.XssCleaner.strip" class="py-name" href="#" onclick="return doclink('link-2180', 'strip', 'link-193');">strip</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">value</tt><tt class="py-op">]</tt> </tt>
<a name="L4875"></a><tt class="py-lineno">4875</tt>  <tt class="py-line">                <tt class="py-keyword">except</tt> <tt class="py-name">KeyError</tt><tt class="py-op">:</tt> </tt>
<a name="L4876"></a><tt class="py-lineno">4876</tt>  <tt class="py-line">                    <tt class="py-keyword">pass</tt> </tt>
<a name="L4877"></a><tt class="py-lineno">4877</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2181" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2181', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4878"></a><tt class="py-lineno">4878</tt>  <tt class="py-line"> </tt>
<a name="L4879"></a><tt class="py-lineno">4879</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">is_id</tt><tt class="py-op">(</tt><tt class="py-param">colname</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4880"></a><tt class="py-lineno">4880</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">colname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">:</tt> </tt>
<a name="L4881"></a><tt class="py-lineno">4881</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">colname</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">==</tt> <tt class="py-string">'id'</tt> </tt>
<a name="L4882"></a><tt class="py-lineno">4882</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4883"></a><tt class="py-lineno">4883</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt>
</div><a name="L4884"></a><tt class="py-lineno">4884</tt>  <tt class="py-line"> </tt>
<a name="L4885"></a><tt class="py-lineno">4885</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">line</tt> <tt class="py-keyword">in</tt> <tt class="py-name">reader</tt><tt class="py-op">:</tt> </tt>
<a name="L4886"></a><tt class="py-lineno">4886</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">line</tt><tt class="py-op">:</tt> </tt>
<a name="L4887"></a><tt class="py-lineno">4887</tt>  <tt class="py-line">                <tt class="py-keyword">break</tt> </tt>
<a name="L4888"></a><tt class="py-lineno">4888</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">colnames</tt><tt class="py-op">:</tt> </tt>
<a name="L4889"></a><tt class="py-lineno">4889</tt>  <tt class="py-line">                <tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt id="link-2182" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2182', 'x', 'link-114');">x</a></tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt id="link-2183" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2183', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">line</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt id="link-2184" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2184', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt><tt class="py-op">]</tt> </tt>
<a name="L4890"></a><tt class="py-lineno">4890</tt>  <tt class="py-line">                <tt class="py-name">cols</tt><tt class="py-op">,</tt> <tt class="py-name">cid</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L4891"></a><tt class="py-lineno">4891</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt><tt class="py-name">colname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">enumerate</tt><tt class="py-op">(</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4892"></a><tt class="py-lineno">4892</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">is_id</tt><tt class="py-op">(</tt><tt class="py-name">colname</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4893"></a><tt class="py-lineno">4893</tt>  <tt class="py-line">                        <tt class="py-name">cid</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> </tt>
<a name="L4894"></a><tt class="py-lineno">4894</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4895"></a><tt class="py-lineno">4895</tt>  <tt class="py-line">                        <tt class="py-name">cols</tt><tt class="py-op">.</tt><tt id="link-2185" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2185', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">)</tt> </tt>
<a name="L4896"></a><tt class="py-lineno">4896</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">colname</tt> <tt class="py-op">==</tt> <tt class="py-name">unique</tt><tt class="py-op">:</tt> </tt>
<a name="L4897"></a><tt class="py-lineno">4897</tt>  <tt class="py-line">                        <tt class="py-name">unique_idx</tt> <tt class="py-op">=</tt> <tt class="py-name">i</tt> </tt>
<a name="L4898"></a><tt class="py-lineno">4898</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4899"></a><tt class="py-lineno">4899</tt>  <tt class="py-line">                <tt id="link-2186" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2186', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">fix</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">colnames</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">id_map</tt><tt class="py-op">)</tt> \ </tt>
<a name="L4900"></a><tt class="py-lineno">4900</tt>  <tt class="py-line">                             <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">cols</tt> <tt class="py-keyword">if</tt> <tt class="py-name">colnames</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt><tt class="py-op">]</tt> </tt>
<a name="L4901"></a><tt class="py-lineno">4901</tt>  <tt class="py-line">                <tt class="py-comment"># Validation. Check for duplicate of 'unique' &amp;,</tt> </tt>
<a name="L4902"></a><tt class="py-lineno">4902</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-comment"># if present, update instead of insert.</tt> </tt>
<a name="L4903"></a><tt class="py-lineno">4903</tt>  <tt class="py-line"><tt class="py-comment"></tt>                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">unique</tt> <tt class="py-keyword">or</tt> <tt class="py-name">unique</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">colnames</tt><tt class="py-op">:</tt> </tt>
<a name="L4904"></a><tt class="py-lineno">4904</tt>  <tt class="py-line">                    <tt class="py-name">new_id</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2187" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2187', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt id="link-2188" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2188', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4905"></a><tt class="py-lineno">4905</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4906"></a><tt class="py-lineno">4906</tt>  <tt class="py-line">                    <tt class="py-name">unique_value</tt> <tt class="py-op">=</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">unique_idx</tt><tt class="py-op">]</tt> </tt>
<a name="L4907"></a><tt class="py-lineno">4907</tt>  <tt class="py-line">                    <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">unique</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">unique_value</tt> </tt>
<a name="L4908"></a><tt class="py-lineno">4908</tt>  <tt class="py-line">                    <tt class="py-name">record</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2189" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2189', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2190" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2190', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4909"></a><tt class="py-lineno">4909</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">record</tt><tt class="py-op">:</tt> </tt>
<a name="L4910"></a><tt class="py-lineno">4910</tt>  <tt class="py-line">                        <tt class="py-name">record</tt><tt class="py-op">.</tt><tt id="link-2191" class="py-name"><a title="web2py.gluon.dal.update_record" class="py-name" href="#" onclick="return doclink('link-2191', 'update_record', 'link-672');">update_record</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt id="link-2192" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2192', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4911"></a><tt class="py-lineno">4911</tt>  <tt class="py-line">                        <tt class="py-name">new_id</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">.</tt><tt id="link-2193" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2193', 'name', 'link-119');">name</a></tt><tt class="py-op">]</tt> </tt>
<a name="L4912"></a><tt class="py-lineno">4912</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4913"></a><tt class="py-lineno">4913</tt>  <tt class="py-line">                        <tt class="py-name">new_id</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2194" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2194', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt id="link-2195" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2195', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L4914"></a><tt class="py-lineno">4914</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">id_map</tt> <tt class="py-keyword">and</tt> <tt class="py-name">cid</tt> <tt class="py-op">!=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L4915"></a><tt class="py-lineno">4915</tt>  <tt class="py-line">                    <tt class="py-name">id_map_self</tt><tt class="py-op">[</tt><tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">cid</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">new_id</tt> </tt>
</div><a name="L4916"></a><tt class="py-lineno">4916</tt>  <tt class="py-line"> </tt>
<a name="Table.with_alias"></a><div id="Table.with_alias-def"><a name="L4917"></a><tt class="py-lineno">4917</tt> <a class="py-toggle" href="#" id="Table.with_alias-toggle" onclick="return toggle('Table.with_alias');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#with_alias">with_alias</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">alias</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.with_alias-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.with_alias-expanded"><a name="L4918"></a><tt class="py-lineno">4918</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2196" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-2196', 'alias', 'link-440');">alias</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt id="link-2197" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-2197', 'alias', 'link-440');">alias</a></tt><tt class="py-op">)</tt> </tt>
</div><a name="L4919"></a><tt class="py-lineno">4919</tt>  <tt class="py-line"> </tt>
<a name="Table.on"></a><div id="Table.on-def"><a name="L4920"></a><tt class="py-lineno">4920</tt> <a class="py-toggle" href="#" id="Table.on-toggle" onclick="return toggle('Table.on');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Table-class.html#on">on</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Table.on-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Table.on-expanded"><a name="L4921"></a><tt class="py-lineno">4921</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2198" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2198', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2199" class="py-name" targets="Variable web2py.gluon.ON=web2py.gluon-module.html#ON,Method web2py.gluon.dal.BaseAdapter.ON()=web2py.gluon.dal.BaseAdapter-class.html#ON,Method web2py.gluon.dal.NoSQLAdapter.ON()=web2py.gluon.dal.NoSQLAdapter-class.html#ON,Variable web2py.gluon.html.ON=web2py.gluon.html-module.html#ON,Variable web2py.gluon.tools.ON=web2py.gluon.tools-module.html#ON"><a title="web2py.gluon.ON
web2py.gluon.dal.BaseAdapter.ON
web2py.gluon.dal.NoSQLAdapter.ON
web2py.gluon.html.ON
web2py.gluon.tools.ON" class="py-name" href="#" onclick="return doclink('link-2199', 'ON', 'link-2199');">ON</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L4922"></a><tt class="py-lineno">4922</tt>  <tt class="py-line"> </tt>
<a name="L4923"></a><tt class="py-lineno">4923</tt>  <tt class="py-line"> </tt>
<a name="L4924"></a><tt class="py-lineno">4924</tt>  <tt class="py-line"> </tt>
<a name="Expression"></a><div id="Expression-def"><a name="L4925"></a><tt class="py-lineno">4925</tt> <a class="py-toggle" href="#" id="Expression-toggle" onclick="return toggle('Expression');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html">Expression</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Expression-expanded"><a name="L4926"></a><tt class="py-lineno">4926</tt>  <tt class="py-line"> </tt>
<a name="Expression.__init__"></a><div id="Expression.__init__-def"><a name="L4927"></a><tt class="py-lineno">4927</tt> <a class="py-toggle" href="#" id="Expression.__init__-toggle" onclick="return toggle('Expression.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__init__">__init__</a><tt class="py-op">(</tt> </tt>
<a name="L4928"></a><tt class="py-lineno">4928</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L4929"></a><tt class="py-lineno">4929</tt>  <tt class="py-line">        <tt class="py-param">db</tt><tt class="py-op">,</tt> </tt>
<a name="L4930"></a><tt class="py-lineno">4930</tt>  <tt class="py-line">        <tt class="py-param">op</tt><tt class="py-op">,</tt> </tt>
<a name="L4931"></a><tt class="py-lineno">4931</tt>  <tt class="py-line">        <tt class="py-param">first</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L4932"></a><tt class="py-lineno">4932</tt>  <tt class="py-line">        <tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L4933"></a><tt class="py-lineno">4933</tt>  <tt class="py-line">        <tt class="py-param">type</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L4934"></a><tt class="py-lineno">4934</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__init__-expanded"><a name="L4935"></a><tt class="py-lineno">4935</tt>  <tt class="py-line"> </tt>
<a name="L4936"></a><tt class="py-lineno">4936</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L4937"></a><tt class="py-lineno">4937</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt> <tt class="py-op">=</tt> <tt class="py-name">op</tt> </tt>
<a name="L4938"></a><tt class="py-lineno">4938</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2200" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2200', 'first', 'link-297');">first</a></tt> <tt class="py-op">=</tt> <tt id="link-2201" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2201', 'first', 'link-297');">first</a></tt> </tt>
<a name="L4939"></a><tt class="py-lineno">4939</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">second</tt> </tt>
<a name="L4940"></a><tt class="py-lineno">4940</tt>  <tt class="py-line">        <tt class="py-comment">### self._tablename =  first._tablename ## CHECK</tt> </tt>
<a name="L4941"></a><tt class="py-lineno">4941</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">type</tt> <tt class="py-keyword">and</tt> <tt id="link-2202" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2202', 'first', 'link-297');">first</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt id="link-2203" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2203', 'first', 'link-297');">first</a></tt><tt class="py-op">,</tt><tt class="py-string">'type'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L4942"></a><tt class="py-lineno">4942</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">=</tt> <tt id="link-2204" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2204', 'first', 'link-297');">first</a></tt><tt class="py-op">.</tt><tt class="py-name">type</tt> </tt>
<a name="L4943"></a><tt class="py-lineno">4943</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4944"></a><tt class="py-lineno">4944</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">=</tt> <tt class="py-name">type</tt> </tt>
</div><a name="L4945"></a><tt class="py-lineno">4945</tt>  <tt class="py-line"> </tt>
<a name="Expression.sum"></a><div id="Expression.sum-def"><a name="L4946"></a><tt class="py-lineno">4946</tt> <a class="py-toggle" href="#" id="Expression.sum-toggle" onclick="return toggle('Expression.sum');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#sum">sum</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.sum-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.sum-expanded"><a name="L4947"></a><tt class="py-lineno">4947</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2205" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2205', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2206" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.AGGREGATE()=web2py.gluon.dal.BaseAdapter-class.html#AGGREGATE,Method web2py.gluon.dal.NoSQLAdapter.AGGREGATE()=web2py.gluon.dal.NoSQLAdapter-class.html#AGGREGATE"><a title="web2py.gluon.dal.BaseAdapter.AGGREGATE
web2py.gluon.dal.NoSQLAdapter.AGGREGATE" class="py-name" href="#" onclick="return doclink('link-2206', 'AGGREGATE', 'link-2206');">AGGREGATE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'SUM'</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4948"></a><tt class="py-lineno">4948</tt>  <tt class="py-line"> </tt>
<a name="Expression.max"></a><div id="Expression.max-def"><a name="L4949"></a><tt class="py-lineno">4949</tt> <a class="py-toggle" href="#" id="Expression.max-toggle" onclick="return toggle('Expression.max');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#max">max</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.max-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.max-expanded"><a name="L4950"></a><tt class="py-lineno">4950</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2207" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2207', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2208" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.AGGREGATE
web2py.gluon.dal.NoSQLAdapter.AGGREGATE" class="py-name" href="#" onclick="return doclink('link-2208', 'AGGREGATE', 'link-2206');">AGGREGATE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'MAX'</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4951"></a><tt class="py-lineno">4951</tt>  <tt class="py-line"> </tt>
<a name="Expression.min"></a><div id="Expression.min-def"><a name="L4952"></a><tt class="py-lineno">4952</tt> <a class="py-toggle" href="#" id="Expression.min-toggle" onclick="return toggle('Expression.min');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#min">min</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.min-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.min-expanded"><a name="L4953"></a><tt class="py-lineno">4953</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2209" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2209', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2210" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.AGGREGATE
web2py.gluon.dal.NoSQLAdapter.AGGREGATE" class="py-name" href="#" onclick="return doclink('link-2210', 'AGGREGATE', 'link-2206');">AGGREGATE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'MIN'</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4954"></a><tt class="py-lineno">4954</tt>  <tt class="py-line"> </tt>
<a name="Expression.len"></a><div id="Expression.len-def"><a name="L4955"></a><tt class="py-lineno">4955</tt> <a class="py-toggle" href="#" id="Expression.len-toggle" onclick="return toggle('Expression.len');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#len">len</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.len-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.len-expanded"><a name="L4956"></a><tt class="py-lineno">4956</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2211" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2211', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2212" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.AGGREGATE
web2py.gluon.dal.NoSQLAdapter.AGGREGATE" class="py-name" href="#" onclick="return doclink('link-2212', 'AGGREGATE', 'link-2206');">AGGREGATE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'LENGTH'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4957"></a><tt class="py-lineno">4957</tt>  <tt class="py-line"> </tt>
<a name="Expression.lower"></a><div id="Expression.lower-def"><a name="L4958"></a><tt class="py-lineno">4958</tt> <a class="py-toggle" href="#" id="Expression.lower-toggle" onclick="return toggle('Expression.lower');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#lower">lower</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.lower-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.lower-expanded"><a name="L4959"></a><tt class="py-lineno">4959</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2213" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2213', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2214" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.LOWER()=web2py.gluon.dal.BaseAdapter-class.html#LOWER,Method web2py.gluon.dal.NoSQLAdapter.LOWER()=web2py.gluon.dal.NoSQLAdapter-class.html#LOWER"><a title="web2py.gluon.dal.BaseAdapter.LOWER
web2py.gluon.dal.NoSQLAdapter.LOWER" class="py-name" href="#" onclick="return doclink('link-2214', 'LOWER', 'link-2214');">LOWER</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4960"></a><tt class="py-lineno">4960</tt>  <tt class="py-line"> </tt>
<a name="Expression.upper"></a><div id="Expression.upper-def"><a name="L4961"></a><tt class="py-lineno">4961</tt> <a class="py-toggle" href="#" id="Expression.upper-toggle" onclick="return toggle('Expression.upper');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#upper">upper</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.upper-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.upper-expanded"><a name="L4962"></a><tt class="py-lineno">4962</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2215" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2215', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2216" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.UPPER()=web2py.gluon.dal.BaseAdapter-class.html#UPPER,Method web2py.gluon.dal.NoSQLAdapter.UPPER()=web2py.gluon.dal.NoSQLAdapter-class.html#UPPER"><a title="web2py.gluon.dal.BaseAdapter.UPPER
web2py.gluon.dal.NoSQLAdapter.UPPER" class="py-name" href="#" onclick="return doclink('link-2216', 'UPPER', 'link-2216');">UPPER</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4963"></a><tt class="py-lineno">4963</tt>  <tt class="py-line"> </tt>
<a name="Expression.year"></a><div id="Expression.year-def"><a name="L4964"></a><tt class="py-lineno">4964</tt> <a class="py-toggle" href="#" id="Expression.year-toggle" onclick="return toggle('Expression.year');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#year">year</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.year-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.year-expanded"><a name="L4965"></a><tt class="py-lineno">4965</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2217" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2217', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2218" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.EXTRACT()=web2py.gluon.dal.BaseAdapter-class.html#EXTRACT,Method web2py.gluon.dal.MSSQLAdapter.EXTRACT()=web2py.gluon.dal.MSSQLAdapter-class.html#EXTRACT,Method web2py.gluon.dal.NoSQLAdapter.EXTRACT()=web2py.gluon.dal.NoSQLAdapter-class.html#EXTRACT,Method web2py.gluon.dal.SQLiteAdapter.EXTRACT()=web2py.gluon.dal.SQLiteAdapter-class.html#EXTRACT"><a title="web2py.gluon.dal.BaseAdapter.EXTRACT
web2py.gluon.dal.MSSQLAdapter.EXTRACT
web2py.gluon.dal.NoSQLAdapter.EXTRACT
web2py.gluon.dal.SQLiteAdapter.EXTRACT" class="py-name" href="#" onclick="return doclink('link-2218', 'EXTRACT', 'link-2218');">EXTRACT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'year'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4966"></a><tt class="py-lineno">4966</tt>  <tt class="py-line"> </tt>
<a name="Expression.month"></a><div id="Expression.month-def"><a name="L4967"></a><tt class="py-lineno">4967</tt> <a class="py-toggle" href="#" id="Expression.month-toggle" onclick="return toggle('Expression.month');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#month">month</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.month-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.month-expanded"><a name="L4968"></a><tt class="py-lineno">4968</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2219" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2219', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2220" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EXTRACT
web2py.gluon.dal.MSSQLAdapter.EXTRACT
web2py.gluon.dal.NoSQLAdapter.EXTRACT
web2py.gluon.dal.SQLiteAdapter.EXTRACT" class="py-name" href="#" onclick="return doclink('link-2220', 'EXTRACT', 'link-2218');">EXTRACT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'month'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4969"></a><tt class="py-lineno">4969</tt>  <tt class="py-line"> </tt>
<a name="Expression.day"></a><div id="Expression.day-def"><a name="L4970"></a><tt class="py-lineno">4970</tt> <a class="py-toggle" href="#" id="Expression.day-toggle" onclick="return toggle('Expression.day');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#day">day</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.day-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.day-expanded"><a name="L4971"></a><tt class="py-lineno">4971</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2221" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2221', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2222" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EXTRACT
web2py.gluon.dal.MSSQLAdapter.EXTRACT
web2py.gluon.dal.NoSQLAdapter.EXTRACT
web2py.gluon.dal.SQLiteAdapter.EXTRACT" class="py-name" href="#" onclick="return doclink('link-2222', 'EXTRACT', 'link-2218');">EXTRACT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'day'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4972"></a><tt class="py-lineno">4972</tt>  <tt class="py-line"> </tt>
<a name="Expression.hour"></a><div id="Expression.hour-def"><a name="L4973"></a><tt class="py-lineno">4973</tt> <a class="py-toggle" href="#" id="Expression.hour-toggle" onclick="return toggle('Expression.hour');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#hour">hour</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.hour-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.hour-expanded"><a name="L4974"></a><tt class="py-lineno">4974</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2223" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2223', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2224" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EXTRACT
web2py.gluon.dal.MSSQLAdapter.EXTRACT
web2py.gluon.dal.NoSQLAdapter.EXTRACT
web2py.gluon.dal.SQLiteAdapter.EXTRACT" class="py-name" href="#" onclick="return doclink('link-2224', 'EXTRACT', 'link-2218');">EXTRACT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'hour'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4975"></a><tt class="py-lineno">4975</tt>  <tt class="py-line"> </tt>
<a name="Expression.minutes"></a><div id="Expression.minutes-def"><a name="L4976"></a><tt class="py-lineno">4976</tt> <a class="py-toggle" href="#" id="Expression.minutes-toggle" onclick="return toggle('Expression.minutes');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#minutes">minutes</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.minutes-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.minutes-expanded"><a name="L4977"></a><tt class="py-lineno">4977</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2225" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2225', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2226" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EXTRACT
web2py.gluon.dal.MSSQLAdapter.EXTRACT
web2py.gluon.dal.NoSQLAdapter.EXTRACT
web2py.gluon.dal.SQLiteAdapter.EXTRACT" class="py-name" href="#" onclick="return doclink('link-2226', 'EXTRACT', 'link-2218');">EXTRACT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'minute'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4978"></a><tt class="py-lineno">4978</tt>  <tt class="py-line"> </tt>
<a name="Expression.coalesce_zero"></a><div id="Expression.coalesce_zero-def"><a name="L4979"></a><tt class="py-lineno">4979</tt> <a class="py-toggle" href="#" id="Expression.coalesce_zero-toggle" onclick="return toggle('Expression.coalesce_zero');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#coalesce_zero">coalesce_zero</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.coalesce_zero-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.coalesce_zero-expanded"><a name="L4980"></a><tt class="py-lineno">4980</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-2227" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2227', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2228" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.COALESCE_ZERO()=web2py.gluon.dal.BaseAdapter-class.html#COALESCE_ZERO"><a title="web2py.gluon.dal.BaseAdapter.COALESCE_ZERO" class="py-name" href="#" onclick="return doclink('link-2228', 'COALESCE_ZERO', 'link-2228');">COALESCE_ZERO</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4981"></a><tt class="py-lineno">4981</tt>  <tt class="py-line"> </tt>
<a name="Expression.seconds"></a><div id="Expression.seconds-def"><a name="L4982"></a><tt class="py-lineno">4982</tt> <a class="py-toggle" href="#" id="Expression.seconds-toggle" onclick="return toggle('Expression.seconds');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#seconds">seconds</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.seconds-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.seconds-expanded"><a name="L4983"></a><tt class="py-lineno">4983</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2229" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2229', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2230" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EXTRACT
web2py.gluon.dal.MSSQLAdapter.EXTRACT
web2py.gluon.dal.NoSQLAdapter.EXTRACT
web2py.gluon.dal.SQLiteAdapter.EXTRACT" class="py-name" href="#" onclick="return doclink('link-2230', 'EXTRACT', 'link-2218');">EXTRACT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'second'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4984"></a><tt class="py-lineno">4984</tt>  <tt class="py-line"> </tt>
<a name="Expression.__getslice__"></a><div id="Expression.__getslice__-def"><a name="L4985"></a><tt class="py-lineno">4985</tt> <a class="py-toggle" href="#" id="Expression.__getslice__-toggle" onclick="return toggle('Expression.__getslice__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__getslice__">__getslice__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">start</tt><tt class="py-op">,</tt> <tt class="py-param">stop</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__getslice__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__getslice__-expanded"><a name="L4986"></a><tt class="py-lineno">4986</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-2231" class="py-name"><a title="web2py.gluon.main.HttpServer.start
web2py.gluon.rocket.Rocket.start
web2py.gluon.rocket.ThreadPool.start
web2py.gluon.widget.start
web2py.gluon.widget.web2pyDialog.start
web2py.gluon.winservice.Service.start
web2py.gluon.winservice.Web2pyService.start" class="py-name" href="#" onclick="return doclink('link-2231', 'start', 'link-853');">start</a></tt> <tt class="py-op">&lt;</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L4987"></a><tt class="py-lineno">4987</tt>  <tt class="py-line">            <tt class="py-name">pos0</tt> <tt class="py-op">=</tt> <tt class="py-string">'(%s - %d)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2232" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2232', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">abs</tt><tt class="py-op">(</tt><tt id="link-2233" class="py-name"><a title="web2py.gluon.main.HttpServer.start
web2py.gluon.rocket.Rocket.start
web2py.gluon.rocket.ThreadPool.start
web2py.gluon.widget.start
web2py.gluon.widget.web2pyDialog.start
web2py.gluon.winservice.Service.start
web2py.gluon.winservice.Web2pyService.start" class="py-name" href="#" onclick="return doclink('link-2233', 'start', 'link-853');">start</a></tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
<a name="L4988"></a><tt class="py-lineno">4988</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4989"></a><tt class="py-lineno">4989</tt>  <tt class="py-line">            <tt class="py-name">pos0</tt> <tt class="py-op">=</tt> <tt id="link-2234" class="py-name"><a title="web2py.gluon.main.HttpServer.start
web2py.gluon.rocket.Rocket.start
web2py.gluon.rocket.ThreadPool.start
web2py.gluon.widget.start
web2py.gluon.widget.web2pyDialog.start
web2py.gluon.winservice.Service.start
web2py.gluon.winservice.Web2pyService.start" class="py-name" href="#" onclick="return doclink('link-2234', 'start', 'link-853');">start</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt> </tt>
<a name="L4990"></a><tt class="py-lineno">4990</tt>  <tt class="py-line"> </tt>
<a name="L4991"></a><tt class="py-lineno">4991</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-2235" class="py-name" targets="Method web2py.gluon.main.HttpServer.stop()=web2py.gluon.main.HttpServer-class.html#stop,Method web2py.gluon.rocket.Monitor.stop()=web2py.gluon.rocket.Monitor-class.html#stop,Method web2py.gluon.rocket.Rocket.stop()=web2py.gluon.rocket.Rocket-class.html#stop,Method web2py.gluon.rocket.ThreadPool.stop()=web2py.gluon.rocket.ThreadPool-class.html#stop,Method web2py.gluon.widget.web2pyDialog.stop()=web2py.gluon.widget.web2pyDialog-class.html#stop,Method web2py.gluon.winservice.Service.stop()=web2py.gluon.winservice.Service-class.html#stop,Method web2py.gluon.winservice.Web2pyService.stop()=web2py.gluon.winservice.Web2pyService-class.html#stop"><a title="web2py.gluon.main.HttpServer.stop
web2py.gluon.rocket.Monitor.stop
web2py.gluon.rocket.Rocket.stop
web2py.gluon.rocket.ThreadPool.stop
web2py.gluon.widget.web2pyDialog.stop
web2py.gluon.winservice.Service.stop
web2py.gluon.winservice.Web2pyService.stop" class="py-name" href="#" onclick="return doclink('link-2235', 'stop', 'link-2235');">stop</a></tt> <tt class="py-op">&lt;</tt> <tt class="py-number">0</tt><tt class="py-op">:</tt> </tt>
<a name="L4992"></a><tt class="py-lineno">4992</tt>  <tt class="py-line">            <tt class="py-name">length</tt> <tt class="py-op">=</tt> <tt class="py-string">'(%s - %d - %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2236" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2236', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">abs</tt><tt class="py-op">(</tt><tt id="link-2237" class="py-name"><a title="web2py.gluon.main.HttpServer.stop
web2py.gluon.rocket.Monitor.stop
web2py.gluon.rocket.Rocket.stop
web2py.gluon.rocket.ThreadPool.stop
web2py.gluon.widget.web2pyDialog.stop
web2py.gluon.winservice.Service.stop
web2py.gluon.winservice.Web2pyService.stop" class="py-name" href="#" onclick="return doclink('link-2237', 'stop', 'link-2235');">stop</a></tt><tt class="py-op">)</tt> <tt class="py-op">-</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">pos0</tt><tt class="py-op">)</tt> </tt>
<a name="L4993"></a><tt class="py-lineno">4993</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt id="link-2238" class="py-name"><a title="web2py.gluon.main.HttpServer.stop
web2py.gluon.rocket.Monitor.stop
web2py.gluon.rocket.Rocket.stop
web2py.gluon.rocket.ThreadPool.stop
web2py.gluon.widget.web2pyDialog.stop
web2py.gluon.winservice.Service.stop
web2py.gluon.winservice.Web2pyService.stop" class="py-name" href="#" onclick="return doclink('link-2238', 'stop', 'link-2235');">stop</a></tt> <tt class="py-op">==</tt> <tt class="py-name">sys</tt><tt class="py-op">.</tt><tt class="py-name">maxint</tt><tt class="py-op">:</tt> </tt>
<a name="L4994"></a><tt class="py-lineno">4994</tt>  <tt class="py-line">            <tt class="py-name">length</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2239" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2239', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L4995"></a><tt class="py-lineno">4995</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L4996"></a><tt class="py-lineno">4996</tt>  <tt class="py-line">            <tt class="py-name">length</tt> <tt class="py-op">=</tt> <tt class="py-string">'(%s - %s)'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-2240" class="py-name"><a title="web2py.gluon.main.HttpServer.stop
web2py.gluon.rocket.Monitor.stop
web2py.gluon.rocket.Rocket.stop
web2py.gluon.rocket.ThreadPool.stop
web2py.gluon.widget.web2pyDialog.stop
web2py.gluon.winservice.Service.stop
web2py.gluon.winservice.Web2pyService.stop" class="py-name" href="#" onclick="return doclink('link-2240', 'stop', 'link-2235');">stop</a></tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">,</tt> <tt class="py-name">pos0</tt><tt class="py-op">)</tt> </tt>
<a name="L4997"></a><tt class="py-lineno">4997</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2241" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2241', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2242" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.SUBSTRING()=web2py.gluon.dal.BaseAdapter-class.html#SUBSTRING,Method web2py.gluon.dal.FireBirdAdapter.SUBSTRING()=web2py.gluon.dal.FireBirdAdapter-class.html#SUBSTRING,Method web2py.gluon.dal.MSSQLAdapter.SUBSTRING()=web2py.gluon.dal.MSSQLAdapter-class.html#SUBSTRING,Method web2py.gluon.dal.MySQLAdapter.SUBSTRING()=web2py.gluon.dal.MySQLAdapter-class.html#SUBSTRING,Method web2py.gluon.dal.NoSQLAdapter.SUBSTRING()=web2py.gluon.dal.NoSQLAdapter-class.html#SUBSTRING"><a title="web2py.gluon.dal.BaseAdapter.SUBSTRING
web2py.gluon.dal.FireBirdAdapter.SUBSTRING
web2py.gluon.dal.MSSQLAdapter.SUBSTRING
web2py.gluon.dal.MySQLAdapter.SUBSTRING
web2py.gluon.dal.NoSQLAdapter.SUBSTRING" class="py-name" href="#" onclick="return doclink('link-2242', 'SUBSTRING', 'link-2242');">SUBSTRING</a></tt><tt class="py-op">,</tt> </tt>
<a name="L4998"></a><tt class="py-lineno">4998</tt>  <tt class="py-line">                          <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">pos0</tt><tt class="py-op">,</tt> <tt class="py-name">length</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L4999"></a><tt class="py-lineno">4999</tt>  <tt class="py-line"> </tt>
<a name="Expression.__getitem__"></a><div id="Expression.__getitem__-def"><a name="L5000"></a><tt class="py-lineno">5000</tt> <a class="py-toggle" href="#" id="Expression.__getitem__-toggle" onclick="return toggle('Expression.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">i</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__getitem__-expanded"><a name="L5001"></a><tt class="py-lineno">5001</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">:</tt><tt class="py-name">i</tt> <tt class="py-op">+</tt> <tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
</div><a name="L5002"></a><tt class="py-lineno">5002</tt>  <tt class="py-line"> </tt>
<a name="Expression.__str__"></a><div id="Expression.__str__-def"><a name="L5003"></a><tt class="py-lineno">5003</tt> <a class="py-toggle" href="#" id="Expression.__str__-toggle" onclick="return toggle('Expression.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__str__-expanded"><a name="L5004"></a><tt class="py-lineno">5004</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2243" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-2243', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5005"></a><tt class="py-lineno">5005</tt>  <tt class="py-line"> </tt>
<a name="Expression.__or__"></a><div id="Expression.__or__-def"><a name="L5006"></a><tt class="py-lineno">5006</tt> <a class="py-toggle" href="#" id="Expression.__or__-toggle" onclick="return toggle('Expression.__or__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__or__">__or__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt>  <tt class="py-comment"># for use in sortby</tt> </tt>
</div><a name="L5007"></a><tt class="py-lineno">5007</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2244" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2244', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2245" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.COMMA()=web2py.gluon.dal.BaseAdapter-class.html#COMMA,Method web2py.gluon.dal.CouchDBAdapter.COMMA()=web2py.gluon.dal.CouchDBAdapter-class.html#COMMA,Method web2py.gluon.dal.GoogleDatastoreAdapter.COMMA()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#COMMA"><a title="web2py.gluon.dal.BaseAdapter.COMMA
web2py.gluon.dal.CouchDBAdapter.COMMA
web2py.gluon.dal.GoogleDatastoreAdapter.COMMA" class="py-name" href="#" onclick="return doclink('link-2245', 'COMMA', 'link-2245');">COMMA</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5008"></a><tt class="py-lineno">5008</tt>  <tt class="py-line"> </tt>
<a name="Expression.__invert__"></a><div id="Expression.__invert__-def"><a name="L5009"></a><tt class="py-lineno">5009</tt> <a class="py-toggle" href="#" id="Expression.__invert__-toggle" onclick="return toggle('Expression.__invert__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__invert__">__invert__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__invert__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__invert__-expanded"><a name="L5010"></a><tt class="py-lineno">5010</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-string">'_op'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt> <tt class="py-op">==</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2246" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.INVERT()=web2py.gluon.dal.BaseAdapter-class.html#INVERT,Method web2py.gluon.dal.GoogleDatastoreAdapter.INVERT()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#INVERT"><a title="web2py.gluon.dal.BaseAdapter.INVERT
web2py.gluon.dal.GoogleDatastoreAdapter.INVERT" class="py-name" href="#" onclick="return doclink('link-2246', 'INVERT', 'link-2246');">INVERT</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5011"></a><tt class="py-lineno">5011</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2247" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2247', 'first', 'link-297');">first</a></tt> </tt>
<a name="L5012"></a><tt class="py-lineno">5012</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2248" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2248', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2249" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.INVERT
web2py.gluon.dal.GoogleDatastoreAdapter.INVERT" class="py-name" href="#" onclick="return doclink('link-2249', 'INVERT', 'link-2246');">INVERT</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">type</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5013"></a><tt class="py-lineno">5013</tt>  <tt class="py-line"> </tt>
<a name="Expression.__add__"></a><div id="Expression.__add__-def"><a name="L5014"></a><tt class="py-lineno">5014</tt> <a class="py-toggle" href="#" id="Expression.__add__-toggle" onclick="return toggle('Expression.__add__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__add__">__add__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__add__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__add__-expanded"><a name="L5015"></a><tt class="py-lineno">5015</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2250" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2250', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2251" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.ADD()=web2py.gluon.dal.BaseAdapter-class.html#ADD,Method web2py.gluon.dal.NoSQLAdapter.ADD()=web2py.gluon.dal.NoSQLAdapter-class.html#ADD"><a title="web2py.gluon.dal.BaseAdapter.ADD
web2py.gluon.dal.NoSQLAdapter.ADD" class="py-name" href="#" onclick="return doclink('link-2251', 'ADD', 'link-2251');">ADD</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5016"></a><tt class="py-lineno">5016</tt>  <tt class="py-line"> </tt>
<a name="Expression.__sub__"></a><div id="Expression.__sub__-def"><a name="L5017"></a><tt class="py-lineno">5017</tt> <a class="py-toggle" href="#" id="Expression.__sub__-toggle" onclick="return toggle('Expression.__sub__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__sub__">__sub__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__sub__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__sub__-expanded"><a name="L5018"></a><tt class="py-lineno">5018</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">==</tt> <tt class="py-string">'integer'</tt><tt class="py-op">:</tt> </tt>
<a name="L5019"></a><tt class="py-lineno">5019</tt>  <tt class="py-line">            <tt class="py-name">result_type</tt> <tt class="py-op">=</tt> <tt class="py-string">'integer'</tt> </tt>
<a name="L5020"></a><tt class="py-lineno">5020</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">[</tt><tt class="py-string">'date'</tt><tt class="py-op">,</tt><tt class="py-string">'time'</tt><tt class="py-op">,</tt><tt class="py-string">'datetime'</tt><tt class="py-op">,</tt><tt class="py-string">'double'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L5021"></a><tt class="py-lineno">5021</tt>  <tt class="py-line">            <tt class="py-name">result_type</tt> <tt class="py-op">=</tt> <tt class="py-string">'double'</tt> </tt>
<a name="L5022"></a><tt class="py-lineno">5022</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5023"></a><tt class="py-lineno">5023</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"subtraction operation not supported for type"</tt> </tt>
<a name="L5024"></a><tt class="py-lineno">5024</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2252" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2252', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2253" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.SUB()=web2py.gluon.dal.BaseAdapter-class.html#SUB,Method web2py.gluon.dal.NoSQLAdapter.SUB()=web2py.gluon.dal.NoSQLAdapter-class.html#SUB"><a title="web2py.gluon.dal.BaseAdapter.SUB
web2py.gluon.dal.NoSQLAdapter.SUB" class="py-name" href="#" onclick="return doclink('link-2253', 'SUB', 'link-2253');">SUB</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">,</tt> </tt>
<a name="L5025"></a><tt class="py-lineno">5025</tt>  <tt class="py-line">                          <tt class="py-name">result_type</tt><tt class="py-op">)</tt> </tt>
</div><a name="Expression.__mul__"></a><div id="Expression.__mul__-def"><a name="L5026"></a><tt class="py-lineno">5026</tt> <a class="py-toggle" href="#" id="Expression.__mul__-toggle" onclick="return toggle('Expression.__mul__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__mul__">__mul__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__mul__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__mul__-expanded"><a name="L5027"></a><tt class="py-lineno">5027</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2254" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2254', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2255" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.MUL()=web2py.gluon.dal.BaseAdapter-class.html#MUL,Method web2py.gluon.dal.NoSQLAdapter.MUL()=web2py.gluon.dal.NoSQLAdapter-class.html#MUL"><a title="web2py.gluon.dal.BaseAdapter.MUL
web2py.gluon.dal.NoSQLAdapter.MUL" class="py-name" href="#" onclick="return doclink('link-2255', 'MUL', 'link-2255');">MUL</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5028"></a><tt class="py-lineno">5028</tt>  <tt class="py-line"> </tt>
<a name="Expression.__div__"></a><div id="Expression.__div__-def"><a name="L5029"></a><tt class="py-lineno">5029</tt> <a class="py-toggle" href="#" id="Expression.__div__-toggle" onclick="return toggle('Expression.__div__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__div__">__div__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__div__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__div__-expanded"><a name="L5030"></a><tt class="py-lineno">5030</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2256" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2256', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2257" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.DIV()=web2py.gluon.dal.BaseAdapter-class.html#DIV,Method web2py.gluon.dal.NoSQLAdapter.DIV()=web2py.gluon.dal.NoSQLAdapter-class.html#DIV,Class web2py.gluon.html.DIV=web2py.gluon.html.DIV-class.html"><a title="web2py.gluon.dal.BaseAdapter.DIV
web2py.gluon.dal.NoSQLAdapter.DIV
web2py.gluon.html.DIV" class="py-name" href="#" onclick="return doclink('link-2257', 'DIV', 'link-2257');">DIV</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5031"></a><tt class="py-lineno">5031</tt>  <tt class="py-line"> </tt>
<a name="Expression.__mod__"></a><div id="Expression.__mod__-def"><a name="L5032"></a><tt class="py-lineno">5032</tt> <a class="py-toggle" href="#" id="Expression.__mod__-toggle" onclick="return toggle('Expression.__mod__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__mod__">__mod__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__mod__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__mod__-expanded"><a name="L5033"></a><tt class="py-lineno">5033</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2258" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2258', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2259" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.MOD()=web2py.gluon.dal.BaseAdapter-class.html#MOD"><a title="web2py.gluon.dal.BaseAdapter.MOD" class="py-name" href="#" onclick="return doclink('link-2259', 'MOD', 'link-2259');">MOD</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5034"></a><tt class="py-lineno">5034</tt>  <tt class="py-line"> </tt>
<a name="Expression.__eq__"></a><div id="Expression.__eq__-def"><a name="L5035"></a><tt class="py-lineno">5035</tt> <a class="py-toggle" href="#" id="Expression.__eq__-toggle" onclick="return toggle('Expression.__eq__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__eq__">__eq__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__eq__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__eq__-expanded"><a name="L5036"></a><tt class="py-lineno">5036</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2260" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2260', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2261" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.EQ
web2py.gluon.dal.CouchDBAdapter.EQ
web2py.gluon.dal.GoogleDatastoreAdapter.EQ" class="py-name" href="#" onclick="return doclink('link-2261', 'EQ', 'link-1358');">EQ</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5037"></a><tt class="py-lineno">5037</tt>  <tt class="py-line"> </tt>
<a name="Expression.__ne__"></a><div id="Expression.__ne__-def"><a name="L5038"></a><tt class="py-lineno">5038</tt> <a class="py-toggle" href="#" id="Expression.__ne__-toggle" onclick="return toggle('Expression.__ne__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__ne__">__ne__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__ne__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__ne__-expanded"><a name="L5039"></a><tt class="py-lineno">5039</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2262" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2262', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2263" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.NE
web2py.gluon.dal.CouchDBAdapter.NE
web2py.gluon.dal.GoogleDatastoreAdapter.NE" class="py-name" href="#" onclick="return doclink('link-2263', 'NE', 'link-1359');">NE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5040"></a><tt class="py-lineno">5040</tt>  <tt class="py-line"> </tt>
<a name="Expression.__lt__"></a><div id="Expression.__lt__-def"><a name="L5041"></a><tt class="py-lineno">5041</tt> <a class="py-toggle" href="#" id="Expression.__lt__-toggle" onclick="return toggle('Expression.__lt__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__lt__">__lt__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__lt__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__lt__-expanded"><a name="L5042"></a><tt class="py-lineno">5042</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2264" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2264', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2265" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.LT
web2py.gluon.dal.GoogleDatastoreAdapter.LT" class="py-name" href="#" onclick="return doclink('link-2265', 'LT', 'link-1362');">LT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5043"></a><tt class="py-lineno">5043</tt>  <tt class="py-line"> </tt>
<a name="Expression.__le__"></a><div id="Expression.__le__-def"><a name="L5044"></a><tt class="py-lineno">5044</tt> <a class="py-toggle" href="#" id="Expression.__le__-toggle" onclick="return toggle('Expression.__le__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__le__">__le__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__le__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__le__-expanded"><a name="L5045"></a><tt class="py-lineno">5045</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2266" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2266', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2267" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.LE
web2py.gluon.dal.GoogleDatastoreAdapter.LE" class="py-name" href="#" onclick="return doclink('link-2267', 'LE', 'link-1365');">LE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5046"></a><tt class="py-lineno">5046</tt>  <tt class="py-line"> </tt>
<a name="Expression.__gt__"></a><div id="Expression.__gt__-def"><a name="L5047"></a><tt class="py-lineno">5047</tt> <a class="py-toggle" href="#" id="Expression.__gt__-toggle" onclick="return toggle('Expression.__gt__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__gt__">__gt__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__gt__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__gt__-expanded"><a name="L5048"></a><tt class="py-lineno">5048</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2268" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2268', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2269" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.GT
web2py.gluon.dal.GoogleDatastoreAdapter.GT" class="py-name" href="#" onclick="return doclink('link-2269', 'GT', 'link-1364');">GT</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5049"></a><tt class="py-lineno">5049</tt>  <tt class="py-line"> </tt>
<a name="Expression.__ge__"></a><div id="Expression.__ge__-def"><a name="L5050"></a><tt class="py-lineno">5050</tt> <a class="py-toggle" href="#" id="Expression.__ge__-toggle" onclick="return toggle('Expression.__ge__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#__ge__">__ge__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.__ge__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.__ge__-expanded"><a name="L5051"></a><tt class="py-lineno">5051</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2270" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2270', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2271" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.GE
web2py.gluon.dal.GoogleDatastoreAdapter.GE" class="py-name" href="#" onclick="return doclink('link-2271', 'GE', 'link-1363');">GE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5052"></a><tt class="py-lineno">5052</tt>  <tt class="py-line"> </tt>
<a name="Expression.like"></a><div id="Expression.like-def"><a name="L5053"></a><tt class="py-lineno">5053</tt> <a class="py-toggle" href="#" id="Expression.like-toggle" onclick="return toggle('Expression.like');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#like">like</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.like-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.like-expanded"><a name="L5054"></a><tt class="py-lineno">5054</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2272" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2272', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2273" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.LIKE()=web2py.gluon.dal.BaseAdapter-class.html#LIKE,Method web2py.gluon.dal.NoSQLAdapter.LIKE()=web2py.gluon.dal.NoSQLAdapter-class.html#LIKE,Method web2py.gluon.dal.PostgreSQLAdapter.LIKE()=web2py.gluon.dal.PostgreSQLAdapter-class.html#LIKE"><a title="web2py.gluon.dal.BaseAdapter.LIKE
web2py.gluon.dal.NoSQLAdapter.LIKE
web2py.gluon.dal.PostgreSQLAdapter.LIKE" class="py-name" href="#" onclick="return doclink('link-2273', 'LIKE', 'link-2273');">LIKE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5055"></a><tt class="py-lineno">5055</tt>  <tt class="py-line"> </tt>
<a name="Expression.belongs"></a><div id="Expression.belongs-def"><a name="L5056"></a><tt class="py-lineno">5056</tt> <a class="py-toggle" href="#" id="Expression.belongs-toggle" onclick="return toggle('Expression.belongs');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#belongs">belongs</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.belongs-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.belongs-expanded"><a name="L5057"></a><tt class="py-lineno">5057</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2274" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2274', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2275" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.BELONGS()=web2py.gluon.dal.BaseAdapter-class.html#BELONGS,Method web2py.gluon.dal.GoogleDatastoreAdapter.BELONGS()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#BELONGS"><a title="web2py.gluon.dal.BaseAdapter.BELONGS
web2py.gluon.dal.GoogleDatastoreAdapter.BELONGS" class="py-name" href="#" onclick="return doclink('link-2275', 'BELONGS', 'link-2275');">BELONGS</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5058"></a><tt class="py-lineno">5058</tt>  <tt class="py-line"> </tt>
<a name="Expression.startswith"></a><div id="Expression.startswith-def"><a name="L5059"></a><tt class="py-lineno">5059</tt> <a class="py-toggle" href="#" id="Expression.startswith-toggle" onclick="return toggle('Expression.startswith');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#startswith">startswith</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.startswith-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.startswith-expanded"><a name="L5060"></a><tt class="py-lineno">5060</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt> <tt class="py-string">'text'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5061"></a><tt class="py-lineno">5061</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"startswith used with incompatible field type"</tt> </tt>
<a name="L5062"></a><tt class="py-lineno">5062</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2276" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2276', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2277" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.STARTSWITH()=web2py.gluon.dal.BaseAdapter-class.html#STARTSWITH,Method web2py.gluon.dal.NoSQLAdapter.STARTSWITH()=web2py.gluon.dal.NoSQLAdapter-class.html#STARTSWITH,Method web2py.gluon.dal.PostgreSQLAdapter.STARTSWITH()=web2py.gluon.dal.PostgreSQLAdapter-class.html#STARTSWITH"><a title="web2py.gluon.dal.BaseAdapter.STARTSWITH
web2py.gluon.dal.NoSQLAdapter.STARTSWITH
web2py.gluon.dal.PostgreSQLAdapter.STARTSWITH" class="py-name" href="#" onclick="return doclink('link-2277', 'STARTSWITH', 'link-2277');">STARTSWITH</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5063"></a><tt class="py-lineno">5063</tt>  <tt class="py-line"> </tt>
<a name="Expression.endswith"></a><div id="Expression.endswith-def"><a name="L5064"></a><tt class="py-lineno">5064</tt> <a class="py-toggle" href="#" id="Expression.endswith-toggle" onclick="return toggle('Expression.endswith');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#endswith">endswith</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.endswith-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.endswith-expanded"><a name="L5065"></a><tt class="py-lineno">5065</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt> <tt class="py-string">'text'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5066"></a><tt class="py-lineno">5066</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"endswith used with incompatible field type"</tt> </tt>
<a name="L5067"></a><tt class="py-lineno">5067</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2278" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2278', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2279" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.ENDSWITH()=web2py.gluon.dal.BaseAdapter-class.html#ENDSWITH,Method web2py.gluon.dal.NoSQLAdapter.ENDSWITH()=web2py.gluon.dal.NoSQLAdapter-class.html#ENDSWITH,Method web2py.gluon.dal.PostgreSQLAdapter.ENDSWITH()=web2py.gluon.dal.PostgreSQLAdapter-class.html#ENDSWITH"><a title="web2py.gluon.dal.BaseAdapter.ENDSWITH
web2py.gluon.dal.NoSQLAdapter.ENDSWITH
web2py.gluon.dal.PostgreSQLAdapter.ENDSWITH" class="py-name" href="#" onclick="return doclink('link-2279', 'ENDSWITH', 'link-2279');">ENDSWITH</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5068"></a><tt class="py-lineno">5068</tt>  <tt class="py-line"> </tt>
<a name="Expression.contains"></a><div id="Expression.contains-def"><a name="L5069"></a><tt class="py-lineno">5069</tt> <a class="py-toggle" href="#" id="Expression.contains-toggle" onclick="return toggle('Expression.contains');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#contains">contains</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.contains-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.contains-expanded"><a name="L5070"></a><tt class="py-lineno">5070</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt> <tt class="py-string">'text'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">.</tt><tt id="link-2280" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2280', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'list:'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5071"></a><tt class="py-lineno">5071</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"contains used with incompatible field type"</tt> </tt>
<a name="L5072"></a><tt class="py-lineno">5072</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2281" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2281', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2282" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.CONTAINS()=web2py.gluon.dal.BaseAdapter-class.html#CONTAINS,Method web2py.gluon.dal.GoogleDatastoreAdapter.CONTAINS()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#CONTAINS,Method web2py.gluon.dal.PostgreSQLAdapter.CONTAINS()=web2py.gluon.dal.PostgreSQLAdapter-class.html#CONTAINS"><a title="web2py.gluon.dal.BaseAdapter.CONTAINS
web2py.gluon.dal.GoogleDatastoreAdapter.CONTAINS
web2py.gluon.dal.PostgreSQLAdapter.CONTAINS" class="py-name" href="#" onclick="return doclink('link-2282', 'CONTAINS', 'link-2282');">CONTAINS</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5073"></a><tt class="py-lineno">5073</tt>  <tt class="py-line"> </tt>
<a name="Expression.with_alias"></a><div id="Expression.with_alias-def"><a name="L5074"></a><tt class="py-lineno">5074</tt> <a class="py-toggle" href="#" id="Expression.with_alias-toggle" onclick="return toggle('Expression.with_alias');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Expression-class.html#with_alias">with_alias</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">alias</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Expression.with_alias-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Expression.with_alias-expanded"><a name="L5075"></a><tt class="py-lineno">5075</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2283" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2283', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2284" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.AS()=web2py.gluon.dal.BaseAdapter-class.html#AS,Method web2py.gluon.dal.NoSQLAdapter.AS()=web2py.gluon.dal.NoSQLAdapter-class.html#AS"><a title="web2py.gluon.dal.BaseAdapter.AS
web2py.gluon.dal.NoSQLAdapter.AS" class="py-name" href="#" onclick="return doclink('link-2284', 'AS', 'link-2284');">AS</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt id="link-2285" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.alias
web2py.gluon.dal.NoSQLAdapter.alias" class="py-name" href="#" onclick="return doclink('link-2285', 'alias', 'link-440');">alias</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L5076"></a><tt class="py-lineno">5076</tt>  <tt class="py-line"> </tt>
<a name="L5077"></a><tt class="py-lineno">5077</tt>  <tt class="py-line">    <tt class="py-comment"># for use in both Query and sortby</tt> </tt>
<a name="L5078"></a><tt class="py-lineno">5078</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L5079"></a><tt class="py-lineno">5079</tt>  <tt class="py-line"> </tt>
<a name="SQLCustomType"></a><div id="SQLCustomType-def"><a name="L5080"></a><tt class="py-lineno">5080</tt> <a class="py-toggle" href="#" id="SQLCustomType-toggle" onclick="return toggle('SQLCustomType');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCustomType-class.html">SQLCustomType</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCustomType-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="SQLCustomType-expanded"><a name="L5081"></a><tt class="py-lineno">5081</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L5082"></a><tt class="py-lineno">5082</tt>  <tt class="py-line"><tt class="py-docstring">    allows defining of custom SQL types</tt> </tt>
<a name="L5083"></a><tt class="py-lineno">5083</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5084"></a><tt class="py-lineno">5084</tt>  <tt class="py-line"><tt class="py-docstring">    Example::</tt> </tt>
<a name="L5085"></a><tt class="py-lineno">5085</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5086"></a><tt class="py-lineno">5086</tt>  <tt class="py-line"><tt class="py-docstring">        decimal = SQLCustomType(</tt> </tt>
<a name="L5087"></a><tt class="py-lineno">5087</tt>  <tt class="py-line"><tt class="py-docstring">            type ='double',</tt> </tt>
<a name="L5088"></a><tt class="py-lineno">5088</tt>  <tt class="py-line"><tt class="py-docstring">            native ='integer',</tt> </tt>
<a name="L5089"></a><tt class="py-lineno">5089</tt>  <tt class="py-line"><tt class="py-docstring">            encoder =(lambda x: int(float(x) * 100)),</tt> </tt>
<a name="L5090"></a><tt class="py-lineno">5090</tt>  <tt class="py-line"><tt class="py-docstring">            decoder = (lambda x: Decimal("0.00") + Decimal(str(float(x)/100)) )</tt> </tt>
<a name="L5091"></a><tt class="py-lineno">5091</tt>  <tt class="py-line"><tt class="py-docstring">            )</tt> </tt>
<a name="L5092"></a><tt class="py-lineno">5092</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5093"></a><tt class="py-lineno">5093</tt>  <tt class="py-line"><tt class="py-docstring">        db.define_table(</tt> </tt>
<a name="L5094"></a><tt class="py-lineno">5094</tt>  <tt class="py-line"><tt class="py-docstring">            'example',</tt> </tt>
<a name="L5095"></a><tt class="py-lineno">5095</tt>  <tt class="py-line"><tt class="py-docstring">            Field('value', type=decimal)</tt> </tt>
<a name="L5096"></a><tt class="py-lineno">5096</tt>  <tt class="py-line"><tt class="py-docstring">            )</tt> </tt>
<a name="L5097"></a><tt class="py-lineno">5097</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5098"></a><tt class="py-lineno">5098</tt>  <tt class="py-line"><tt class="py-docstring">    :param type: the web2py type (default = 'string')</tt> </tt>
<a name="L5099"></a><tt class="py-lineno">5099</tt>  <tt class="py-line"><tt class="py-docstring">    :param native: the backend type</tt> </tt>
<a name="L5100"></a><tt class="py-lineno">5100</tt>  <tt class="py-line"><tt class="py-docstring">    :param encoder: how to encode the value to store it in the backend</tt> </tt>
<a name="L5101"></a><tt class="py-lineno">5101</tt>  <tt class="py-line"><tt class="py-docstring">    :param decoder: how to decode the value retrieved from the backend</tt> </tt>
<a name="L5102"></a><tt class="py-lineno">5102</tt>  <tt class="py-line"><tt class="py-docstring">    :param validator: what validators to use ( default = None, will use the</tt> </tt>
<a name="L5103"></a><tt class="py-lineno">5103</tt>  <tt class="py-line"><tt class="py-docstring">        default validator for type)</tt> </tt>
<a name="L5104"></a><tt class="py-lineno">5104</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L5105"></a><tt class="py-lineno">5105</tt>  <tt class="py-line"> </tt>
<a name="SQLCustomType.__init__"></a><div id="SQLCustomType.__init__-def"><a name="L5106"></a><tt class="py-lineno">5106</tt> <a class="py-toggle" href="#" id="SQLCustomType.__init__-toggle" onclick="return toggle('SQLCustomType.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCustomType-class.html#__init__">__init__</a><tt class="py-op">(</tt> </tt>
<a name="L5107"></a><tt class="py-lineno">5107</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L5108"></a><tt class="py-lineno">5108</tt>  <tt class="py-line">        <tt class="py-param">type</tt><tt class="py-op">=</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt> </tt>
<a name="L5109"></a><tt class="py-lineno">5109</tt>  <tt class="py-line">        <tt class="py-param">native</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5110"></a><tt class="py-lineno">5110</tt>  <tt class="py-line">        <tt class="py-param">encoder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5111"></a><tt class="py-lineno">5111</tt>  <tt class="py-line">        <tt class="py-param">decoder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5112"></a><tt class="py-lineno">5112</tt>  <tt class="py-line">        <tt class="py-param">validator</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5113"></a><tt class="py-lineno">5113</tt>  <tt class="py-line">        <tt class="py-param">_class</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5114"></a><tt class="py-lineno">5114</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCustomType.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLCustomType.__init__-expanded"><a name="L5115"></a><tt class="py-lineno">5115</tt>  <tt class="py-line"> </tt>
<a name="L5116"></a><tt class="py-lineno">5116</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">=</tt> <tt class="py-name">type</tt> </tt>
<a name="L5117"></a><tt class="py-lineno">5117</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">native</tt> <tt class="py-op">=</tt> <tt class="py-name">native</tt> </tt>
<a name="L5118"></a><tt class="py-lineno">5118</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">encoder</tt> <tt class="py-op">=</tt> <tt class="py-name">encoder</tt> <tt class="py-keyword">or</tt> <tt class="py-op">(</tt><tt class="py-keyword">lambda</tt> <tt id="link-2286" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2286', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt> <tt id="link-2287" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2287', 'x', 'link-114');">x</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5119"></a><tt class="py-lineno">5119</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2288" class="py-name"><a title="web2py.gluon.decoder
web2py.gluon.decoder.decoder" class="py-name" href="#" onclick="return doclink('link-2288', 'decoder', 'link-629');">decoder</a></tt> <tt class="py-op">=</tt> <tt id="link-2289" class="py-name"><a title="web2py.gluon.decoder
web2py.gluon.decoder.decoder" class="py-name" href="#" onclick="return doclink('link-2289', 'decoder', 'link-629');">decoder</a></tt> <tt class="py-keyword">or</tt> <tt class="py-op">(</tt><tt class="py-keyword">lambda</tt> <tt id="link-2290" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2290', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt> <tt id="link-2291" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2291', 'x', 'link-114');">x</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5120"></a><tt class="py-lineno">5120</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">validator</tt> <tt class="py-op">=</tt> <tt class="py-name">validator</tt> </tt>
<a name="L5121"></a><tt class="py-lineno">5121</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_class</tt> <tt class="py-op">=</tt> <tt class="py-name">_class</tt> <tt class="py-keyword">or</tt> <tt class="py-name">type</tt> </tt>
</div><a name="L5122"></a><tt class="py-lineno">5122</tt>  <tt class="py-line"> </tt>
<a name="SQLCustomType.startswith"></a><div id="SQLCustomType.startswith-def"><a name="L5123"></a><tt class="py-lineno">5123</tt> <a class="py-toggle" href="#" id="SQLCustomType.startswith-toggle" onclick="return toggle('SQLCustomType.startswith');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCustomType-class.html#startswith">startswith</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">dummy</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCustomType.startswith-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLCustomType.startswith-expanded"><a name="L5124"></a><tt class="py-lineno">5124</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt>
</div><a name="L5125"></a><tt class="py-lineno">5125</tt>  <tt class="py-line"> </tt>
<a name="SQLCustomType.__getslice__"></a><div id="SQLCustomType.__getslice__-def"><a name="L5126"></a><tt class="py-lineno">5126</tt> <a class="py-toggle" href="#" id="SQLCustomType.__getslice__-toggle" onclick="return toggle('SQLCustomType.__getslice__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCustomType-class.html#__getslice__">__getslice__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">a</tt><tt class="py-op">=</tt><tt class="py-number">0</tt><tt class="py-op">,</tt> <tt class="py-param">b</tt><tt class="py-op">=</tt><tt class="py-number">100</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCustomType.__getslice__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLCustomType.__getslice__-expanded"><a name="L5127"></a><tt class="py-lineno">5127</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L5128"></a><tt class="py-lineno">5128</tt>  <tt class="py-line"> </tt>
<a name="SQLCustomType.__getitem__"></a><div id="SQLCustomType.__getitem__-def"><a name="L5129"></a><tt class="py-lineno">5129</tt> <a class="py-toggle" href="#" id="SQLCustomType.__getitem__-toggle" onclick="return toggle('SQLCustomType.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCustomType-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">i</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCustomType.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLCustomType.__getitem__-expanded"><a name="L5130"></a><tt class="py-lineno">5130</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
</div><a name="L5131"></a><tt class="py-lineno">5131</tt>  <tt class="py-line"> </tt>
<a name="SQLCustomType.__str__"></a><div id="SQLCustomType.__str__-def"><a name="L5132"></a><tt class="py-lineno">5132</tt> <a class="py-toggle" href="#" id="SQLCustomType.__str__-toggle" onclick="return toggle('SQLCustomType.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.SQLCustomType-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="SQLCustomType.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="SQLCustomType.__str__-expanded"><a name="L5133"></a><tt class="py-lineno">5133</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_class</tt> </tt>
</div></div><a name="L5134"></a><tt class="py-lineno">5134</tt>  <tt class="py-line"> </tt>
<a name="L5135"></a><tt class="py-lineno">5135</tt>  <tt class="py-line"> </tt>
<a name="Field"></a><div id="Field-def"><a name="L5136"></a><tt class="py-lineno">5136</tt> <a class="py-toggle" href="#" id="Field-toggle" onclick="return toggle('Field');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html">Field</a><tt class="py-op">(</tt><tt class="py-base-class">Expression</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Field-expanded"><a name="L5137"></a><tt class="py-lineno">5137</tt>  <tt class="py-line"> </tt>
<a name="L5138"></a><tt class="py-lineno">5138</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L5139"></a><tt class="py-lineno">5139</tt>  <tt class="py-line"><tt class="py-docstring">    an instance of this class represents a database field</tt> </tt>
<a name="L5140"></a><tt class="py-lineno">5140</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5141"></a><tt class="py-lineno">5141</tt>  <tt class="py-line"><tt class="py-docstring">    example::</tt> </tt>
<a name="L5142"></a><tt class="py-lineno">5142</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5143"></a><tt class="py-lineno">5143</tt>  <tt class="py-line"><tt class="py-docstring">        a = Field(name, 'string', length=32, default=None, required=False,</tt> </tt>
<a name="L5144"></a><tt class="py-lineno">5144</tt>  <tt class="py-line"><tt class="py-docstring">            requires=IS_NOT_EMPTY(), ondelete='CASCADE',</tt> </tt>
<a name="L5145"></a><tt class="py-lineno">5145</tt>  <tt class="py-line"><tt class="py-docstring">            notnull=False, unique=False,</tt> </tt>
<a name="L5146"></a><tt class="py-lineno">5146</tt>  <tt class="py-line"><tt class="py-docstring">            uploadfield=True, widget=None, label=None, comment=None,</tt> </tt>
<a name="L5147"></a><tt class="py-lineno">5147</tt>  <tt class="py-line"><tt class="py-docstring">            uploadfield=True, # True means store on disk,</tt> </tt>
<a name="L5148"></a><tt class="py-lineno">5148</tt>  <tt class="py-line"><tt class="py-docstring">                              # 'a_field_name' means store in this field in db</tt> </tt>
<a name="L5149"></a><tt class="py-lineno">5149</tt>  <tt class="py-line"><tt class="py-docstring">                              # False means file content will be discarded.</tt> </tt>
<a name="L5150"></a><tt class="py-lineno">5150</tt>  <tt class="py-line"><tt class="py-docstring">            writable=True, readable=True, update=None, authorize=None,</tt> </tt>
<a name="L5151"></a><tt class="py-lineno">5151</tt>  <tt class="py-line"><tt class="py-docstring">            autodelete=False, represent=None, uploadfolder=None,</tt> </tt>
<a name="L5152"></a><tt class="py-lineno">5152</tt>  <tt class="py-line"><tt class="py-docstring">            uploadseparate=False # upload to separate directories by uuid_keys</tt> </tt>
<a name="L5153"></a><tt class="py-lineno">5153</tt>  <tt class="py-line"><tt class="py-docstring">                                 # first 2 character and tablename.fieldname</tt> </tt>
<a name="L5154"></a><tt class="py-lineno">5154</tt>  <tt class="py-line"><tt class="py-docstring">                                 # False - old behavior</tt> </tt>
<a name="L5155"></a><tt class="py-lineno">5155</tt>  <tt class="py-line"><tt class="py-docstring">                                 # True - put uploaded file in</tt> </tt>
<a name="L5156"></a><tt class="py-lineno">5156</tt>  <tt class="py-line"><tt class="py-docstring">                                 #   &lt;uploaddir&gt;/&lt;tablename&gt;.&lt;fieldname&gt;/uuid_key[:2]</tt> </tt>
<a name="L5157"></a><tt class="py-lineno">5157</tt>  <tt class="py-line"><tt class="py-docstring">                                 #        directory)</tt> </tt>
<a name="L5158"></a><tt class="py-lineno">5158</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5159"></a><tt class="py-lineno">5159</tt>  <tt class="py-line"><tt class="py-docstring">    to be used as argument of DAL.define_table</tt> </tt>
<a name="L5160"></a><tt class="py-lineno">5160</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5161"></a><tt class="py-lineno">5161</tt>  <tt class="py-line"><tt class="py-docstring">    allowed field types:</tt> </tt>
<a name="L5162"></a><tt class="py-lineno">5162</tt>  <tt class="py-line"><tt class="py-docstring">    string, boolean, integer, double, text, blob,</tt> </tt>
<a name="L5163"></a><tt class="py-lineno">5163</tt>  <tt class="py-line"><tt class="py-docstring">    date, time, datetime, upload, password</tt> </tt>
<a name="L5164"></a><tt class="py-lineno">5164</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5165"></a><tt class="py-lineno">5165</tt>  <tt class="py-line"><tt class="py-docstring">    strings must have a length of Adapter.maxcharlength by default (512 or 255 for mysql)</tt> </tt>
<a name="L5166"></a><tt class="py-lineno">5166</tt>  <tt class="py-line"><tt class="py-docstring">    fields should have a default or they will be required in SQLFORMs</tt> </tt>
<a name="L5167"></a><tt class="py-lineno">5167</tt>  <tt class="py-line"><tt class="py-docstring">    the requires argument is used to validate the field input in SQLFORMs</tt> </tt>
<a name="L5168"></a><tt class="py-lineno">5168</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5169"></a><tt class="py-lineno">5169</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L5170"></a><tt class="py-lineno">5170</tt>  <tt class="py-line"> </tt>
<a name="Field.__init__"></a><div id="Field.__init__-def"><a name="L5171"></a><tt class="py-lineno">5171</tt> <a class="py-toggle" href="#" id="Field.__init__-toggle" onclick="return toggle('Field.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#__init__">__init__</a><tt class="py-op">(</tt> </tt>
<a name="L5172"></a><tt class="py-lineno">5172</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L5173"></a><tt class="py-lineno">5173</tt>  <tt class="py-line">        <tt class="py-param">fieldname</tt><tt class="py-op">,</tt> </tt>
<a name="L5174"></a><tt class="py-lineno">5174</tt>  <tt class="py-line">        <tt class="py-param">type</tt><tt class="py-op">=</tt><tt class="py-string">'string'</tt><tt class="py-op">,</tt> </tt>
<a name="L5175"></a><tt class="py-lineno">5175</tt>  <tt class="py-line">        <tt class="py-param">length</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5176"></a><tt class="py-lineno">5176</tt>  <tt class="py-line">        <tt class="py-param">default</tt><tt class="py-op">=</tt><tt id="link-2292" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2292', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">,</tt> </tt>
<a name="L5177"></a><tt class="py-lineno">5177</tt>  <tt class="py-line">        <tt class="py-param">required</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L5178"></a><tt class="py-lineno">5178</tt>  <tt class="py-line">        <tt class="py-param">requires</tt><tt class="py-op">=</tt><tt id="link-2293" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2293', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">,</tt> </tt>
<a name="L5179"></a><tt class="py-lineno">5179</tt>  <tt class="py-line">        <tt class="py-param">ondelete</tt><tt class="py-op">=</tt><tt class="py-string">'CASCADE'</tt><tt class="py-op">,</tt> </tt>
<a name="L5180"></a><tt class="py-lineno">5180</tt>  <tt class="py-line">        <tt class="py-param">notnull</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L5181"></a><tt class="py-lineno">5181</tt>  <tt class="py-line">        <tt class="py-param">unique</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L5182"></a><tt class="py-lineno">5182</tt>  <tt class="py-line">        <tt class="py-param">uploadfield</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5183"></a><tt class="py-lineno">5183</tt>  <tt class="py-line">        <tt class="py-param">widget</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5184"></a><tt class="py-lineno">5184</tt>  <tt class="py-line">        <tt class="py-param">label</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5185"></a><tt class="py-lineno">5185</tt>  <tt class="py-line">        <tt class="py-param">comment</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5186"></a><tt class="py-lineno">5186</tt>  <tt class="py-line">        <tt class="py-param">writable</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5187"></a><tt class="py-lineno">5187</tt>  <tt class="py-line">        <tt class="py-param">readable</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5188"></a><tt class="py-lineno">5188</tt>  <tt class="py-line">        <tt class="py-param">update</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5189"></a><tt class="py-lineno">5189</tt>  <tt class="py-line">        <tt class="py-param">authorize</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5190"></a><tt class="py-lineno">5190</tt>  <tt class="py-line">        <tt class="py-param">autodelete</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L5191"></a><tt class="py-lineno">5191</tt>  <tt class="py-line">        <tt class="py-param">represent</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5192"></a><tt class="py-lineno">5192</tt>  <tt class="py-line">        <tt class="py-param">uploadfolder</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5193"></a><tt class="py-lineno">5193</tt>  <tt class="py-line">        <tt class="py-param">uploadseparate</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">,</tt> </tt>
<a name="L5194"></a><tt class="py-lineno">5194</tt>  <tt class="py-line">        <tt class="py-param">compute</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5195"></a><tt class="py-lineno">5195</tt>  <tt class="py-line">        <tt class="py-param">custom_store</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5196"></a><tt class="py-lineno">5196</tt>  <tt class="py-line">        <tt class="py-param">custom_retrieve</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5197"></a><tt class="py-lineno">5197</tt>  <tt class="py-line">        <tt class="py-param">custom_delete</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5198"></a><tt class="py-lineno">5198</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.__init__-expanded"><a name="L5199"></a><tt class="py-lineno">5199</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L5200"></a><tt class="py-lineno">5200</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L5201"></a><tt class="py-lineno">5201</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2294" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2294', 'first', 'link-297');">first</a></tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L5202"></a><tt class="py-lineno">5202</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L5203"></a><tt class="py-lineno">5203</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">fieldname</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5204"></a><tt class="py-lineno">5204</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"missing field name"</tt> </tt>
<a name="L5205"></a><tt class="py-lineno">5205</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">fieldname</tt><tt class="py-op">.</tt><tt id="link-2295" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2295', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5206"></a><tt class="py-lineno">5206</tt>  <tt class="py-line">            <tt class="py-name">fieldname</tt><tt class="py-op">,</tt><tt class="py-name">readable</tt><tt class="py-op">,</tt><tt class="py-name">writable</tt><tt class="py-op">=</tt><tt class="py-name">fieldname</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">False</tt> </tt>
<a name="L5207"></a><tt class="py-lineno">5207</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">fieldname</tt><tt class="py-op">.</tt><tt id="link-2296" class="py-name"><a title="web2py.gluon.dal.Expression.startswith
web2py.gluon.dal.SQLCustomType.startswith" class="py-name" href="#" onclick="return doclink('link-2296', 'startswith', 'link-192');">startswith</a></tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5208"></a><tt class="py-lineno">5208</tt>  <tt class="py-line">            <tt class="py-name">fieldname</tt><tt class="py-op">,</tt><tt class="py-name">readable</tt><tt class="py-op">,</tt><tt class="py-name">writable</tt><tt class="py-op">=</tt><tt class="py-name">fieldname</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">False</tt><tt class="py-op">,</tt><tt class="py-name">False</tt> </tt>
<a name="L5209"></a><tt class="py-lineno">5209</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-string">'='</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fieldname</tt><tt class="py-op">:</tt> </tt>
<a name="L5210"></a><tt class="py-lineno">5210</tt>  <tt class="py-line">            <tt class="py-name">fieldname</tt><tt class="py-op">,</tt><tt class="py-name">default</tt> <tt class="py-op">=</tt> <tt class="py-name">fieldname</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'='</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt>
<a name="L5211"></a><tt class="py-lineno">5211</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2297" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2297', 'name', 'link-119');">name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">fieldname</tt> <tt class="py-op">=</tt> <tt id="link-2298" class="py-name"><a title="web2py.gluon.dal.cleanup" class="py-name" href="#" onclick="return doclink('link-2298', 'cleanup', 'link-1951');">cleanup</a></tt><tt class="py-op">(</tt><tt class="py-name">fieldname</tt><tt class="py-op">)</tt> </tt>
<a name="L5212"></a><tt class="py-lineno">5212</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt id="link-2299" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2299', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">,</tt><tt class="py-name">fieldname</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-name">fieldname</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'_'</tt> <tt class="py-keyword">or</tt> \ </tt>
<a name="L5213"></a><tt class="py-lineno">5213</tt>  <tt class="py-line">                <tt id="link-2300" class="py-name"><a title="web2py.gluon.dal.regex_python_keywords" class="py-name" href="#" onclick="return doclink('link-2300', 'regex_python_keywords', 'link-33');">regex_python_keywords</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">fieldname</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5214"></a><tt class="py-lineno">5214</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Field: invalid field name: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">fieldname</tt> </tt>
<a name="L5215"></a><tt class="py-lineno">5215</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">type</tt><tt class="py-op">,</tt> <tt id="link-2301" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2301', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5216"></a><tt class="py-lineno">5216</tt>  <tt class="py-line">            <tt class="py-name">type</tt> <tt class="py-op">=</tt> <tt class="py-string">'reference '</tt> <tt class="py-op">+</tt> <tt class="py-name">type</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt> </tt>
<a name="L5217"></a><tt class="py-lineno">5217</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">=</tt> <tt class="py-name">type</tt>  <tt class="py-comment"># 'string', 'integer'</tt> </tt>
<a name="L5218"></a><tt class="py-lineno">5218</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">length</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">length</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt id="link-2302" class="py-name"><a title="web2py.gluon.dal.MAXCHARLENGTH" class="py-name" href="#" onclick="return doclink('link-2302', 'MAXCHARLENGTH', 'link-0');">MAXCHARLENGTH</a></tt> <tt class="py-keyword">or</tt> <tt class="py-name">length</tt> </tt>
<a name="L5219"></a><tt class="py-lineno">5219</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">default</tt><tt class="py-op">==</tt><tt id="link-2303" class="py-name"><a title="web2py.gluon.dal.DEFAULT
web2py.gluon.tools.DEFAULT" class="py-name" href="#" onclick="return doclink('link-2303', 'DEFAULT', 'link-25');">DEFAULT</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5220"></a><tt class="py-lineno">5220</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">default</tt> <tt class="py-op">=</tt> <tt id="link-2304" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2304', 'update', 'link-507');">update</a></tt> <tt class="py-keyword">or</tt> <tt class="py-name">None</tt> </tt>
<a name="L5221"></a><tt class="py-lineno">5221</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5222"></a><tt class="py-lineno">5222</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">default</tt> <tt class="py-op">=</tt> <tt class="py-name">default</tt> </tt>
<a name="L5223"></a><tt class="py-lineno">5223</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">required</tt> <tt class="py-op">=</tt> <tt class="py-name">required</tt>  <tt class="py-comment"># is this field required</tt> </tt>
<a name="L5224"></a><tt class="py-lineno">5224</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">ondelete</tt> <tt class="py-op">=</tt> <tt class="py-name">ondelete</tt><tt class="py-op">.</tt><tt id="link-2305" class="py-name"><a title="web2py.gluon.dal.Expression.upper" class="py-name" href="#" onclick="return doclink('link-2305', 'upper', 'link-596');">upper</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt>  <tt class="py-comment"># this is for reference fields only</tt> </tt>
<a name="L5225"></a><tt class="py-lineno">5225</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">notnull</tt> <tt class="py-op">=</tt> <tt class="py-name">notnull</tt> </tt>
<a name="L5226"></a><tt class="py-lineno">5226</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">unique</tt> <tt class="py-op">=</tt> <tt class="py-name">unique</tt> </tt>
<a name="L5227"></a><tt class="py-lineno">5227</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> <tt class="py-op">=</tt> <tt class="py-name">uploadfield</tt> </tt>
<a name="L5228"></a><tt class="py-lineno">5228</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfolder</tt> <tt class="py-op">=</tt> <tt class="py-name">uploadfolder</tt> </tt>
<a name="L5229"></a><tt class="py-lineno">5229</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadseparate</tt> <tt class="py-op">=</tt> <tt class="py-name">uploadseparate</tt> </tt>
<a name="L5230"></a><tt class="py-lineno">5230</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2306" class="py-name" targets="Static Method web2py.gluon.sqlhtml.BooleanWidget.widget()=web2py.gluon.sqlhtml.BooleanWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.CheckboxesWidget.widget()=web2py.gluon.sqlhtml.CheckboxesWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.FormWidget.widget()=web2py.gluon.sqlhtml.FormWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.ListWidget.widget()=web2py.gluon.sqlhtml.ListWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.MultipleOptionsWidget.widget()=web2py.gluon.sqlhtml.MultipleOptionsWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.OptionsWidget.widget()=web2py.gluon.sqlhtml.OptionsWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.PasswordWidget.widget()=web2py.gluon.sqlhtml.PasswordWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.RadioWidget.widget()=web2py.gluon.sqlhtml.RadioWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.StringWidget.widget()=web2py.gluon.sqlhtml.StringWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.TextWidget.widget()=web2py.gluon.sqlhtml.TextWidget-class.html#widget,Static Method web2py.gluon.sqlhtml.UploadWidget.widget()=web2py.gluon.sqlhtml.UploadWidget-class.html#widget,Module web2py.gluon.widget=web2py.gluon.widget-module.html"><a title="web2py.gluon.sqlhtml.BooleanWidget.widget
web2py.gluon.sqlhtml.CheckboxesWidget.widget
web2py.gluon.sqlhtml.FormWidget.widget
web2py.gluon.sqlhtml.ListWidget.widget
web2py.gluon.sqlhtml.MultipleOptionsWidget.widget
web2py.gluon.sqlhtml.OptionsWidget.widget
web2py.gluon.sqlhtml.PasswordWidget.widget
web2py.gluon.sqlhtml.RadioWidget.widget
web2py.gluon.sqlhtml.StringWidget.widget
web2py.gluon.sqlhtml.TextWidget.widget
web2py.gluon.sqlhtml.UploadWidget.widget
web2py.gluon.widget" class="py-name" href="#" onclick="return doclink('link-2306', 'widget', 'link-2306');">widget</a></tt> <tt class="py-op">=</tt> <tt id="link-2307" class="py-name"><a title="web2py.gluon.sqlhtml.BooleanWidget.widget
web2py.gluon.sqlhtml.CheckboxesWidget.widget
web2py.gluon.sqlhtml.FormWidget.widget
web2py.gluon.sqlhtml.ListWidget.widget
web2py.gluon.sqlhtml.MultipleOptionsWidget.widget
web2py.gluon.sqlhtml.OptionsWidget.widget
web2py.gluon.sqlhtml.PasswordWidget.widget
web2py.gluon.sqlhtml.RadioWidget.widget
web2py.gluon.sqlhtml.StringWidget.widget
web2py.gluon.sqlhtml.TextWidget.widget
web2py.gluon.sqlhtml.UploadWidget.widget
web2py.gluon.widget" class="py-name" href="#" onclick="return doclink('link-2307', 'widget', 'link-2306');">widget</a></tt> </tt>
<a name="L5231"></a><tt class="py-lineno">5231</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">label</tt> <tt class="py-op">=</tt> <tt class="py-name">label</tt> <tt class="py-keyword">or</tt> <tt class="py-string">' '</tt><tt class="py-op">.</tt><tt id="link-2308" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2308', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">.</tt><tt class="py-name">capitalize</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fieldname</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L5232"></a><tt class="py-lineno">5232</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">comment</tt> <tt class="py-op">=</tt> <tt class="py-name">comment</tt> </tt>
<a name="L5233"></a><tt class="py-lineno">5233</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">writable</tt> <tt class="py-op">=</tt> <tt class="py-name">writable</tt> </tt>
<a name="L5234"></a><tt class="py-lineno">5234</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">readable</tt> <tt class="py-op">=</tt> <tt class="py-name">readable</tt> </tt>
<a name="L5235"></a><tt class="py-lineno">5235</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2309" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2309', 'update', 'link-507');">update</a></tt> <tt class="py-op">=</tt> <tt id="link-2310" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2310', 'update', 'link-507');">update</a></tt> </tt>
<a name="L5236"></a><tt class="py-lineno">5236</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">authorize</tt> <tt class="py-op">=</tt> <tt class="py-name">authorize</tt> </tt>
<a name="L5237"></a><tt class="py-lineno">5237</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">autodelete</tt> <tt class="py-op">=</tt> <tt class="py-name">autodelete</tt> </tt>
<a name="L5238"></a><tt class="py-lineno">5238</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2311" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2311', 'represent', 'link-304');">represent</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">type</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'list:integer'</tt><tt class="py-op">,</tt><tt class="py-string">'list:string'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5239"></a><tt class="py-lineno">5239</tt>  <tt class="py-line">            <tt id="link-2312" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2312', 'represent', 'link-304');">represent</a></tt><tt class="py-op">=</tt><tt class="py-keyword">lambda</tt> <tt id="link-2313" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2313', 'x', 'link-114');">x</a></tt><tt class="py-op">:</tt> <tt class="py-string">', '</tt><tt class="py-op">.</tt><tt id="link-2314" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2314', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">y</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">y</tt> <tt class="py-keyword">in</tt> <tt id="link-2315" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2315', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">or</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5240"></a><tt class="py-lineno">5240</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2316" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2316', 'represent', 'link-304');">represent</a></tt> <tt class="py-op">=</tt> <tt id="link-2317" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2317', 'represent', 'link-304');">represent</a></tt> </tt>
<a name="L5241"></a><tt class="py-lineno">5241</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">compute</tt> <tt class="py-op">=</tt> <tt class="py-name">compute</tt> </tt>
<a name="L5242"></a><tt class="py-lineno">5242</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">isattachment</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt>
<a name="L5243"></a><tt class="py-lineno">5243</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_store</tt> <tt class="py-op">=</tt> <tt class="py-name">custom_store</tt> </tt>
<a name="L5244"></a><tt class="py-lineno">5244</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_retrieve</tt> <tt class="py-op">=</tt> <tt class="py-name">custom_retrieve</tt> </tt>
<a name="L5245"></a><tt class="py-lineno">5245</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_delete</tt> <tt class="py-op">=</tt> <tt class="py-name">custom_delete</tt> </tt>
<a name="L5246"></a><tt class="py-lineno">5246</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">label</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L5247"></a><tt class="py-lineno">5247</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">label</tt> <tt class="py-op">=</tt> <tt class="py-string">' '</tt><tt class="py-op">.</tt><tt id="link-2318" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2318', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt id="link-2319" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2319', 'x', 'link-114');">x</a></tt><tt class="py-op">.</tt><tt class="py-name">capitalize</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt id="link-2320" class="py-name"><a title="sqlite3.dbapi2.x" class="py-name" href="#" onclick="return doclink('link-2320', 'x', 'link-114');">x</a></tt> <tt class="py-keyword">in</tt> </tt>
<a name="L5248"></a><tt class="py-lineno">5248</tt>  <tt class="py-line">                                  <tt class="py-name">fieldname</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">)</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5249"></a><tt class="py-lineno">5249</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-2321" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2321', 'requires', 'link-1616');">requires</a></tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L5250"></a><tt class="py-lineno">5250</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2322" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2322', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L5251"></a><tt class="py-lineno">5251</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5252"></a><tt class="py-lineno">5252</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2323" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2323', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt id="link-2324" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2324', 'requires', 'link-1616');">requires</a></tt> </tt>
</div><a name="L5253"></a><tt class="py-lineno">5253</tt>  <tt class="py-line"> </tt>
<a name="Field.store"></a><div id="Field.store-def"><a name="L5254"></a><tt class="py-lineno">5254</tt> <a class="py-toggle" href="#" id="Field.store-toggle" onclick="return toggle('Field.store');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#store">store</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">file</tt><tt class="py-op">,</tt> <tt class="py-param">filename</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-param">path</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.store-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.store-expanded"><a name="L5255"></a><tt class="py-lineno">5255</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_store</tt><tt class="py-op">:</tt> </tt>
<a name="L5256"></a><tt class="py-lineno">5256</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_store</tt><tt class="py-op">(</tt><tt class="py-name">file</tt><tt class="py-op">,</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt><tt class="py-name">path</tt><tt class="py-op">)</tt> </tt>
<a name="L5257"></a><tt class="py-lineno">5257</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">filename</tt><tt class="py-op">:</tt> </tt>
<a name="L5258"></a><tt class="py-lineno">5258</tt>  <tt class="py-line">            <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt class="py-name">file</tt><tt class="py-op">.</tt><tt id="link-2325" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2325', 'name', 'link-119');">name</a></tt> </tt>
<a name="L5259"></a><tt class="py-lineno">5259</tt>  <tt class="py-line">        <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt class="py-name">basename</tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'/'</tt><tt class="py-op">,</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">sep</tt><tt class="py-op">)</tt>\ </tt>
<a name="L5260"></a><tt class="py-lineno">5260</tt>  <tt class="py-line">                                        <tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'\\'</tt><tt class="py-op">,</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">sep</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L5261"></a><tt class="py-lineno">5261</tt>  <tt class="py-line">        <tt id="link-2326" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2326', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">'\.(?P&lt;e&gt;\w{1,5})$'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2327" class="py-name"><a title="web2py.gluon.tools.Crud.search" class="py-name" href="#" onclick="return doclink('link-2327', 'search', 'link-621');">search</a></tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt> </tt>
<a name="L5262"></a><tt class="py-lineno">5262</tt>  <tt class="py-line">        <tt class="py-name">extension</tt> <tt class="py-op">=</tt> <tt id="link-2328" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2328', 'm', 'link-638');">m</a></tt> <tt class="py-keyword">and</tt> <tt id="link-2329" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2329', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'e'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> <tt class="py-string">'txt'</tt> </tt>
<a name="L5263"></a><tt class="py-lineno">5263</tt>  <tt class="py-line">        <tt class="py-name">uuid_key</tt> <tt class="py-op">=</tt> <tt id="link-2330" class="py-name"><a title="web2py.gluon.utils.web2py_uuid" class="py-name" href="#" onclick="return doclink('link-2330', 'web2py_uuid', 'link-14');">web2py_uuid</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'-'</tt><tt class="py-op">,</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">16</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt>
<a name="L5264"></a><tt class="py-lineno">5264</tt>  <tt class="py-line">        <tt class="py-name">encoded_filename</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b16encode</tt><tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2331" class="py-name"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-2331', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5265"></a><tt class="py-lineno">5265</tt>  <tt class="py-line">        <tt class="py-name">newfilename</tt> <tt class="py-op">=</tt> <tt class="py-string">'%s.%s.%s.%s'</tt> <tt class="py-op">%</tt> \ </tt>
<a name="L5266"></a><tt class="py-lineno">5266</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2332" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2332', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">uuid_key</tt><tt class="py-op">,</tt> <tt class="py-name">encoded_filename</tt><tt class="py-op">)</tt> </tt>
<a name="L5267"></a><tt class="py-lineno">5267</tt>  <tt class="py-line">        <tt class="py-name">newfilename</tt> <tt class="py-op">=</tt> <tt class="py-name">newfilename</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">200</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-string">'.'</tt> <tt class="py-op">+</tt> <tt class="py-name">extension</tt> </tt>
<a name="L5268"></a><tt class="py-lineno">5268</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">,</tt><tt id="link-2333" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2333', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5269"></a><tt class="py-lineno">5269</tt>  <tt class="py-line">            <tt class="py-name">blob_uploadfield_name</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> </tt>
<a name="L5270"></a><tt class="py-lineno">5270</tt>  <tt class="py-line">            <tt id="link-2334" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2334', 'keys', 'link-269');">keys</a></tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">.</tt><tt id="link-2335" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2335', 'name', 'link-119');">name</a></tt><tt class="py-op">:</tt> <tt class="py-name">newfilename</tt><tt class="py-op">,</tt> </tt>
<a name="L5271"></a><tt class="py-lineno">5271</tt>  <tt class="py-line">                  <tt class="py-name">blob_uploadfield_name</tt><tt class="py-op">:</tt> <tt class="py-name">file</tt><tt class="py-op">.</tt><tt id="link-2336" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.read
web2py.gluon.debug.Pipe.read
web2py.gluon.languages.lazyT.read
web2py.gluon.rocket.ChunkedReader.read
web2py.gluon.tools.Crud.read" class="py-name" href="#" onclick="return doclink('link-2336', 'read', 'link-1110');">read</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">}</tt> </tt>
<a name="L5272"></a><tt class="py-lineno">5272</tt>  <tt class="py-line">            <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">.</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt id="link-2337" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.insert
web2py.gluon.dal.CouchDBAdapter.insert
web2py.gluon.dal.GoogleDatastoreAdapter.insert
web2py.gluon.dal.MongoDBAdapter.insert
web2py.gluon.dal.Table.insert
web2py.gluon.html.DIV.insert
web2py.gluon.template.Content.insert" class="py-name" href="#" onclick="return doclink('link-2337', 'insert', 'link-338');">insert</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt id="link-2338" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2338', 'keys', 'link-269');">keys</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5273"></a><tt class="py-lineno">5273</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> <tt class="py-op">==</tt> <tt class="py-name">True</tt><tt class="py-op">:</tt> </tt>
<a name="L5274"></a><tt class="py-lineno">5274</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">path</tt><tt class="py-op">:</tt> </tt>
<a name="L5275"></a><tt class="py-lineno">5275</tt>  <tt class="py-line">                <tt class="py-keyword">pass</tt> </tt>
<a name="L5276"></a><tt class="py-lineno">5276</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfolder</tt><tt class="py-op">:</tt> </tt>
<a name="L5277"></a><tt class="py-lineno">5277</tt>  <tt class="py-line">                <tt class="py-name">path</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfolder</tt> </tt>
<a name="L5278"></a><tt class="py-lineno">5278</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">:</tt> </tt>
<a name="L5279"></a><tt class="py-lineno">5279</tt>  <tt class="py-line">                <tt class="py-name">path</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2339" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2339', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">,</tt> <tt class="py-string">'..'</tt><tt class="py-op">,</tt> <tt class="py-string">'uploads'</tt><tt class="py-op">)</tt> </tt>
<a name="L5280"></a><tt class="py-lineno">5280</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5281"></a><tt class="py-lineno">5281</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">RuntimeError</tt><tt class="py-op">,</tt> <tt class="py-string">"you must specify a Field(...,uploadfolder=...)"</tt> </tt>
<a name="L5282"></a><tt class="py-lineno">5282</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadseparate</tt><tt class="py-op">:</tt> </tt>
<a name="L5283"></a><tt class="py-lineno">5283</tt>  <tt class="py-line">                <tt class="py-name">path</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2340" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2340', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">,</tt><tt class="py-string">"%s.%s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_tablename</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2341" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2341', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">uuid_key</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5284"></a><tt class="py-lineno">5284</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2342" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-2342', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5285"></a><tt class="py-lineno">5285</tt>  <tt class="py-line">                <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">makedirs</tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">)</tt> </tt>
<a name="L5286"></a><tt class="py-lineno">5286</tt>  <tt class="py-line">            <tt class="py-name">pathfilename</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2343" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2343', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">,</tt> <tt class="py-name">newfilename</tt><tt class="py-op">)</tt> </tt>
<a name="L5287"></a><tt class="py-lineno">5287</tt>  <tt class="py-line">            <tt class="py-name">dest_file</tt> <tt class="py-op">=</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">pathfilename</tt><tt class="py-op">,</tt> <tt class="py-string">'wb'</tt><tt class="py-op">)</tt> </tt>
<a name="L5288"></a><tt class="py-lineno">5288</tt>  <tt class="py-line">            <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L5289"></a><tt class="py-lineno">5289</tt>  <tt class="py-line">                <tt class="py-name">shutil</tt><tt class="py-op">.</tt><tt class="py-name">copyfileobj</tt><tt class="py-op">(</tt><tt class="py-name">file</tt><tt class="py-op">,</tt> <tt class="py-name">dest_file</tt><tt class="py-op">)</tt> </tt>
<a name="L5290"></a><tt class="py-lineno">5290</tt>  <tt class="py-line">            <tt class="py-keyword">finally</tt><tt class="py-op">:</tt> </tt>
<a name="L5291"></a><tt class="py-lineno">5291</tt>  <tt class="py-line">                <tt class="py-name">dest_file</tt><tt class="py-op">.</tt><tt id="link-2344" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.close
web2py.gluon.dal.DatabaseStoredFile.close
web2py.gluon.dal.NoSQLAdapter.close
web2py.gluon.rocket.Connection.close" class="py-name" href="#" onclick="return doclink('link-2344', 'close', 'link-179');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5292"></a><tt class="py-lineno">5292</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">newfilename</tt> </tt>
</div><a name="L5293"></a><tt class="py-lineno">5293</tt>  <tt class="py-line"> </tt>
<a name="Field.retrieve"></a><div id="Field.retrieve-def"><a name="L5294"></a><tt class="py-lineno">5294</tt> <a class="py-toggle" href="#" id="Field.retrieve-toggle" onclick="return toggle('Field.retrieve');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#retrieve">retrieve</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">name</tt><tt class="py-op">,</tt> <tt class="py-param">path</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.retrieve-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.retrieve-expanded"><a name="L5295"></a><tt class="py-lineno">5295</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_retrieve</tt><tt class="py-op">:</tt> </tt>
<a name="L5296"></a><tt class="py-lineno">5296</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">custom_retrieve</tt><tt class="py-op">(</tt><tt id="link-2345" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2345', 'name', 'link-119');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">path</tt><tt class="py-op">)</tt> </tt>
<a name="L5297"></a><tt class="py-lineno">5297</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt id="link-2346" class="py-name"><a title="web2py.gluon.http" class="py-name" href="#" onclick="return doclink('link-2346', 'http', 'link-1530');">http</a></tt> </tt>
<a name="L5298"></a><tt class="py-lineno">5298</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">authorize</tt> <tt class="py-keyword">or</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5299"></a><tt class="py-lineno">5299</tt>  <tt class="py-line">            <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">(</tt><tt class="py-name">self</tt> <tt class="py-op">==</tt> <tt id="link-2347" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2347', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2348" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2348', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2349" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2349', 'first', 'link-297');">first</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5300"></a><tt class="py-lineno">5300</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">row</tt><tt class="py-op">:</tt> </tt>
<a name="L5301"></a><tt class="py-lineno">5301</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt id="link-2350" class="py-name"><a title="web2py.gluon.http" class="py-name" href="#" onclick="return doclink('link-2350', 'http', 'link-1530');">http</a></tt><tt class="py-op">.</tt><tt id="link-2351" class="py-name" targets="Class web2py.gluon.http.HTTP=web2py.gluon.http.HTTP-class.html"><a title="web2py.gluon.http.HTTP" class="py-name" href="#" onclick="return doclink('link-2351', 'HTTP', 'link-2351');">HTTP</a></tt><tt class="py-op">(</tt><tt class="py-number">404</tt><tt class="py-op">)</tt> </tt>
<a name="L5302"></a><tt class="py-lineno">5302</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">authorize</tt> <tt class="py-keyword">and</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">authorize</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5303"></a><tt class="py-lineno">5303</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt id="link-2352" class="py-name"><a title="web2py.gluon.http" class="py-name" href="#" onclick="return doclink('link-2352', 'http', 'link-1530');">http</a></tt><tt class="py-op">.</tt><tt id="link-2353" class="py-name"><a title="web2py.gluon.http.HTTP" class="py-name" href="#" onclick="return doclink('link-2353', 'HTTP', 'link-2351');">HTTP</a></tt><tt class="py-op">(</tt><tt class="py-number">403</tt><tt class="py-op">)</tt> </tt>
<a name="L5304"></a><tt class="py-lineno">5304</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L5305"></a><tt class="py-lineno">5305</tt>  <tt class="py-line">            <tt id="link-2354" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2354', 'm', 'link-638');">m</a></tt> <tt class="py-op">=</tt> <tt id="link-2355" class="py-name"><a title="web2py.gluon.dal.regex_content" class="py-name" href="#" onclick="return doclink('link-2355', 'regex_content', 'link-30');">regex_content</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt id="link-2356" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2356', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5306"></a><tt class="py-lineno">5306</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2357" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2357', 'm', 'link-638');">m</a></tt> <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">isattachment</tt><tt class="py-op">:</tt> </tt>
<a name="L5307"></a><tt class="py-lineno">5307</tt>  <tt class="py-line">                <tt class="py-keyword">raise</tt> <tt class="py-name">TypeError</tt><tt class="py-op">,</tt> <tt class="py-string">'Can\'t retrieve %s'</tt> <tt class="py-op">%</tt> <tt id="link-2358" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2358', 'name', 'link-119');">name</a></tt> </tt>
<a name="L5308"></a><tt class="py-lineno">5308</tt>  <tt class="py-line">            <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b16decode</tt><tt class="py-op">(</tt><tt id="link-2359" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2359', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'name'</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L5309"></a><tt class="py-lineno">5309</tt>  <tt class="py-line">            <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt id="link-2360" class="py-name"><a title="web2py.gluon.dal.regex_cleanup_fn" class="py-name" href="#" onclick="return doclink('link-2360', 'regex_cleanup_fn', 'link-31');">regex_cleanup_fn</a></tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt><tt class="py-string">'_'</tt><tt class="py-op">,</tt> <tt class="py-name">filename</tt><tt class="py-op">)</tt> </tt>
<a name="L5310"></a><tt class="py-lineno">5310</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt> <tt class="py-op">(</tt><tt class="py-name">TypeError</tt><tt class="py-op">,</tt> <tt class="py-name">AttributeError</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5311"></a><tt class="py-lineno">5311</tt>  <tt class="py-line">            <tt class="py-name">filename</tt> <tt class="py-op">=</tt> <tt id="link-2361" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2361', 'name', 'link-119');">name</a></tt> </tt>
<a name="L5312"></a><tt class="py-lineno">5312</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">,</tt> <tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt>  <tt class="py-comment"># ## if file is in DB</tt> </tt>
<a name="L5313"></a><tt class="py-lineno">5313</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-name">cStringIO</tt><tt class="py-op">.</tt><tt class="py-name">StringIO</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">]</tt> <tt class="py-keyword">or</tt> <tt class="py-string">''</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L5314"></a><tt class="py-lineno">5314</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">,</tt><tt id="link-2362" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2362', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5315"></a><tt class="py-lineno">5315</tt>  <tt class="py-line">            <tt class="py-name">blob_uploadfield_name</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> </tt>
<a name="L5316"></a><tt class="py-lineno">5316</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> <tt class="py-op">==</tt> <tt id="link-2363" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2363', 'name', 'link-119');">name</a></tt> </tt>
<a name="L5317"></a><tt class="py-lineno">5317</tt>  <tt class="py-line">            <tt class="py-name">data</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt><tt class="py-op">.</tt><tt class="py-name">table</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-name">blob_uploadfield_name</tt><tt class="py-op">]</tt> </tt>
<a name="L5318"></a><tt class="py-lineno">5318</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-name">cStringIO</tt><tt class="py-op">.</tt><tt class="py-name">StringIO</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L5319"></a><tt class="py-lineno">5319</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5320"></a><tt class="py-lineno">5320</tt>  <tt class="py-line">            <tt class="py-comment"># ## if file is on filesystem</tt> </tt>
<a name="L5321"></a><tt class="py-lineno">5321</tt>  <tt class="py-line"><tt class="py-comment"></tt>            <tt class="py-keyword">if</tt> <tt class="py-name">path</tt><tt class="py-op">:</tt> </tt>
<a name="L5322"></a><tt class="py-lineno">5322</tt>  <tt class="py-line">                <tt class="py-keyword">pass</tt> </tt>
<a name="L5323"></a><tt class="py-lineno">5323</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfolder</tt><tt class="py-op">:</tt> </tt>
<a name="L5324"></a><tt class="py-lineno">5324</tt>  <tt class="py-line">                <tt class="py-name">path</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadfolder</tt> </tt>
<a name="L5325"></a><tt class="py-lineno">5325</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5326"></a><tt class="py-lineno">5326</tt>  <tt class="py-line">                <tt class="py-name">path</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2364" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2364', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">,</tt> <tt class="py-string">'..'</tt><tt class="py-op">,</tt> <tt class="py-string">'uploads'</tt><tt class="py-op">)</tt> </tt>
<a name="L5327"></a><tt class="py-lineno">5327</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">uploadseparate</tt><tt class="py-op">:</tt> </tt>
<a name="L5328"></a><tt class="py-lineno">5328</tt>  <tt class="py-line">                <tt class="py-name">t</tt> <tt class="py-op">=</tt> <tt id="link-2365" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2365', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'table'</tt><tt class="py-op">)</tt> </tt>
<a name="L5329"></a><tt class="py-lineno">5329</tt>  <tt class="py-line">                <tt class="py-name">f</tt> <tt class="py-op">=</tt> <tt id="link-2366" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2366', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'field'</tt><tt class="py-op">)</tt> </tt>
<a name="L5330"></a><tt class="py-lineno">5330</tt>  <tt class="py-line">                <tt id="link-2367" class="py-name" targets="Function web2py.gluon.rocket.u()=web2py.gluon.rocket-module.html#u"><a title="web2py.gluon.rocket.u" class="py-name" href="#" onclick="return doclink('link-2367', 'u', 'link-2367');">u</a></tt> <tt class="py-op">=</tt> <tt id="link-2368" class="py-name"><a title="web2py.gluon.languages.lazyT.m" class="py-name" href="#" onclick="return doclink('link-2368', 'm', 'link-638');">m</a></tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-string">'uuidkey'</tt><tt class="py-op">)</tt> </tt>
<a name="L5331"></a><tt class="py-lineno">5331</tt>  <tt class="py-line">                <tt class="py-name">path</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2369" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2369', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">,</tt><tt class="py-string">"%s.%s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt><tt class="py-name">f</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt id="link-2370" class="py-name"><a title="web2py.gluon.rocket.u" class="py-name" href="#" onclick="return doclink('link-2370', 'u', 'link-2367');">u</a></tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5332"></a><tt class="py-lineno">5332</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">filename</tt><tt class="py-op">,</tt> <tt class="py-name">open</tt><tt class="py-op">(</tt><tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2371" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2371', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">path</tt><tt class="py-op">,</tt> <tt id="link-2372" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2372', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-string">'rb'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5333"></a><tt class="py-lineno">5333</tt>  <tt class="py-line"> </tt>
<a name="Field.formatter"></a><div id="Field.formatter-def"><a name="L5334"></a><tt class="py-lineno">5334</tt> <a class="py-toggle" href="#" id="Field.formatter-toggle" onclick="return toggle('Field.formatter');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#formatter">formatter</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.formatter-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.formatter-expanded"><a name="L5335"></a><tt class="py-lineno">5335</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">value</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">or</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2373" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2373', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5336"></a><tt class="py-lineno">5336</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">value</tt> </tt>
<a name="L5337"></a><tt class="py-lineno">5337</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2374" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2374', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5338"></a><tt class="py-lineno">5338</tt>  <tt class="py-line">            <tt id="link-2375" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2375', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2376" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2376', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">]</tt> </tt>
<a name="L5339"></a><tt class="py-lineno">5339</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2377" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2377', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5340"></a><tt class="py-lineno">5340</tt>  <tt class="py-line">            <tt id="link-2378" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2378', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt class="py-name">list</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2379" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2379', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5341"></a><tt class="py-lineno">5341</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5342"></a><tt class="py-lineno">5342</tt>  <tt class="py-line">            <tt id="link-2380" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2380', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt class="py-name">copy</tt><tt class="py-op">.</tt><tt class="py-name">copy</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2381" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2381', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5343"></a><tt class="py-lineno">5343</tt>  <tt class="py-line">        <tt id="link-2382" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2382', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">.</tt><tt class="py-name">reverse</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5344"></a><tt class="py-lineno">5344</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt id="link-2383" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2383', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5345"></a><tt class="py-lineno">5345</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">item</tt><tt class="py-op">,</tt> <tt class="py-string">'formatter'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5346"></a><tt class="py-lineno">5346</tt>  <tt class="py-line">                <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">item</tt><tt class="py-op">.</tt><tt id="link-2384" class="py-name" targets="Method web2py.gluon.dal.Field.formatter()=web2py.gluon.dal.Field-class.html#formatter,Method web2py.gluon.validators.IS_DATE.formatter()=web2py.gluon.validators.IS_DATE-class.html#formatter,Method web2py.gluon.validators.IS_DATETIME.formatter()=web2py.gluon.validators.IS_DATETIME-class.html#formatter,Method web2py.gluon.validators.IS_DECIMAL_IN_RANGE.formatter()=web2py.gluon.validators.IS_DECIMAL_IN_RANGE-class.html#formatter,Method web2py.gluon.validators.IS_EMPTY_OR.formatter()=web2py.gluon.validators.IS_EMPTY_OR-class.html#formatter,Method web2py.gluon.validators.IS_FLOAT_IN_RANGE.formatter()=web2py.gluon.validators.IS_FLOAT_IN_RANGE-class.html#formatter,Method web2py.gluon.validators.Validator.formatter()=web2py.gluon.validators.Validator-class.html#formatter"><a title="web2py.gluon.dal.Field.formatter
web2py.gluon.validators.IS_DATE.formatter
web2py.gluon.validators.IS_DATETIME.formatter
web2py.gluon.validators.IS_DECIMAL_IN_RANGE.formatter
web2py.gluon.validators.IS_EMPTY_OR.formatter
web2py.gluon.validators.IS_FLOAT_IN_RANGE.formatter
web2py.gluon.validators.Validator.formatter" class="py-name" href="#" onclick="return doclink('link-2384', 'formatter', 'link-2384');">formatter</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L5347"></a><tt class="py-lineno">5347</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">value</tt> </tt>
</div><a name="L5348"></a><tt class="py-lineno">5348</tt>  <tt class="py-line"> </tt>
<a name="Field.validate"></a><div id="Field.validate-def"><a name="L5349"></a><tt class="py-lineno">5349</tt> <a class="py-toggle" href="#" id="Field.validate-toggle" onclick="return toggle('Field.validate');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#validate">validate</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.validate-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.validate-expanded"><a name="L5350"></a><tt class="py-lineno">5350</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2385" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2385', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5351"></a><tt class="py-lineno">5351</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L5352"></a><tt class="py-lineno">5352</tt>  <tt class="py-line">        <tt id="link-2386" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2386', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2387" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2387', 'requires', 'link-1616');">requires</a></tt> </tt>
<a name="L5353"></a><tt class="py-lineno">5353</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-2388" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2388', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt> <tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5354"></a><tt class="py-lineno">5354</tt>  <tt class="py-line">            <tt id="link-2389" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2389', 'requires', 'link-1616');">requires</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt id="link-2390" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2390', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">]</tt> </tt>
<a name="L5355"></a><tt class="py-lineno">5355</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">validator</tt> <tt class="py-keyword">in</tt> <tt id="link-2391" class="py-name"><a title="web2py.gluon.tools.Auth.requires" class="py-name" href="#" onclick="return doclink('link-2391', 'requires', 'link-1616');">requires</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5356"></a><tt class="py-lineno">5356</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt id="link-2392" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-2392', 'error', 'link-884');">error</a></tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">validator</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L5357"></a><tt class="py-lineno">5357</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt id="link-2393" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-2393', 'error', 'link-884');">error</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5358"></a><tt class="py-lineno">5358</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt id="link-2394" class="py-name"><a title="web2py.gluon.tools.Service.error
web2py.gluon.widget.web2pyDialog.error" class="py-name" href="#" onclick="return doclink('link-2394', 'error', 'link-884');">error</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5359"></a><tt class="py-lineno">5359</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5360"></a><tt class="py-lineno">5360</tt>  <tt class="py-line"> </tt>
<a name="Field.count"></a><div id="Field.count-def"><a name="L5361"></a><tt class="py-lineno">5361</tt> <a class="py-toggle" href="#" id="Field.count-toggle" onclick="return toggle('Field.count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#count">count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.count-expanded"><a name="L5362"></a><tt class="py-lineno">5362</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2395" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2395', 'Expression', 'link-431');">Expression</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2396" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.AGGREGATE
web2py.gluon.dal.NoSQLAdapter.AGGREGATE" class="py-name" href="#" onclick="return doclink('link-2396', 'AGGREGATE', 'link-2206');">AGGREGATE</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">,</tt> <tt class="py-string">'COUNT'</tt><tt class="py-op">,</tt> <tt class="py-string">'integer'</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5363"></a><tt class="py-lineno">5363</tt>  <tt class="py-line"> </tt>
<a name="Field.__nonzero__"></a><div id="Field.__nonzero__-def"><a name="L5364"></a><tt class="py-lineno">5364</tt> <a class="py-toggle" href="#" id="Field.__nonzero__-toggle" onclick="return toggle('Field.__nonzero__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#__nonzero__">__nonzero__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.__nonzero__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.__nonzero__-expanded"><a name="L5365"></a><tt class="py-lineno">5365</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">True</tt> </tt>
</div><a name="L5366"></a><tt class="py-lineno">5366</tt>  <tt class="py-line"> </tt>
<a name="Field.__str__"></a><div id="Field.__str__-def"><a name="L5367"></a><tt class="py-lineno">5367</tt> <a class="py-toggle" href="#" id="Field.__str__-toggle" onclick="return toggle('Field.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Field-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Field.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Field.__str__-expanded"><a name="L5368"></a><tt class="py-lineno">5368</tt>  <tt class="py-line">        <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt>
<a name="L5369"></a><tt class="py-lineno">5369</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2397" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2397', 'name', 'link-119');">name</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5370"></a><tt class="py-lineno">5370</tt>  <tt class="py-line">        <tt class="py-keyword">except</tt><tt class="py-op">:</tt> </tt>
<a name="L5371"></a><tt class="py-lineno">5371</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-string">'&lt;no table&gt;.%s'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2398" class="py-name"><a title="web2py.gluon.import_all.name" class="py-name" href="#" onclick="return doclink('link-2398', 'name', 'link-119');">name</a></tt> </tt>
</div></div><a name="L5372"></a><tt class="py-lineno">5372</tt>  <tt class="py-line"> </tt>
<a name="L5373"></a><tt class="py-lineno">5373</tt>  <tt class="py-line"> </tt>
<a name="Query"></a><div id="Query-def"><a name="L5374"></a><tt class="py-lineno">5374</tt> <a class="py-toggle" href="#" id="Query-toggle" onclick="return toggle('Query');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Query-class.html">Query</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Query-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Query-expanded"><a name="L5375"></a><tt class="py-lineno">5375</tt>  <tt class="py-line"> </tt>
<a name="L5376"></a><tt class="py-lineno">5376</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L5377"></a><tt class="py-lineno">5377</tt>  <tt class="py-line"><tt class="py-docstring">    a query object necessary to define a set.</tt> </tt>
<a name="L5378"></a><tt class="py-lineno">5378</tt>  <tt class="py-line"><tt class="py-docstring">    it can be stored or can be passed to DAL.__call__() to obtain a Set</tt> </tt>
<a name="L5379"></a><tt class="py-lineno">5379</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5380"></a><tt class="py-lineno">5380</tt>  <tt class="py-line"><tt class="py-docstring">    Example::</tt> </tt>
<a name="L5381"></a><tt class="py-lineno">5381</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5382"></a><tt class="py-lineno">5382</tt>  <tt class="py-line"><tt class="py-docstring">        query = db.users.name=='Max'</tt> </tt>
<a name="L5383"></a><tt class="py-lineno">5383</tt>  <tt class="py-line"><tt class="py-docstring">        set = db(query)</tt> </tt>
<a name="L5384"></a><tt class="py-lineno">5384</tt>  <tt class="py-line"><tt class="py-docstring">        records = set.select()</tt> </tt>
<a name="L5385"></a><tt class="py-lineno">5385</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5386"></a><tt class="py-lineno">5386</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L5387"></a><tt class="py-lineno">5387</tt>  <tt class="py-line"> </tt>
<a name="Query.__init__"></a><div id="Query.__init__-def"><a name="L5388"></a><tt class="py-lineno">5388</tt> <a class="py-toggle" href="#" id="Query.__init__-toggle" onclick="return toggle('Query.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Query-class.html#__init__">__init__</a><tt class="py-op">(</tt> </tt>
<a name="L5389"></a><tt class="py-lineno">5389</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L5390"></a><tt class="py-lineno">5390</tt>  <tt class="py-line">        <tt class="py-param">db</tt><tt class="py-op">,</tt> </tt>
<a name="L5391"></a><tt class="py-lineno">5391</tt>  <tt class="py-line">        <tt class="py-param">op</tt><tt class="py-op">,</tt> </tt>
<a name="L5392"></a><tt class="py-lineno">5392</tt>  <tt class="py-line">        <tt class="py-param">first</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5393"></a><tt class="py-lineno">5393</tt>  <tt class="py-line">        <tt class="py-param">second</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5394"></a><tt class="py-lineno">5394</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Query.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Query.__init__-expanded"><a name="L5395"></a><tt class="py-lineno">5395</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L5396"></a><tt class="py-lineno">5396</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt> <tt class="py-op">=</tt> <tt class="py-name">op</tt> </tt>
<a name="L5397"></a><tt class="py-lineno">5397</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2399" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2399', 'first', 'link-297');">first</a></tt> <tt class="py-op">=</tt> <tt id="link-2400" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2400', 'first', 'link-297');">first</a></tt> </tt>
<a name="L5398"></a><tt class="py-lineno">5398</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">second</tt> <tt class="py-op">=</tt> <tt class="py-name">second</tt> </tt>
</div><a name="L5399"></a><tt class="py-lineno">5399</tt>  <tt class="py-line"> </tt>
<a name="Query.__str__"></a><div id="Query.__str__-def"><a name="L5400"></a><tt class="py-lineno">5400</tt> <a class="py-toggle" href="#" id="Query.__str__-toggle" onclick="return toggle('Query.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Query-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Query.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Query.__str__-expanded"><a name="L5401"></a><tt class="py-lineno">5401</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2401" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.expand
web2py.gluon.dal.CouchDBAdapter.expand
web2py.gluon.dal.GoogleDatastoreAdapter.expand" class="py-name" href="#" onclick="return doclink('link-2401', 'expand', 'link-296');">expand</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5402"></a><tt class="py-lineno">5402</tt>  <tt class="py-line"> </tt>
<a name="Query.__and__"></a><div id="Query.__and__-def"><a name="L5403"></a><tt class="py-lineno">5403</tt> <a class="py-toggle" href="#" id="Query.__and__-toggle" onclick="return toggle('Query.__and__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Query-class.html#__and__">__and__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Query.__and__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Query.__and__-expanded"><a name="L5404"></a><tt class="py-lineno">5404</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2402" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2402', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2403" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.AND()=web2py.gluon.dal.BaseAdapter-class.html#AND,Method web2py.gluon.dal.CouchDBAdapter.AND()=web2py.gluon.dal.CouchDBAdapter-class.html#AND,Method web2py.gluon.dal.GoogleDatastoreAdapter.AND()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#AND,Method web2py.gluon.dal.NoSQLAdapter.AND()=web2py.gluon.dal.NoSQLAdapter-class.html#AND"><a title="web2py.gluon.dal.BaseAdapter.AND
web2py.gluon.dal.CouchDBAdapter.AND
web2py.gluon.dal.GoogleDatastoreAdapter.AND
web2py.gluon.dal.NoSQLAdapter.AND" class="py-name" href="#" onclick="return doclink('link-2403', 'AND', 'link-2403');">AND</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5405"></a><tt class="py-lineno">5405</tt>  <tt class="py-line"> </tt>
<a name="Query.__or__"></a><div id="Query.__or__-def"><a name="L5406"></a><tt class="py-lineno">5406</tt> <a class="py-toggle" href="#" id="Query.__or__-toggle" onclick="return toggle('Query.__or__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Query-class.html#__or__">__or__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Query.__or__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Query.__or__-expanded"><a name="L5407"></a><tt class="py-lineno">5407</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2404" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2404', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2405" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.OR()=web2py.gluon.dal.BaseAdapter-class.html#OR,Method web2py.gluon.dal.CouchDBAdapter.OR()=web2py.gluon.dal.CouchDBAdapter-class.html#OR,Method web2py.gluon.dal.NoSQLAdapter.OR()=web2py.gluon.dal.NoSQLAdapter-class.html#OR"><a title="web2py.gluon.dal.BaseAdapter.OR
web2py.gluon.dal.CouchDBAdapter.OR
web2py.gluon.dal.NoSQLAdapter.OR" class="py-name" href="#" onclick="return doclink('link-2405', 'OR', 'link-2405');">OR</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">other</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5408"></a><tt class="py-lineno">5408</tt>  <tt class="py-line"> </tt>
<a name="Query.__invert__"></a><div id="Query.__invert__-def"><a name="L5409"></a><tt class="py-lineno">5409</tt> <a class="py-toggle" href="#" id="Query.__invert__-toggle" onclick="return toggle('Query.__invert__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Query-class.html#__invert__">__invert__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Query.__invert__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Query.__invert__-expanded"><a name="L5410"></a><tt class="py-lineno">5410</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">op</tt><tt class="py-op">==</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2406" class="py-name" targets="Method web2py.gluon.dal.BaseAdapter.NOT()=web2py.gluon.dal.BaseAdapter-class.html#NOT,Method web2py.gluon.dal.GoogleDatastoreAdapter.NOT()=web2py.gluon.dal.GoogleDatastoreAdapter-class.html#NOT"><a title="web2py.gluon.dal.BaseAdapter.NOT
web2py.gluon.dal.GoogleDatastoreAdapter.NOT" class="py-name" href="#" onclick="return doclink('link-2406', 'NOT', 'link-2406');">NOT</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5411"></a><tt class="py-lineno">5411</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2407" class="py-name"><a title="web2py.gluon.dal.Rows.first" class="py-name" href="#" onclick="return doclink('link-2407', 'first', 'link-297');">first</a></tt> </tt>
<a name="L5412"></a><tt class="py-lineno">5412</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2408" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2408', 'Query', 'link-432');">Query</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2409" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.NOT
web2py.gluon.dal.GoogleDatastoreAdapter.NOT" class="py-name" href="#" onclick="return doclink('link-2409', 'NOT', 'link-2406');">NOT</a></tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L5413"></a><tt class="py-lineno">5413</tt>  <tt class="py-line"> </tt>
<a name="L5414"></a><tt class="py-lineno">5414</tt>  <tt class="py-line"> </tt>
<a name="L5415"></a><tt class="py-lineno">5415</tt>  <tt class="py-line"><tt id="link-2410" class="py-name" targets="Variable web2py.gluon.dal.regex_quotes=web2py.gluon.dal-module.html#regex_quotes"><a title="web2py.gluon.dal.regex_quotes" class="py-name" href="#" onclick="return doclink('link-2410', 'regex_quotes', 'link-2410');">regex_quotes</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">"'[^']*'"</tt><tt class="py-op">)</tt> </tt>
<a name="L5416"></a><tt class="py-lineno">5416</tt>  <tt class="py-line"> </tt>
<a name="L5417"></a><tt class="py-lineno">5417</tt>  <tt class="py-line"> </tt>
<a name="xorify"></a><div id="xorify-def"><a name="L5418"></a><tt class="py-lineno">5418</tt> <a class="py-toggle" href="#" id="xorify-toggle" onclick="return toggle('xorify');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#xorify">xorify</a><tt class="py-op">(</tt><tt class="py-param">orderby</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="xorify-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="xorify-expanded"><a name="L5419"></a><tt class="py-lineno">5419</tt>  <tt class="py-line">    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">orderby</tt><tt class="py-op">:</tt> </tt>
<a name="L5420"></a><tt class="py-lineno">5420</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L5421"></a><tt class="py-lineno">5421</tt>  <tt class="py-line">    <tt class="py-name">orderby2</tt> <tt class="py-op">=</tt> <tt class="py-name">orderby</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
<a name="L5422"></a><tt class="py-lineno">5422</tt>  <tt class="py-line">    <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">orderby</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L5423"></a><tt class="py-lineno">5423</tt>  <tt class="py-line">        <tt class="py-name">orderby2</tt> <tt class="py-op">=</tt> <tt class="py-name">orderby2</tt> <tt class="py-op">|</tt> <tt class="py-name">item</tt> </tt>
<a name="L5424"></a><tt class="py-lineno">5424</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">orderby2</tt> </tt>
</div><a name="L5425"></a><tt class="py-lineno">5425</tt>  <tt class="py-line"> </tt>
<a name="L5426"></a><tt class="py-lineno">5426</tt>  <tt class="py-line"> </tt>
<a name="Set"></a><div id="Set-def"><a name="L5427"></a><tt class="py-lineno">5427</tt> <a class="py-toggle" href="#" id="Set-toggle" onclick="return toggle('Set');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html">Set</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Set-expanded"><a name="L5428"></a><tt class="py-lineno">5428</tt>  <tt class="py-line"> </tt>
<a name="L5429"></a><tt class="py-lineno">5429</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L5430"></a><tt class="py-lineno">5430</tt>  <tt class="py-line"><tt class="py-docstring">    a Set represents a set of records in the database,</tt> </tt>
<a name="L5431"></a><tt class="py-lineno">5431</tt>  <tt class="py-line"><tt class="py-docstring">    the records are identified by the query=Query(...) object.</tt> </tt>
<a name="L5432"></a><tt class="py-lineno">5432</tt>  <tt class="py-line"><tt class="py-docstring">    normally the Set is generated by DAL.__call__(Query(...))</tt> </tt>
<a name="L5433"></a><tt class="py-lineno">5433</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5434"></a><tt class="py-lineno">5434</tt>  <tt class="py-line"><tt class="py-docstring">    given a set, for example</tt> </tt>
<a name="L5435"></a><tt class="py-lineno">5435</tt>  <tt class="py-line"><tt class="py-docstring">       set = db(db.users.name=='Max')</tt> </tt>
<a name="L5436"></a><tt class="py-lineno">5436</tt>  <tt class="py-line"><tt class="py-docstring">    you can:</tt> </tt>
<a name="L5437"></a><tt class="py-lineno">5437</tt>  <tt class="py-line"><tt class="py-docstring">       set.update(db.users.name='Massimo')</tt> </tt>
<a name="L5438"></a><tt class="py-lineno">5438</tt>  <tt class="py-line"><tt class="py-docstring">       set.delete() # all elements in the set</tt> </tt>
<a name="L5439"></a><tt class="py-lineno">5439</tt>  <tt class="py-line"><tt class="py-docstring">       set.select(orderby=db.users.id, groupby=db.users.name, limitby=(0,10))</tt> </tt>
<a name="L5440"></a><tt class="py-lineno">5440</tt>  <tt class="py-line"><tt class="py-docstring">    and take subsets:</tt> </tt>
<a name="L5441"></a><tt class="py-lineno">5441</tt>  <tt class="py-line"><tt class="py-docstring">       subset = set(db.users.id&lt;5)</tt> </tt>
<a name="L5442"></a><tt class="py-lineno">5442</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L5443"></a><tt class="py-lineno">5443</tt>  <tt class="py-line"> </tt>
<a name="Set.__init__"></a><div id="Set.__init__-def"><a name="L5444"></a><tt class="py-lineno">5444</tt> <a class="py-toggle" href="#" id="Set.__init__-toggle" onclick="return toggle('Set.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">db</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.__init__-expanded"><a name="L5445"></a><tt class="py-lineno">5445</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L5446"></a><tt class="py-lineno">5446</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> <tt class="py-comment"># for backward compatibility</tt> </tt>
<a name="L5447"></a><tt class="py-lineno">5447</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt> </tt>
</div><a name="L5448"></a><tt class="py-lineno">5448</tt>  <tt class="py-line"> </tt>
<a name="Set.__call__"></a><div id="Set.__call__-def"><a name="L5449"></a><tt class="py-lineno">5449</tt> <a class="py-toggle" href="#" id="Set.__call__-toggle" onclick="return toggle('Set.__call__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#__call__">__call__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">query</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.__call__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.__call__-expanded"><a name="L5450"></a><tt class="py-lineno">5450</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-2411" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2411', 'Table', 'link-1207');">Table</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5451"></a><tt class="py-lineno">5451</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">&gt;</tt><tt class="py-number">0</tt> </tt>
<a name="L5452"></a><tt class="py-lineno">5452</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt id="link-2412" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2412', 'Field', 'link-430');">Field</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5453"></a><tt class="py-lineno">5453</tt>  <tt class="py-line">            <tt class="py-name">query</tt> <tt class="py-op">=</tt> <tt class="py-name">query</tt><tt class="py-op">!=</tt><tt class="py-name">None</tt> </tt>
<a name="L5454"></a><tt class="py-lineno">5454</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">:</tt> </tt>
<a name="L5455"></a><tt class="py-lineno">5455</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-2413" class="py-name"><a title="web2py.gluon.dal.Set" class="py-name" href="#" onclick="return doclink('link-2413', 'Set', 'link-676');">Set</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt> <tt class="py-op">&amp;</tt> <tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L5456"></a><tt class="py-lineno">5456</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5457"></a><tt class="py-lineno">5457</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-2414" class="py-name"><a title="web2py.gluon.dal.Set" class="py-name" href="#" onclick="return doclink('link-2414', 'Set', 'link-676');">Set</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5458"></a><tt class="py-lineno">5458</tt>  <tt class="py-line"> </tt>
<a name="Set._count"></a><div id="Set._count-def"><a name="L5459"></a><tt class="py-lineno">5459</tt> <a class="py-toggle" href="#" id="Set._count-toggle" onclick="return toggle('Set._count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#_count">_count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set._count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set._count-expanded"><a name="L5460"></a><tt class="py-lineno">5460</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2415" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._count
web2py.gluon.dal.NoSQLAdapter._count
web2py.gluon.dal.Set._count" class="py-name" href="#" onclick="return doclink('link-2415', '_count', 'link-558');">_count</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">distinct</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5461"></a><tt class="py-lineno">5461</tt>  <tt class="py-line"> </tt>
<a name="Set._select"></a><div id="Set._select-def"><a name="L5462"></a><tt class="py-lineno">5462</tt> <a class="py-toggle" href="#" id="Set._select-toggle" onclick="return toggle('Set._select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#_select">_select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set._select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set._select-expanded"><a name="L5463"></a><tt class="py-lineno">5463</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2416" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._select
web2py.gluon.dal.CouchDBAdapter._select
web2py.gluon.dal.NoSQLAdapter._select
web2py.gluon.dal.Set._select" class="py-name" href="#" onclick="return doclink('link-2416', '_select', 'link-536');">_select</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt><tt class="py-name">attributes</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5464"></a><tt class="py-lineno">5464</tt>  <tt class="py-line"> </tt>
<a name="Set._delete"></a><div id="Set._delete-def"><a name="L5465"></a><tt class="py-lineno">5465</tt> <a class="py-toggle" href="#" id="Set._delete-toggle" onclick="return toggle('Set._delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#_delete">_delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set._delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set._delete-expanded"><a name="L5466"></a><tt class="py-lineno">5466</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2417" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-2417', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L5467"></a><tt class="py-lineno">5467</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2418" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._delete
web2py.gluon.dal.NoSQLAdapter._delete
web2py.gluon.dal.Set._delete" class="py-name" href="#" onclick="return doclink('link-2418', '_delete', 'link-461');">_delete</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5468"></a><tt class="py-lineno">5468</tt>  <tt class="py-line"> </tt>
<a name="Set._update"></a><div id="Set._update-def"><a name="L5469"></a><tt class="py-lineno">5469</tt> <a class="py-toggle" href="#" id="Set._update-toggle" onclick="return toggle('Set._update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#_update">_update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">update_fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set._update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set._update-expanded"><a name="L5470"></a><tt class="py-lineno">5470</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2419" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-2419', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L5471"></a><tt class="py-lineno">5471</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2420" class="py-name"><a title="web2py.gluon.dal.Table._listify" class="py-name" href="#" onclick="return doclink('link-2420', '_listify', 'link-2145');">_listify</a></tt><tt class="py-op">(</tt><tt class="py-name">update_fields</tt><tt class="py-op">,</tt><tt id="link-2421" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2421', 'update', 'link-507');">update</a></tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L5472"></a><tt class="py-lineno">5472</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2422" class="py-name"><a title="web2py.gluon.dal.BaseAdapter._update
web2py.gluon.dal.NoSQLAdapter._update
web2py.gluon.dal.Set._update" class="py-name" href="#" onclick="return doclink('link-2422', '_update', 'link-456');">_update</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5473"></a><tt class="py-lineno">5473</tt>  <tt class="py-line"> </tt>
<a name="Set.isempty"></a><div id="Set.isempty-def"><a name="L5474"></a><tt class="py-lineno">5474</tt> <a class="py-toggle" href="#" id="Set.isempty-toggle" onclick="return toggle('Set.isempty');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#isempty">isempty</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.isempty-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.isempty-expanded"><a name="L5475"></a><tt class="py-lineno">5475</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2423" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2423', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">limitby</tt><tt class="py-op">=</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt class="py-number">1</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5476"></a><tt class="py-lineno">5476</tt>  <tt class="py-line"> </tt>
<a name="Set.count"></a><div id="Set.count-def"><a name="L5477"></a><tt class="py-lineno">5477</tt> <a class="py-toggle" href="#" id="Set.count-toggle" onclick="return toggle('Set.count');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#count">count</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">distinct</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.count-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.count-expanded"><a name="L5478"></a><tt class="py-lineno">5478</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2424" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-2424', 'count', 'link-1426');">count</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">distinct</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5479"></a><tt class="py-lineno">5479</tt>  <tt class="py-line"> </tt>
<a name="Set.select"></a><div id="Set.select-def"><a name="L5480"></a><tt class="py-lineno">5480</tt> <a class="py-toggle" href="#" id="Set.select-toggle" onclick="return toggle('Set.select');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#select">select</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-param">fields</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">attributes</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.select-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.select-expanded"><a name="L5481"></a><tt class="py-lineno">5481</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2425" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2425', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">,</tt><tt class="py-name">attributes</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5482"></a><tt class="py-lineno">5482</tt>  <tt class="py-line"> </tt>
<a name="Set.delete"></a><div id="Set.delete-def"><a name="L5483"></a><tt class="py-lineno">5483</tt> <a class="py-toggle" href="#" id="Set.delete-toggle" onclick="return toggle('Set.delete');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#delete">delete</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.delete-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.delete-expanded"><a name="L5484"></a><tt class="py-lineno">5484</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2426" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-2426', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L5485"></a><tt class="py-lineno">5485</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2427" class="py-name" targets="Method web2py.gluon.dal.Set.delete_uploaded_files()=web2py.gluon.dal.Set-class.html#delete_uploaded_files"><a title="web2py.gluon.dal.Set.delete_uploaded_files" class="py-name" href="#" onclick="return doclink('link-2427', 'delete_uploaded_files', 'link-2427');">delete_uploaded_files</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5486"></a><tt class="py-lineno">5486</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2428" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.delete
web2py.gluon.dal.CouchDBAdapter.delete
web2py.gluon.dal.GoogleDatastoreAdapter.delete
web2py.gluon.dal.MongoDBAdapter.delete
web2py.gluon.dal.Set.delete
web2py.gluon.tools.Crud.delete" class="py-name" href="#" onclick="return doclink('link-2428', 'delete', 'link-469');">delete</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5487"></a><tt class="py-lineno">5487</tt>  <tt class="py-line"> </tt>
<a name="Set.update"></a><div id="Set.update-def"><a name="L5488"></a><tt class="py-lineno">5488</tt> <a class="py-toggle" href="#" id="Set.update-toggle" onclick="return toggle('Set.update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#update">update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">update_fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.update-expanded"><a name="L5489"></a><tt class="py-lineno">5489</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2429" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-2429', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L5490"></a><tt class="py-lineno">5490</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2430" class="py-name"><a title="web2py.gluon.dal.Table._listify" class="py-name" href="#" onclick="return doclink('link-2430', '_listify', 'link-2145');">_listify</a></tt><tt class="py-op">(</tt><tt class="py-name">update_fields</tt><tt class="py-op">,</tt><tt id="link-2431" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2431', 'update', 'link-507');">update</a></tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L5491"></a><tt class="py-lineno">5491</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L5492"></a><tt class="py-lineno">5492</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"No fields to update"</tt> </tt>
<a name="L5493"></a><tt class="py-lineno">5493</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2432" class="py-name"><a title="web2py.gluon.dal.Set.delete_uploaded_files" class="py-name" href="#" onclick="return doclink('link-2432', 'delete_uploaded_files', 'link-2427');">delete_uploaded_files</a></tt><tt class="py-op">(</tt><tt class="py-name">update_fields</tt><tt class="py-op">)</tt> </tt>
<a name="L5494"></a><tt class="py-lineno">5494</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2433" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2433', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5495"></a><tt class="py-lineno">5495</tt>  <tt class="py-line">     </tt>
<a name="Set.validate_and_update"></a><div id="Set.validate_and_update-def"><a name="L5496"></a><tt class="py-lineno">5496</tt> <a class="py-toggle" href="#" id="Set.validate_and_update-toggle" onclick="return toggle('Set.validate_and_update');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#validate_and_update">validate_and_update</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">update_fields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.validate_and_update-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.validate_and_update-expanded"><a name="L5497"></a><tt class="py-lineno">5497</tt>  <tt class="py-line">        <tt class="py-name">tablename</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2434" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.get_table" class="py-name" href="#" onclick="return doclink('link-2434', 'get_table', 'link-1381');">get_table</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt> </tt>
<a name="L5498"></a><tt class="py-lineno">5498</tt>  <tt class="py-line">        <tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt id="link-2435" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2435', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5499"></a><tt class="py-lineno">5499</tt>  <tt class="py-line">        <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">errors</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2436" class="py-name"><a title="web2py.gluon.dal.Table._validate
web2py.gluon.html.DIV._validate
web2py.gluon.html.INPUT._validate
web2py.gluon.tools.Recaptcha._validate" class="py-name" href="#" onclick="return doclink('link-2436', '_validate', 'link-2149');">_validate</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">update_fields</tt><tt class="py-op">)</tt>  </tt>
<a name="L5500"></a><tt class="py-lineno">5500</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt id="link-2437" class="py-name"><a title="web2py.gluon.dal.Table._listify" class="py-name" href="#" onclick="return doclink('link-2437', '_listify', 'link-2145');">_listify</a></tt><tt class="py-op">(</tt><tt class="py-name">update_fields</tt><tt class="py-op">,</tt><tt id="link-2438" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2438', 'update', 'link-507');">update</a></tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt> </tt>
<a name="L5501"></a><tt class="py-lineno">5501</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L5502"></a><tt class="py-lineno">5502</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">"No fields to update"</tt> </tt>
<a name="L5503"></a><tt class="py-lineno">5503</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2439" class="py-name"><a title="web2py.gluon.dal.Set.delete_uploaded_files" class="py-name" href="#" onclick="return doclink('link-2439', 'delete_uploaded_files', 'link-2427');">delete_uploaded_files</a></tt><tt class="py-op">(</tt><tt class="py-name">update_fields</tt><tt class="py-op">)</tt> </tt>
<a name="L5504"></a><tt class="py-lineno">5504</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">errors</tt><tt class="py-op">:</tt> </tt>
<a name="L5505"></a><tt class="py-lineno">5505</tt>  <tt class="py-line">            <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">updated</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2440" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2440', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">,</tt><tt class="py-name">fields</tt><tt class="py-op">)</tt> </tt>
<a name="L5506"></a><tt class="py-lineno">5506</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5507"></a><tt class="py-lineno">5507</tt>  <tt class="py-line">            <tt class="py-name">response</tt><tt class="py-op">.</tt><tt class="py-name">updated</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L5508"></a><tt class="py-lineno">5508</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">response</tt> </tt>
</div><a name="L5509"></a><tt class="py-lineno">5509</tt>  <tt class="py-line"> </tt>
<a name="Set.delete_uploaded_files"></a><div id="Set.delete_uploaded_files-def"><a name="L5510"></a><tt class="py-lineno">5510</tt> <a class="py-toggle" href="#" id="Set.delete_uploaded_files-toggle" onclick="return toggle('Set.delete_uploaded_files');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Set-class.html#delete_uploaded_files">delete_uploaded_files</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">upload_fields</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Set.delete_uploaded_files-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Set.delete_uploaded_files-expanded"><a name="L5511"></a><tt class="py-lineno">5511</tt>  <tt class="py-line">        <tt class="py-name">table</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt id="link-2441" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.tables
web2py.gluon.tools.Crud.tables" class="py-name" href="#" onclick="return doclink('link-2441', 'tables', 'link-313');">tables</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">query</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> </tt>
<a name="L5512"></a><tt class="py-lineno">5512</tt>  <tt class="py-line">        <tt class="py-comment"># ## mind uploadfield==True means file is not in DB</tt> </tt>
<a name="L5513"></a><tt class="py-lineno">5513</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-keyword">if</tt> <tt class="py-name">upload_fields</tt><tt class="py-op">:</tt> </tt>
<a name="L5514"></a><tt class="py-lineno">5514</tt>  <tt class="py-line">            <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">upload_fields</tt><tt class="py-op">.</tt><tt id="link-2442" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2442', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5515"></a><tt class="py-lineno">5515</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5516"></a><tt class="py-lineno">5516</tt>  <tt class="py-line">            <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt> </tt>
<a name="L5517"></a><tt class="py-lineno">5517</tt>  <tt class="py-line">        <tt class="py-name">fields</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">f</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt> <tt class="py-keyword">if</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt> <tt class="py-op">==</tt> <tt class="py-string">'upload'</tt> </tt>
<a name="L5518"></a><tt class="py-lineno">5518</tt>  <tt class="py-line">                   <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">uploadfield</tt> <tt class="py-op">==</tt> <tt class="py-name">True</tt> </tt>
<a name="L5519"></a><tt class="py-lineno">5519</tt>  <tt class="py-line">                   <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">autodelete</tt><tt class="py-op">]</tt> </tt>
<a name="L5520"></a><tt class="py-lineno">5520</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L5521"></a><tt class="py-lineno">5521</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> </tt>
<a name="L5522"></a><tt class="py-lineno">5522</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">record</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2443" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.select
web2py.gluon.dal.CouchDBAdapter.select
web2py.gluon.dal.GoogleDatastoreAdapter.select
web2py.gluon.dal.MongoDBAdapter.select
web2py.gluon.dal.Set.select
web2py.gluon.tools.Crud.select" class="py-name" href="#" onclick="return doclink('link-2443', 'select', 'link-465');">select</a></tt><tt class="py-op">(</tt><tt class="py-op">*</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt> <tt class="py-keyword">for</tt> <tt class="py-name">f</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5523"></a><tt class="py-lineno">5523</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">fieldname</tt> <tt class="py-keyword">in</tt> <tt class="py-name">fields</tt><tt class="py-op">:</tt> </tt>
<a name="L5524"></a><tt class="py-lineno">5524</tt>  <tt class="py-line">                <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt> </tt>
<a name="L5525"></a><tt class="py-lineno">5525</tt>  <tt class="py-line">                <tt class="py-name">oldname</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">.</tt><tt id="link-2444" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2444', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">fieldname</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt> </tt>
<a name="L5526"></a><tt class="py-lineno">5526</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">oldname</tt><tt class="py-op">:</tt> </tt>
<a name="L5527"></a><tt class="py-lineno">5527</tt>  <tt class="py-line">                    <tt class="py-keyword">continue</tt> </tt>
<a name="L5528"></a><tt class="py-lineno">5528</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">upload_fields</tt> <tt class="py-keyword">and</tt> <tt class="py-name">oldname</tt> <tt class="py-op">==</tt> <tt class="py-name">upload_fields</tt><tt class="py-op">[</tt><tt class="py-name">fieldname</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L5529"></a><tt class="py-lineno">5529</tt>  <tt class="py-line">                    <tt class="py-keyword">continue</tt> </tt>
<a name="L5530"></a><tt class="py-lineno">5530</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">custom_delete</tt><tt class="py-op">:</tt> </tt>
<a name="L5531"></a><tt class="py-lineno">5531</tt>  <tt class="py-line">                    <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">custom_delete</tt><tt class="py-op">(</tt><tt class="py-name">oldname</tt><tt class="py-op">)</tt> </tt>
<a name="L5532"></a><tt class="py-lineno">5532</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5533"></a><tt class="py-lineno">5533</tt>  <tt class="py-line">                    <tt class="py-name">uploadfolder</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">uploadfolder</tt> </tt>
<a name="L5534"></a><tt class="py-lineno">5534</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">uploadfolder</tt><tt class="py-op">:</tt> </tt>
<a name="L5535"></a><tt class="py-lineno">5535</tt>  <tt class="py-line">                        <tt class="py-name">uploadfolder</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2445" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2445', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">.</tt><tt class="py-name">_adapter</tt><tt class="py-op">.</tt><tt class="py-name">folder</tt><tt class="py-op">,</tt> <tt class="py-string">'..'</tt><tt class="py-op">,</tt> <tt class="py-string">'uploads'</tt><tt class="py-op">)</tt> </tt>
<a name="L5536"></a><tt class="py-lineno">5536</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">uploadseparate</tt><tt class="py-op">:</tt> </tt>
<a name="L5537"></a><tt class="py-lineno">5537</tt>  <tt class="py-line">                        <tt id="link-2446" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2446', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-name">oldname</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L5538"></a><tt class="py-lineno">5538</tt>  <tt class="py-line">                        <tt class="py-name">uploadfolder</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2447" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2447', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">uploadfolder</tt><tt class="py-op">,</tt> </tt>
<a name="L5539"></a><tt class="py-lineno">5539</tt>  <tt class="py-line">                                                    <tt class="py-string">"%s.%s"</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-2448" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2448', 'items', 'link-266');">items</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt id="link-2449" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2449', 'items', 'link-266');">items</a></tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt>
<a name="L5540"></a><tt class="py-lineno">5540</tt>  <tt class="py-line">                                                    <tt id="link-2450" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2450', 'items', 'link-266');">items</a></tt><tt class="py-op">[</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">)</tt>                 </tt>
<a name="L5541"></a><tt class="py-lineno">5541</tt>  <tt class="py-line">                    <tt class="py-name">oldpath</tt> <tt class="py-op">=</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2451" class="py-name"><a title="web2py.gluon.html.join" class="py-name" href="#" onclick="return doclink('link-2451', 'join', 'link-228');">join</a></tt><tt class="py-op">(</tt><tt class="py-name">uploadfolder</tt><tt class="py-op">,</tt> <tt class="py-name">oldname</tt><tt class="py-op">)</tt> </tt>
<a name="L5542"></a><tt class="py-lineno">5542</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">path</tt><tt class="py-op">.</tt><tt id="link-2452" class="py-name"><a title="web2py.gluon.dal.DatabaseStoredFile.exists" class="py-name" href="#" onclick="return doclink('link-2452', 'exists', 'link-138');">exists</a></tt><tt class="py-op">(</tt><tt class="py-name">oldpath</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5543"></a><tt class="py-lineno">5543</tt>  <tt class="py-line">                        <tt class="py-name">os</tt><tt class="py-op">.</tt><tt class="py-name">unlink</tt><tt class="py-op">(</tt><tt class="py-name">oldpath</tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L5544"></a><tt class="py-lineno">5544</tt>  <tt class="py-line"> </tt>
<a name="update_record"></a><div id="update_record-def"><a name="L5545"></a><tt class="py-lineno">5545</tt> <a class="py-toggle" href="#" id="update_record-toggle" onclick="return toggle('update_record');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#update_record">update_record</a><tt class="py-op">(</tt><tt class="py-param">pack</tt><tt class="py-op">,</tt> <tt class="py-param">a</tt><tt class="py-op">=</tt><tt class="py-op">{</tt><tt class="py-op">}</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="update_record-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="update_record-expanded"><a name="L5546"></a><tt class="py-lineno">5546</tt>  <tt class="py-line">    <tt class="py-op">(</tt><tt class="py-name">colset</tt><tt class="py-op">,</tt> <tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">id</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">pack</tt> </tt>
<a name="L5547"></a><tt class="py-lineno">5547</tt>  <tt class="py-line">    <tt id="link-2453" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-2453', 'b', 'link-188');">b</a></tt> <tt class="py-op">=</tt> <tt class="py-name">a</tt> <tt class="py-keyword">or</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-name">colset</tt><tt class="py-op">)</tt> </tt>
<a name="L5548"></a><tt class="py-lineno">5548</tt>  <tt class="py-line">    <tt class="py-name">c</tt> <tt class="py-op">=</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">(</tt><tt id="link-2454" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2454', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt id="link-2455" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2455', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt><tt class="py-name">v</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt id="link-2456" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-2456', 'b', 'link-188');">b</a></tt><tt class="py-op">.</tt><tt id="link-2457" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2457', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> <tt class="py-keyword">if</tt> <tt id="link-2458" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2458', 'k', 'link-189');">k</a></tt> <tt class="py-keyword">in</tt> <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">fields</tt> <tt class="py-keyword">and</tt> <tt class="py-name">table</tt><tt class="py-op">[</tt><tt id="link-2459" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2459', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">!=</tt><tt class="py-string">'id'</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5549"></a><tt class="py-lineno">5549</tt>  <tt class="py-line">    <tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_db</tt><tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">.</tt><tt class="py-name">_id</tt><tt class="py-op">==</tt><tt class="py-name">id</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2460" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2460', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-op">**</tt><tt class="py-name">c</tt><tt class="py-op">)</tt> </tt>
<a name="L5550"></a><tt class="py-lineno">5550</tt>  <tt class="py-line">    <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt id="link-2461" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2461', 'k', 'link-189');">k</a></tt><tt class="py-op">,</tt> <tt class="py-name">v</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">c</tt><tt class="py-op">.</tt><tt id="link-2462" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2462', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5551"></a><tt class="py-lineno">5551</tt>  <tt class="py-line">        <tt class="py-name">colset</tt><tt class="py-op">[</tt><tt id="link-2463" class="py-name"><a title="psycopg2.k" class="py-name" href="#" onclick="return doclink('link-2463', 'k', 'link-189');">k</a></tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">v</tt> </tt>
</div><a name="L5552"></a><tt class="py-lineno">5552</tt>  <tt class="py-line"> </tt>
<a name="L5553"></a><tt class="py-lineno">5553</tt>  <tt class="py-line"> </tt>
<a name="Rows"></a><div id="Rows-def"><a name="L5554"></a><tt class="py-lineno">5554</tt> <a class="py-toggle" href="#" id="Rows-toggle" onclick="return toggle('Rows');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html">Rows</a><tt class="py-op">(</tt><tt class="py-base-class">object</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Rows-expanded"><a name="L5555"></a><tt class="py-lineno">5555</tt>  <tt class="py-line"> </tt>
<a name="L5556"></a><tt class="py-lineno">5556</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L5557"></a><tt class="py-lineno">5557</tt>  <tt class="py-line"><tt class="py-docstring">    A wrapper for the return value of a select. It basically represents a table.</tt> </tt>
<a name="L5558"></a><tt class="py-lineno">5558</tt>  <tt class="py-line"><tt class="py-docstring">    It has an iterator and each row is represented as a dictionary.</tt> </tt>
<a name="L5559"></a><tt class="py-lineno">5559</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
<a name="L5560"></a><tt class="py-lineno">5560</tt>  <tt class="py-line"> </tt>
<a name="L5561"></a><tt class="py-lineno">5561</tt>  <tt class="py-line">    <tt class="py-comment"># ## TODO: this class still needs some work to care for ID/OID</tt> </tt>
<a name="L5562"></a><tt class="py-lineno">5562</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="Rows.__init__"></a><div id="Rows.__init__-def"><a name="L5563"></a><tt class="py-lineno">5563</tt> <a class="py-toggle" href="#" id="Rows.__init__-toggle" onclick="return toggle('Rows.__init__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__init__">__init__</a><tt class="py-op">(</tt> </tt>
<a name="L5564"></a><tt class="py-lineno">5564</tt>  <tt class="py-line">        <tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L5565"></a><tt class="py-lineno">5565</tt>  <tt class="py-line">        <tt class="py-param">db</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt>
<a name="L5566"></a><tt class="py-lineno">5566</tt>  <tt class="py-line">        <tt class="py-param">records</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
<a name="L5567"></a><tt class="py-lineno">5567</tt>  <tt class="py-line">        <tt class="py-param">colnames</tt><tt class="py-op">=</tt><tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> </tt>
<a name="L5568"></a><tt class="py-lineno">5568</tt>  <tt class="py-line">        <tt class="py-param">compact</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5569"></a><tt class="py-lineno">5569</tt>  <tt class="py-line">        <tt class="py-param">rawrows</tt><tt class="py-op">=</tt><tt class="py-name">None</tt> </tt>
<a name="L5570"></a><tt class="py-lineno">5570</tt>  <tt class="py-line">        <tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__init__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__init__-expanded"><a name="L5571"></a><tt class="py-lineno">5571</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt> <tt class="py-op">=</tt> <tt class="py-name">db</tt> </tt>
<a name="L5572"></a><tt class="py-lineno">5572</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt> <tt class="py-op">=</tt> <tt class="py-name">records</tt> </tt>
<a name="L5573"></a><tt class="py-lineno">5573</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-name">colnames</tt> </tt>
<a name="L5574"></a><tt class="py-lineno">5574</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">compact</tt> <tt class="py-op">=</tt> <tt class="py-name">compact</tt> </tt>
<a name="L5575"></a><tt class="py-lineno">5575</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">response</tt> <tt class="py-op">=</tt> <tt class="py-name">rawrows</tt> </tt>
</div><a name="L5576"></a><tt class="py-lineno">5576</tt>  <tt class="py-line"> </tt>
<a name="Rows.setvirtualfields"></a><div id="Rows.setvirtualfields-def"><a name="L5577"></a><tt class="py-lineno">5577</tt> <a class="py-toggle" href="#" id="Rows.setvirtualfields-toggle" onclick="return toggle('Rows.setvirtualfields');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#setvirtualfields">setvirtualfields</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-op">**</tt><tt class="py-param">keyed_virtualfields</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.setvirtualfields-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.setvirtualfields-expanded"><a name="L5578"></a><tt class="py-lineno">5578</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">keyed_virtualfields</tt><tt class="py-op">:</tt> </tt>
<a name="L5579"></a><tt class="py-lineno">5579</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">self</tt> </tt>
<a name="L5580"></a><tt class="py-lineno">5580</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">row</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">:</tt> </tt>
<a name="L5581"></a><tt class="py-lineno">5581</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-op">(</tt><tt class="py-name">tablename</tt><tt class="py-op">,</tt><tt class="py-name">virtualfields</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">keyed_virtualfields</tt><tt class="py-op">.</tt><tt id="link-2464" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2464', 'items', 'link-266');">items</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5582"></a><tt class="py-lineno">5582</tt>  <tt class="py-line">                <tt class="py-name">attributes</tt> <tt class="py-op">=</tt> <tt class="py-name">dir</tt><tt class="py-op">(</tt><tt class="py-name">virtualfields</tt><tt class="py-op">)</tt> </tt>
<a name="L5583"></a><tt class="py-lineno">5583</tt>  <tt class="py-line">                <tt class="py-name">virtualfields</tt><tt class="py-op">.</tt><tt class="py-name">__dict__</tt><tt class="py-op">.</tt><tt id="link-2465" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.update
web2py.gluon.dal.CouchDBAdapter.update
web2py.gluon.dal.GoogleDatastoreAdapter.update
web2py.gluon.dal.MongoDBAdapter.update
web2py.gluon.dal.Set.update
web2py.gluon.html.DIV.update
web2py.gluon.tools.Crud.update
web2py.gluon.widget.web2pyDialog.update" class="py-name" href="#" onclick="return doclink('link-2465', 'update', 'link-507');">update</a></tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">)</tt> </tt>
<a name="L5584"></a><tt class="py-lineno">5584</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">tablename</tt> <tt class="py-keyword">in</tt> <tt class="py-name">row</tt><tt class="py-op">:</tt> </tt>
<a name="L5585"></a><tt class="py-lineno">5585</tt>  <tt class="py-line">                    <tt class="py-name">box</tt> <tt class="py-op">=</tt> <tt class="py-name">row</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt id="link-2466" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2466', 'Row', 'link-600');">Row</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5586"></a><tt class="py-lineno">5586</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5587"></a><tt class="py-lineno">5587</tt>  <tt class="py-line">                    <tt class="py-name">box</tt> <tt class="py-op">=</tt> <tt class="py-name">row</tt><tt class="py-op">[</tt><tt class="py-name">tablename</tt><tt class="py-op">]</tt> </tt>
<a name="L5588"></a><tt class="py-lineno">5588</tt>  <tt class="py-line">                <tt class="py-keyword">for</tt> <tt class="py-name">attribute</tt> <tt class="py-keyword">in</tt> <tt class="py-name">attributes</tt><tt class="py-op">:</tt> </tt>
<a name="L5589"></a><tt class="py-lineno">5589</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">attribute</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-string">'_'</tt><tt class="py-op">:</tt> </tt>
<a name="L5590"></a><tt class="py-lineno">5590</tt>  <tt class="py-line">                        <tt class="py-name">method</tt> <tt class="py-op">=</tt> <tt class="py-name">getattr</tt><tt class="py-op">(</tt><tt class="py-name">virtualfields</tt><tt class="py-op">,</tt><tt class="py-name">attribute</tt><tt class="py-op">)</tt> </tt>
<a name="L5591"></a><tt class="py-lineno">5591</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">method</tt><tt class="py-op">,</tt><tt class="py-string">'im_func'</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">method</tt><tt class="py-op">.</tt><tt class="py-name">im_func</tt><tt class="py-op">.</tt><tt class="py-name">func_code</tt><tt class="py-op">.</tt><tt class="py-name">co_argcount</tt><tt class="py-op">:</tt> </tt>
<a name="L5592"></a><tt class="py-lineno">5592</tt>  <tt class="py-line">                            <tt class="py-name">box</tt><tt class="py-op">[</tt><tt class="py-name">attribute</tt><tt class="py-op">]</tt><tt class="py-op">=</tt><tt class="py-name">method</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5593"></a><tt class="py-lineno">5593</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt> </tt>
</div><a name="L5594"></a><tt class="py-lineno">5594</tt>  <tt class="py-line"> </tt>
<a name="Rows.__and__"></a><div id="Rows.__and__-def"><a name="L5595"></a><tt class="py-lineno">5595</tt> <a class="py-toggle" href="#" id="Rows.__and__-toggle" onclick="return toggle('Rows.__and__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__and__">__and__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__and__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__and__-expanded"><a name="L5596"></a><tt class="py-lineno">5596</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">!=</tt><tt class="py-name">other</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt id="link-2467" class="py-name"><a title="exceptions.Exception" class="py-name" href="#" onclick="return doclink('link-2467', 'Exception', 'link-328');">Exception</a></tt><tt class="py-op">,</tt> <tt class="py-string">'Cannot &amp; incompatible Rows objects'</tt> </tt>
<a name="L5597"></a><tt class="py-lineno">5597</tt>  <tt class="py-line">        <tt class="py-name">records</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">+</tt><tt class="py-name">other</tt><tt class="py-op">.</tt><tt class="py-name">records</tt> </tt>
<a name="L5598"></a><tt class="py-lineno">5598</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2468" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2468', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">records</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5599"></a><tt class="py-lineno">5599</tt>  <tt class="py-line"> </tt>
<a name="Rows.__or__"></a><div id="Rows.__or__-def"><a name="L5600"></a><tt class="py-lineno">5600</tt> <a class="py-toggle" href="#" id="Rows.__or__-toggle" onclick="return toggle('Rows.__or__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__or__">__or__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">other</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__or__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__or__-expanded"><a name="L5601"></a><tt class="py-lineno">5601</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">!=</tt><tt class="py-name">other</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">:</tt> <tt class="py-keyword">raise</tt> <tt id="link-2469" class="py-name"><a title="exceptions.Exception" class="py-name" href="#" onclick="return doclink('link-2469', 'Exception', 'link-328');">Exception</a></tt><tt class="py-op">,</tt> <tt class="py-string">'Cannot | incompatible Rows objects'</tt> </tt>
<a name="L5602"></a><tt class="py-lineno">5602</tt>  <tt class="py-line">        <tt class="py-name">records</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt> </tt>
<a name="L5603"></a><tt class="py-lineno">5603</tt>  <tt class="py-line">        <tt class="py-name">records</tt> <tt class="py-op">+=</tt> <tt class="py-op">[</tt><tt class="py-name">record</tt> <tt class="py-keyword">for</tt> <tt class="py-name">record</tt> <tt class="py-keyword">in</tt> <tt class="py-name">other</tt><tt class="py-op">.</tt><tt class="py-name">records</tt> \ </tt>
<a name="L5604"></a><tt class="py-lineno">5604</tt>  <tt class="py-line">                        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">record</tt> <tt class="py-keyword">in</tt> <tt class="py-name">records</tt><tt class="py-op">]</tt> </tt>
<a name="L5605"></a><tt class="py-lineno">5605</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2470" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2470', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">records</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5606"></a><tt class="py-lineno">5606</tt>  <tt class="py-line"> </tt>
<a name="Rows.__nonzero__"></a><div id="Rows.__nonzero__-def"><a name="L5607"></a><tt class="py-lineno">5607</tt> <a class="py-toggle" href="#" id="Rows.__nonzero__-toggle" onclick="return toggle('Rows.__nonzero__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__nonzero__">__nonzero__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__nonzero__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__nonzero__-expanded"><a name="L5608"></a><tt class="py-lineno">5608</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-2471" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2471', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5609"></a><tt class="py-lineno">5609</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-number">1</tt> </tt>
<a name="L5610"></a><tt class="py-lineno">5610</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-number">0</tt> </tt>
</div><a name="L5611"></a><tt class="py-lineno">5611</tt>  <tt class="py-line"> </tt>
<a name="Rows.__len__"></a><div id="Rows.__len__-def"><a name="L5612"></a><tt class="py-lineno">5612</tt> <a class="py-toggle" href="#" id="Rows.__len__-toggle" onclick="return toggle('Rows.__len__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__len__">__len__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__len__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__len__-expanded"><a name="L5613"></a><tt class="py-lineno">5613</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2472" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2472', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5614"></a><tt class="py-lineno">5614</tt>  <tt class="py-line"> </tt>
<a name="Rows.__getslice__"></a><div id="Rows.__getslice__-def"><a name="L5615"></a><tt class="py-lineno">5615</tt> <a class="py-toggle" href="#" id="Rows.__getslice__-toggle" onclick="return toggle('Rows.__getslice__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__getslice__">__getslice__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">a</tt><tt class="py-op">,</tt> <tt class="py-param">b</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__getslice__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__getslice__-expanded"><a name="L5616"></a><tt class="py-lineno">5616</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2473" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2473', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">[</tt><tt class="py-name">a</tt><tt class="py-op">:</tt><tt id="link-2474" class="py-name"><a title="web2py.gluon.rocket.b" class="py-name" href="#" onclick="return doclink('link-2474', 'b', 'link-188');">b</a></tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5617"></a><tt class="py-lineno">5617</tt>  <tt class="py-line"> </tt>
<a name="Rows.__getitem__"></a><div id="Rows.__getitem__-def"><a name="L5618"></a><tt class="py-lineno">5618</tt> <a class="py-toggle" href="#" id="Rows.__getitem__-toggle" onclick="return toggle('Rows.__getitem__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__getitem__">__getitem__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">i</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__getitem__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__getitem__-expanded"><a name="L5619"></a><tt class="py-lineno">5619</tt>  <tt class="py-line">        <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L5620"></a><tt class="py-lineno">5620</tt>  <tt class="py-line">        <tt id="link-2475" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2475', 'keys', 'link-269');">keys</a></tt> <tt class="py-op">=</tt> <tt class="py-name">row</tt><tt class="py-op">.</tt><tt id="link-2476" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2476', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5621"></a><tt class="py-lineno">5621</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">compact</tt> <tt class="py-keyword">and</tt> <tt id="link-2477" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2477', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt id="link-2478" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2478', 'keys', 'link-269');">keys</a></tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt> <tt class="py-keyword">and</tt> <tt id="link-2479" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2479', 'keys', 'link-269');">keys</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-string">'_extra'</tt><tt class="py-op">:</tt> </tt>
<a name="L5622"></a><tt class="py-lineno">5622</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">row</tt><tt class="py-op">[</tt><tt class="py-name">row</tt><tt class="py-op">.</tt><tt id="link-2480" class="py-name"><a title="web2py.gluon.rocket.Headers.keys
web2py.gluon.tools.PluginManager.keys" class="py-name" href="#" onclick="return doclink('link-2480', 'keys', 'link-269');">keys</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> </tt>
<a name="L5623"></a><tt class="py-lineno">5623</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">row</tt> </tt>
</div><a name="L5624"></a><tt class="py-lineno">5624</tt>  <tt class="py-line"> </tt>
<a name="Rows.__iter__"></a><div id="Rows.__iter__-def"><a name="L5625"></a><tt class="py-lineno">5625</tt> <a class="py-toggle" href="#" id="Rows.__iter__-toggle" onclick="return toggle('Rows.__iter__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__iter__">__iter__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__iter__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__iter__-expanded"><a name="L5626"></a><tt class="py-lineno">5626</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5627"></a><tt class="py-lineno">5627</tt>  <tt class="py-line"><tt class="py-docstring">        iterator over records</tt> </tt>
<a name="L5628"></a><tt class="py-lineno">5628</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5629"></a><tt class="py-lineno">5629</tt>  <tt class="py-line"> </tt>
<a name="L5630"></a><tt class="py-lineno">5630</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">xrange</tt><tt class="py-op">(</tt><tt id="link-2481" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2481', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5631"></a><tt class="py-lineno">5631</tt>  <tt class="py-line">            <tt class="py-keyword">yield</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
</div><a name="L5632"></a><tt class="py-lineno">5632</tt>  <tt class="py-line"> </tt>
<a name="Rows.__str__"></a><div id="Rows.__str__-def"><a name="L5633"></a><tt class="py-lineno">5633</tt> <a class="py-toggle" href="#" id="Rows.__str__-toggle" onclick="return toggle('Rows.__str__');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#__str__">__str__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.__str__-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.__str__-expanded"><a name="L5634"></a><tt class="py-lineno">5634</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5635"></a><tt class="py-lineno">5635</tt>  <tt class="py-line"><tt class="py-docstring">        serializes the table into a csv file</tt> </tt>
<a name="L5636"></a><tt class="py-lineno">5636</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5637"></a><tt class="py-lineno">5637</tt>  <tt class="py-line"> </tt>
<a name="L5638"></a><tt class="py-lineno">5638</tt>  <tt class="py-line">        <tt id="link-2482" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-2482', 's', 'link-647');">s</a></tt> <tt class="py-op">=</tt> <tt class="py-name">cStringIO</tt><tt class="py-op">.</tt><tt class="py-name">StringIO</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5639"></a><tt class="py-lineno">5639</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2483" class="py-name"><a title="web2py.gluon.dal.DAL.export_to_csv_file
web2py.gluon.dal.Rows.export_to_csv_file" class="py-name" href="#" onclick="return doclink('link-2483', 'export_to_csv_file', 'link-1986');">export_to_csv_file</a></tt><tt class="py-op">(</tt><tt id="link-2484" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-2484', 's', 'link-647');">s</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5640"></a><tt class="py-lineno">5640</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2485" class="py-name"><a title="web2py.gluon.languages.lazyT.s" class="py-name" href="#" onclick="return doclink('link-2485', 's', 'link-647');">s</a></tt><tt class="py-op">.</tt><tt class="py-name">getvalue</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5641"></a><tt class="py-lineno">5641</tt>  <tt class="py-line"> </tt>
<a name="Rows.first"></a><div id="Rows.first-def"><a name="L5642"></a><tt class="py-lineno">5642</tt> <a class="py-toggle" href="#" id="Rows.first-toggle" onclick="return toggle('Rows.first');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#first">first</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.first-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.first-expanded"><a name="L5643"></a><tt class="py-lineno">5643</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">:</tt> </tt>
<a name="L5644"></a><tt class="py-lineno">5644</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L5645"></a><tt class="py-lineno">5645</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> </tt>
</div><a name="L5646"></a><tt class="py-lineno">5646</tt>  <tt class="py-line"> </tt>
<a name="Rows.last"></a><div id="Rows.last-def"><a name="L5647"></a><tt class="py-lineno">5647</tt> <a class="py-toggle" href="#" id="Rows.last-toggle" onclick="return toggle('Rows.last');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#last">last</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.last-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.last-expanded"><a name="L5648"></a><tt class="py-lineno">5648</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">:</tt> </tt>
<a name="L5649"></a><tt class="py-lineno">5649</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">None</tt> </tt>
<a name="L5650"></a><tt class="py-lineno">5650</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt>
</div><a name="L5651"></a><tt class="py-lineno">5651</tt>  <tt class="py-line"> </tt>
<a name="Rows.find"></a><div id="Rows.find-def"><a name="L5652"></a><tt class="py-lineno">5652</tt> <a class="py-toggle" href="#" id="Rows.find-toggle" onclick="return toggle('Rows.find');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#find">find</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt><tt class="py-param">f</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.find-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.find-expanded"><a name="L5653"></a><tt class="py-lineno">5653</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5654"></a><tt class="py-lineno">5654</tt>  <tt class="py-line"><tt class="py-docstring">        returns a new Rows object, a subset of the original object,</tt> </tt>
<a name="L5655"></a><tt class="py-lineno">5655</tt>  <tt class="py-line"><tt class="py-docstring">        filtered by the function f</tt> </tt>
<a name="L5656"></a><tt class="py-lineno">5656</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5657"></a><tt class="py-lineno">5657</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">:</tt> </tt>
<a name="L5658"></a><tt class="py-lineno">5658</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-2486" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2486', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
<a name="L5659"></a><tt class="py-lineno">5659</tt>  <tt class="py-line">        <tt class="py-name">records</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L5660"></a><tt class="py-lineno">5660</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-number">0</tt><tt class="py-op">,</tt><tt id="link-2487" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2487', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5661"></a><tt class="py-lineno">5661</tt>  <tt class="py-line">            <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L5662"></a><tt class="py-lineno">5662</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">f</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5663"></a><tt class="py-lineno">5663</tt>  <tt class="py-line">                <tt class="py-name">records</tt><tt class="py-op">.</tt><tt id="link-2488" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2488', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5664"></a><tt class="py-lineno">5664</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2489" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2489', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">records</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5665"></a><tt class="py-lineno">5665</tt>  <tt class="py-line"> </tt>
<a name="Rows.exclude"></a><div id="Rows.exclude-def"><a name="L5666"></a><tt class="py-lineno">5666</tt> <a class="py-toggle" href="#" id="Rows.exclude-toggle" onclick="return toggle('Rows.exclude');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#exclude">exclude</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">f</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.exclude-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.exclude-expanded"><a name="L5667"></a><tt class="py-lineno">5667</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5668"></a><tt class="py-lineno">5668</tt>  <tt class="py-line"><tt class="py-docstring">        removes elements from the calling Rows object, filtered by the function f,</tt> </tt>
<a name="L5669"></a><tt class="py-lineno">5669</tt>  <tt class="py-line"><tt class="py-docstring">        and returns a new Rows object containing the removed elements</tt> </tt>
<a name="L5670"></a><tt class="py-lineno">5670</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5671"></a><tt class="py-lineno">5671</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">:</tt> </tt>
<a name="L5672"></a><tt class="py-lineno">5672</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-2490" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2490', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
<a name="L5673"></a><tt class="py-lineno">5673</tt>  <tt class="py-line">        <tt class="py-name">removed</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L5674"></a><tt class="py-lineno">5674</tt>  <tt class="py-line">        <tt class="py-name">i</tt><tt class="py-op">=</tt><tt class="py-number">0</tt> </tt>
<a name="L5675"></a><tt class="py-lineno">5675</tt>  <tt class="py-line">        <tt class="py-keyword">while</tt> <tt class="py-name">i</tt><tt class="py-op">&lt;</tt><tt id="link-2491" class="py-name"><a title="web2py.gluon.dal.Expression.len" class="py-name" href="#" onclick="return doclink('link-2491', 'len', 'link-131');">len</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5676"></a><tt class="py-lineno">5676</tt>  <tt class="py-line">            <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L5677"></a><tt class="py-lineno">5677</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">f</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5678"></a><tt class="py-lineno">5678</tt>  <tt class="py-line">                <tt class="py-name">removed</tt><tt class="py-op">.</tt><tt id="link-2492" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2492', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5679"></a><tt class="py-lineno">5679</tt>  <tt class="py-line">                <tt class="py-keyword">del</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">records</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt> </tt>
<a name="L5680"></a><tt class="py-lineno">5680</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5681"></a><tt class="py-lineno">5681</tt>  <tt class="py-line">                <tt class="py-name">i</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt>
<a name="L5682"></a><tt class="py-lineno">5682</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2493" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2493', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt> <tt class="py-name">removed</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5683"></a><tt class="py-lineno">5683</tt>  <tt class="py-line"> </tt>
<a name="Rows.sort"></a><div id="Rows.sort-def"><a name="L5684"></a><tt class="py-lineno">5684</tt> <a class="py-toggle" href="#" id="Rows.sort-toggle" onclick="return toggle('Rows.sort');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#sort">sort</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">f</tt><tt class="py-op">,</tt> <tt class="py-param">reverse</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.sort-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.sort-expanded"><a name="L5685"></a><tt class="py-lineno">5685</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5686"></a><tt class="py-lineno">5686</tt>  <tt class="py-line"><tt class="py-docstring">        returns a list of sorted elements (not sorted in place)</tt> </tt>
<a name="L5687"></a><tt class="py-lineno">5687</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5688"></a><tt class="py-lineno">5688</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2494" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2494', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">,</tt><tt class="py-name">sorted</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">,</tt><tt class="py-name">key</tt><tt class="py-op">=</tt><tt class="py-name">f</tt><tt class="py-op">,</tt><tt class="py-name">reverse</tt><tt class="py-op">=</tt><tt class="py-name">reverse</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5689"></a><tt class="py-lineno">5689</tt>  <tt class="py-line"> </tt>
<a name="Rows.as_list"></a><div id="Rows.as_list-def"><a name="L5690"></a><tt class="py-lineno">5690</tt> <a class="py-toggle" href="#" id="Rows.as_list-toggle" onclick="return toggle('Rows.as_list');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#as_list">as_list</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L5691"></a><tt class="py-lineno">5691</tt>  <tt class="py-line">                <tt class="py-param">compact</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5692"></a><tt class="py-lineno">5692</tt>  <tt class="py-line">                <tt class="py-param">storage_to_dict</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5693"></a><tt class="py-lineno">5693</tt>  <tt class="py-line">                <tt class="py-param">datetime_to_str</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.as_list-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.as_list-expanded"><a name="L5694"></a><tt class="py-lineno">5694</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5695"></a><tt class="py-lineno">5695</tt>  <tt class="py-line"><tt class="py-docstring">        returns the data as a list or dictionary.</tt> </tt>
<a name="L5696"></a><tt class="py-lineno">5696</tt>  <tt class="py-line"><tt class="py-docstring">        :param storage_to_dict: when True returns a dict, otherwise a list(default True)</tt> </tt>
<a name="L5697"></a><tt class="py-lineno">5697</tt>  <tt class="py-line"><tt class="py-docstring">        :param datetime_to_str: convert datetime fields as strings (default True)</tt> </tt>
<a name="L5698"></a><tt class="py-lineno">5698</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5699"></a><tt class="py-lineno">5699</tt>  <tt class="py-line">        <tt class="py-op">(</tt><tt class="py-name">oc</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">compact</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">compact</tt><tt class="py-op">,</tt> <tt class="py-name">compact</tt><tt class="py-op">)</tt> </tt>
<a name="L5700"></a><tt class="py-lineno">5700</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">storage_to_dict</tt><tt class="py-op">:</tt> </tt>
<a name="L5701"></a><tt class="py-lineno">5701</tt>  <tt class="py-line">            <tt id="link-2495" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2495', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">item</tt><tt class="py-op">.</tt><tt id="link-2496" class="py-name"><a title="web2py.gluon.dal.Row.as_dict
web2py.gluon.dal.Rows.as_dict" class="py-name" href="#" onclick="return doclink('link-2496', 'as_dict', 'link-1725');">as_dict</a></tt><tt class="py-op">(</tt><tt class="py-name">datetime_to_str</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">]</tt> </tt>
<a name="L5702"></a><tt class="py-lineno">5702</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5703"></a><tt class="py-lineno">5703</tt>  <tt class="py-line">            <tt id="link-2497" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2497', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">item</tt> <tt class="py-keyword">for</tt> <tt class="py-name">item</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">]</tt> </tt>
<a name="L5704"></a><tt class="py-lineno">5704</tt>  <tt class="py-line">        <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">compact</tt> <tt class="py-op">=</tt> <tt class="py-name">compact</tt> </tt>
<a name="L5705"></a><tt class="py-lineno">5705</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2498" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2498', 'items', 'link-266');">items</a></tt> </tt>
</div><a name="L5706"></a><tt class="py-lineno">5706</tt>  <tt class="py-line"> </tt>
<a name="L5707"></a><tt class="py-lineno">5707</tt>  <tt class="py-line"> </tt>
<a name="Rows.as_dict"></a><div id="Rows.as_dict-def"><a name="L5708"></a><tt class="py-lineno">5708</tt> <a class="py-toggle" href="#" id="Rows.as_dict-toggle" onclick="return toggle('Rows.as_dict');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#as_dict">as_dict</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> </tt>
<a name="L5709"></a><tt class="py-lineno">5709</tt>  <tt class="py-line">                <tt class="py-param">key</tt><tt class="py-op">=</tt><tt class="py-string">'id'</tt><tt class="py-op">,</tt> </tt>
<a name="L5710"></a><tt class="py-lineno">5710</tt>  <tt class="py-line">                <tt class="py-param">compact</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5711"></a><tt class="py-lineno">5711</tt>  <tt class="py-line">                <tt class="py-param">storage_to_dict</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5712"></a><tt class="py-lineno">5712</tt>  <tt class="py-line">                <tt class="py-param">datetime_to_str</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.as_dict-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.as_dict-expanded"><a name="L5713"></a><tt class="py-lineno">5713</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5714"></a><tt class="py-lineno">5714</tt>  <tt class="py-line"><tt class="py-docstring">        returns the data as a dictionary of dictionaries (storage_to_dict=True) or records (False)</tt> </tt>
<a name="L5715"></a><tt class="py-lineno">5715</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5716"></a><tt class="py-lineno">5716</tt>  <tt class="py-line"><tt class="py-docstring">        :param key: the name of the field to be used as dict key, normally the id</tt> </tt>
<a name="L5717"></a><tt class="py-lineno">5717</tt>  <tt class="py-line"><tt class="py-docstring">        :param compact: ? (default True)</tt> </tt>
<a name="L5718"></a><tt class="py-lineno">5718</tt>  <tt class="py-line"><tt class="py-docstring">        :param storage_to_dict: when True returns a dict, otherwise a list(default True)</tt> </tt>
<a name="L5719"></a><tt class="py-lineno">5719</tt>  <tt class="py-line"><tt class="py-docstring">        :param datetime_to_str: convert datetime fields as strings (default True)</tt> </tt>
<a name="L5720"></a><tt class="py-lineno">5720</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5721"></a><tt class="py-lineno">5721</tt>  <tt class="py-line">        <tt id="link-2499" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2499', 'rows', 'link-539');">rows</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-2500" class="py-name" targets="Method web2py.gluon.dal.Rows.as_list()=web2py.gluon.dal.Rows-class.html#as_list"><a title="web2py.gluon.dal.Rows.as_list" class="py-name" href="#" onclick="return doclink('link-2500', 'as_list', 'link-2500');">as_list</a></tt><tt class="py-op">(</tt><tt class="py-name">compact</tt><tt class="py-op">,</tt> <tt class="py-name">storage_to_dict</tt><tt class="py-op">,</tt> <tt class="py-name">datetime_to_str</tt><tt class="py-op">)</tt> </tt>
<a name="L5722"></a><tt class="py-lineno">5722</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">key</tt><tt class="py-op">.</tt><tt id="link-2501" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.count
web2py.gluon.dal.CouchDBAdapter.count
web2py.gluon.dal.Field.count
web2py.gluon.dal.GoogleDatastoreAdapter.count
web2py.gluon.dal.MongoDBAdapter.count
web2py.gluon.dal.Set.count" class="py-name" href="#" onclick="return doclink('link-2501', 'count', 'link-1426');">count</a></tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt><tt class="py-op">==</tt><tt class="py-number">1</tt><tt class="py-op">:</tt> </tt>
<a name="L5723"></a><tt class="py-lineno">5723</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">table</tt><tt class="py-op">,</tt> <tt class="py-name">field</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">key</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L5724"></a><tt class="py-lineno">5724</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">[</tt><tt class="py-name">table</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">field</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">r</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">r</tt> <tt class="py-keyword">in</tt> <tt id="link-2502" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2502', 'rows', 'link-539');">rows</a></tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5725"></a><tt class="py-lineno">5725</tt>  <tt class="py-line">        <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">,</tt><tt class="py-name">str</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5726"></a><tt class="py-lineno">5726</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">[</tt><tt class="py-name">key</tt><tt class="py-op">]</tt><tt class="py-op">,</tt><tt class="py-name">r</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">r</tt> <tt class="py-keyword">in</tt> <tt id="link-2503" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2503', 'rows', 'link-539');">rows</a></tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5727"></a><tt class="py-lineno">5727</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5728"></a><tt class="py-lineno">5728</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-op">(</tt><tt class="py-name">key</tt><tt class="py-op">(</tt><tt class="py-name">r</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-name">r</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">r</tt> <tt class="py-keyword">in</tt> <tt id="link-2504" class="py-name"><a title="web2py.gluon.tools.Crud.rows" class="py-name" href="#" onclick="return doclink('link-2504', 'rows', 'link-539');">rows</a></tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5729"></a><tt class="py-lineno">5729</tt>  <tt class="py-line"> </tt>
<a name="Rows.export_to_csv_file"></a><div id="Rows.export_to_csv_file-def"><a name="L5730"></a><tt class="py-lineno">5730</tt> <a class="py-toggle" href="#" id="Rows.export_to_csv_file-toggle" onclick="return toggle('Rows.export_to_csv_file');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#export_to_csv_file">export_to_csv_file</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">ofile</tt><tt class="py-op">,</tt> <tt class="py-param">null</tt><tt class="py-op">=</tt><tt class="py-string">'&lt;NULL&gt;'</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-param">args</tt><tt class="py-op">,</tt> <tt class="py-op">**</tt><tt class="py-param">kwargs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.export_to_csv_file-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.export_to_csv_file-expanded"><a name="L5731"></a><tt class="py-lineno">5731</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5732"></a><tt class="py-lineno">5732</tt>  <tt class="py-line"><tt class="py-docstring">        export data to csv, the first line contains the column names</tt> </tt>
<a name="L5733"></a><tt class="py-lineno">5733</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5734"></a><tt class="py-lineno">5734</tt>  <tt class="py-line"><tt class="py-docstring">        :param ofile: where the csv must be exported to</tt> </tt>
<a name="L5735"></a><tt class="py-lineno">5735</tt>  <tt class="py-line"><tt class="py-docstring">        :param null: how null values must be represented (default '&lt;NULL&gt;')</tt> </tt>
<a name="L5736"></a><tt class="py-lineno">5736</tt>  <tt class="py-line"><tt class="py-docstring">        :param delimiter: delimiter to separate values (default ',')</tt> </tt>
<a name="L5737"></a><tt class="py-lineno">5737</tt>  <tt class="py-line"><tt class="py-docstring">        :param quotechar: character to use to quote string values (default '"')</tt> </tt>
<a name="L5738"></a><tt class="py-lineno">5738</tt>  <tt class="py-line"><tt class="py-docstring">        :param quoting: quote system, use csv.QUOTE_*** (default csv.QUOTE_MINIMAL)</tt> </tt>
<a name="L5739"></a><tt class="py-lineno">5739</tt>  <tt class="py-line"><tt class="py-docstring">        :param represent: use the fields .represent value (default False)</tt> </tt>
<a name="L5740"></a><tt class="py-lineno">5740</tt>  <tt class="py-line"><tt class="py-docstring">        :param colnames: list of column names to use (default self.colnames)</tt> </tt>
<a name="L5741"></a><tt class="py-lineno">5741</tt>  <tt class="py-line"><tt class="py-docstring">                         This will only work when exporting rows objects!!!!</tt> </tt>
<a name="L5742"></a><tt class="py-lineno">5742</tt>  <tt class="py-line"><tt class="py-docstring">                         DO NOT use this with db.export_to_csv()</tt> </tt>
<a name="L5743"></a><tt class="py-lineno">5743</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5744"></a><tt class="py-lineno">5744</tt>  <tt class="py-line">        <tt class="py-name">delimiter</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2505" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2505', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'delimiter'</tt><tt class="py-op">,</tt> <tt class="py-string">','</tt><tt class="py-op">)</tt> </tt>
<a name="L5745"></a><tt class="py-lineno">5745</tt>  <tt class="py-line">        <tt class="py-name">quotechar</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2506" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2506', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'quotechar'</tt><tt class="py-op">,</tt> <tt class="py-string">'"'</tt><tt class="py-op">)</tt> </tt>
<a name="L5746"></a><tt class="py-lineno">5746</tt>  <tt class="py-line">        <tt class="py-name">quoting</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2507" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2507', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'quoting'</tt><tt class="py-op">,</tt> <tt id="link-2508" class="py-name"><a title="web2py.gluon.serializers.csv
web2py.gluon.tools.Service.csv" class="py-name" href="#" onclick="return doclink('link-2508', 'csv', 'link-5');">csv</a></tt><tt class="py-op">.</tt><tt class="py-name">QUOTE_MINIMAL</tt><tt class="py-op">)</tt> </tt>
<a name="L5747"></a><tt class="py-lineno">5747</tt>  <tt class="py-line">        <tt id="link-2509" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2509', 'represent', 'link-304');">represent</a></tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2510" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2510', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'represent'</tt><tt class="py-op">,</tt> <tt class="py-name">False</tt><tt class="py-op">)</tt> </tt>
<a name="L5748"></a><tt class="py-lineno">5748</tt>  <tt class="py-line">        <tt class="py-name">writer</tt> <tt class="py-op">=</tt> <tt id="link-2511" class="py-name"><a title="web2py.gluon.serializers.csv
web2py.gluon.tools.Service.csv" class="py-name" href="#" onclick="return doclink('link-2511', 'csv', 'link-5');">csv</a></tt><tt class="py-op">.</tt><tt class="py-name">writer</tt><tt class="py-op">(</tt><tt class="py-name">ofile</tt><tt class="py-op">,</tt> <tt class="py-name">delimiter</tt><tt class="py-op">=</tt><tt class="py-name">delimiter</tt><tt class="py-op">,</tt> </tt>
<a name="L5749"></a><tt class="py-lineno">5749</tt>  <tt class="py-line">                            <tt class="py-name">quotechar</tt><tt class="py-op">=</tt><tt class="py-name">quotechar</tt><tt class="py-op">,</tt> <tt class="py-name">quoting</tt><tt class="py-op">=</tt><tt class="py-name">quoting</tt><tt class="py-op">)</tt> </tt>
<a name="L5750"></a><tt class="py-lineno">5750</tt>  <tt class="py-line">        <tt class="py-name">colnames</tt> <tt class="py-op">=</tt> <tt class="py-name">kwargs</tt><tt class="py-op">.</tt><tt id="link-2512" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2512', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-string">'colnames'</tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
<a name="L5751"></a><tt class="py-lineno">5751</tt>  <tt class="py-line">        <tt class="py-comment"># a proper csv starting with the column names</tt> </tt>
<a name="L5752"></a><tt class="py-lineno">5752</tt>  <tt class="py-line"><tt class="py-comment"></tt>        <tt class="py-name">writer</tt><tt class="py-op">.</tt><tt class="py-name">writerow</tt><tt class="py-op">(</tt><tt class="py-name">colnames</tt><tt class="py-op">)</tt> </tt>
<a name="L5753"></a><tt class="py-lineno">5753</tt>  <tt class="py-line"> </tt>
<a name="L5754"></a><tt class="py-lineno">5754</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">none_exception</tt><tt class="py-op">(</tt><tt class="py-param">value</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5755"></a><tt class="py-lineno">5755</tt>  <tt class="py-line">            <tt class="py-docstring">"""</tt> </tt>
<a name="L5756"></a><tt class="py-lineno">5756</tt>  <tt class="py-line"><tt class="py-docstring">            returns a cleaned up value that can be used for csv export:</tt> </tt>
<a name="L5757"></a><tt class="py-lineno">5757</tt>  <tt class="py-line"><tt class="py-docstring">            - unicode text is encoded as such</tt> </tt>
<a name="L5758"></a><tt class="py-lineno">5758</tt>  <tt class="py-line"><tt class="py-docstring">            - None values are replaced with the given representation (default &lt;NULL&gt;)</tt> </tt>
<a name="L5759"></a><tt class="py-lineno">5759</tt>  <tt class="py-line"><tt class="py-docstring">            """</tt> </tt>
<a name="L5760"></a><tt class="py-lineno">5760</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">value</tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L5761"></a><tt class="py-lineno">5761</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">null</tt> </tt>
<a name="L5762"></a><tt class="py-lineno">5762</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-name">unicode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5763"></a><tt class="py-lineno">5763</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt id="link-2513" class="py-name"><a title="web2py.gluon.languages.lazyT.encode" class="py-name" href="#" onclick="return doclink('link-2513', 'encode', 'link-238');">encode</a></tt><tt class="py-op">(</tt><tt class="py-string">'utf8'</tt><tt class="py-op">)</tt> </tt>
<a name="L5764"></a><tt class="py-lineno">5764</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt><tt id="link-2514" class="py-name"><a title="web2py.gluon.dal.Reference" class="py-name" href="#" onclick="return doclink('link-2514', 'Reference', 'link-337');">Reference</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5765"></a><tt class="py-lineno">5765</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">int</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L5766"></a><tt class="py-lineno">5766</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">hasattr</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-string">'isoformat'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5767"></a><tt class="py-lineno">5767</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">value</tt><tt class="py-op">.</tt><tt class="py-name">isoformat</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">[</tt><tt class="py-op">:</tt><tt class="py-number">19</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">'T'</tt><tt class="py-op">,</tt> <tt class="py-string">' '</tt><tt class="py-op">)</tt> </tt>
<a name="L5768"></a><tt class="py-lineno">5768</tt>  <tt class="py-line">            <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">list</tt><tt class="py-op">,</tt><tt class="py-name">tuple</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-comment"># for type='list:..'</tt> </tt>
<a name="L5769"></a><tt class="py-lineno">5769</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt id="link-2515" class="py-name"><a title="web2py.gluon.dal.bar_encode" class="py-name" href="#" onclick="return doclink('link-2515', 'bar_encode', 'link-594');">bar_encode</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L5770"></a><tt class="py-lineno">5770</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">value</tt> </tt>
</div><a name="L5771"></a><tt class="py-lineno">5771</tt>  <tt class="py-line"> </tt>
<a name="L5772"></a><tt class="py-lineno">5772</tt>  <tt class="py-line">        <tt class="py-keyword">for</tt> <tt class="py-name">record</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">:</tt> </tt>
<a name="L5773"></a><tt class="py-lineno">5773</tt>  <tt class="py-line">            <tt class="py-name">row</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt>
<a name="L5774"></a><tt class="py-lineno">5774</tt>  <tt class="py-line">            <tt class="py-keyword">for</tt> <tt class="py-name">col</tt> <tt class="py-keyword">in</tt> <tt class="py-name">colnames</tt><tt class="py-op">:</tt> </tt>
<a name="L5775"></a><tt class="py-lineno">5775</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2516" class="py-name"><a title="web2py.gluon.dal.table_field
web2py.gluon.sqlhtml.table_field" class="py-name" href="#" onclick="return doclink('link-2516', 'table_field', 'link-29');">table_field</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">col</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5776"></a><tt class="py-lineno">5776</tt>  <tt class="py-line">                    <tt class="py-name">row</tt><tt class="py-op">.</tt><tt id="link-2517" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2517', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">record</tt><tt class="py-op">.</tt><tt class="py-name">_extra</tt><tt class="py-op">[</tt><tt class="py-name">col</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt>
<a name="L5777"></a><tt class="py-lineno">5777</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5778"></a><tt class="py-lineno">5778</tt>  <tt class="py-line">                    <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">f</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">col</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L5779"></a><tt class="py-lineno">5779</tt>  <tt class="py-line">                    <tt class="py-name">field</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">db</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt> </tt>
<a name="L5780"></a><tt class="py-lineno">5780</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">record</tt><tt class="py-op">.</tt><tt id="link-2518" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2518', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt id="link-2519" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2519', 'Row', 'link-600');">Row</a></tt><tt class="py-op">,</tt><tt class="py-name">dict</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5781"></a><tt class="py-lineno">5781</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt> </tt>
<a name="L5782"></a><tt class="py-lineno">5782</tt>  <tt class="py-line">                    <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5783"></a><tt class="py-lineno">5783</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt> </tt>
<a name="L5784"></a><tt class="py-lineno">5784</tt>  <tt class="py-line">                    <tt class="py-keyword">if</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt class="py-name">type</tt><tt class="py-op">==</tt><tt class="py-string">'blob'</tt> <tt class="py-keyword">and</tt> <tt class="py-name">value</tt><tt class="py-op">!=</tt><tt class="py-name">None</tt><tt class="py-op">:</tt> </tt>
<a name="L5785"></a><tt class="py-lineno">5785</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">base64</tt><tt class="py-op">.</tt><tt class="py-name">b64encode</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L5786"></a><tt class="py-lineno">5786</tt>  <tt class="py-line">                    <tt class="py-keyword">elif</tt> <tt id="link-2520" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2520', 'represent', 'link-304');">represent</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2521" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2521', 'represent', 'link-304');">represent</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5787"></a><tt class="py-lineno">5787</tt>  <tt class="py-line">                        <tt class="py-name">value</tt> <tt class="py-op">=</tt> <tt class="py-name">field</tt><tt class="py-op">.</tt><tt id="link-2522" class="py-name"><a title="web2py.gluon.dal.BaseAdapter.represent
web2py.gluon.dal.CouchDBAdapter.represent
web2py.gluon.dal.MSSQL2Adapter.represent
web2py.gluon.dal.NoSQLAdapter.represent
web2py.gluon.sqlhtml.UploadWidget.represent
web2py.gluon.sqlhtml.represent" class="py-name" href="#" onclick="return doclink('link-2522', 'represent', 'link-304');">represent</a></tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt> </tt>
<a name="L5788"></a><tt class="py-lineno">5788</tt>  <tt class="py-line">                    <tt class="py-name">row</tt><tt class="py-op">.</tt><tt id="link-2523" class="py-name"><a title="web2py.gluon.html.DIV.append
web2py.gluon.template.BlockNode.append
web2py.gluon.template.Content.append" class="py-name" href="#" onclick="return doclink('link-2523', 'append', 'link-36');">append</a></tt><tt class="py-op">(</tt><tt class="py-name">none_exception</tt><tt class="py-op">(</tt><tt class="py-name">value</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt>
<a name="L5789"></a><tt class="py-lineno">5789</tt>  <tt class="py-line">            <tt class="py-name">writer</tt><tt class="py-op">.</tt><tt class="py-name">writerow</tt><tt class="py-op">(</tt><tt class="py-name">row</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5790"></a><tt class="py-lineno">5790</tt>  <tt class="py-line"> </tt>
<a name="Rows.xml"></a><div id="Rows.xml-def"><a name="L5791"></a><tt class="py-lineno">5791</tt> <a class="py-toggle" href="#" id="Rows.xml-toggle" onclick="return toggle('Rows.xml');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#xml">xml</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.xml-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.xml-expanded"><a name="L5792"></a><tt class="py-lineno">5792</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5793"></a><tt class="py-lineno">5793</tt>  <tt class="py-line"><tt class="py-docstring">        serializes the table using sqlhtml.SQLTABLE (if present)</tt> </tt>
<a name="L5794"></a><tt class="py-lineno">5794</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5795"></a><tt class="py-lineno">5795</tt>  <tt class="py-line"> </tt>
<a name="L5796"></a><tt class="py-lineno">5796</tt>  <tt class="py-line">        <tt class="py-keyword">import</tt> <tt id="link-2524" class="py-name" targets="Module web2py.gluon.sqlhtml=web2py.gluon.sqlhtml-module.html"><a title="web2py.gluon.sqlhtml" class="py-name" href="#" onclick="return doclink('link-2524', 'sqlhtml', 'link-2524');">sqlhtml</a></tt> </tt>
<a name="L5797"></a><tt class="py-lineno">5797</tt>  <tt class="py-line">        <tt class="py-keyword">return</tt> <tt id="link-2525" class="py-name"><a title="web2py.gluon.sqlhtml" class="py-name" href="#" onclick="return doclink('link-2525', 'sqlhtml', 'link-2524');">sqlhtml</a></tt><tt class="py-op">.</tt><tt id="link-2526" class="py-name" targets="Class web2py.gluon.sqlhtml.SQLTABLE=web2py.gluon.sqlhtml.SQLTABLE-class.html"><a title="web2py.gluon.sqlhtml.SQLTABLE" class="py-name" href="#" onclick="return doclink('link-2526', 'SQLTABLE', 'link-2526');">SQLTABLE</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-2527" class="py-name" targets="Method web2py.gluon.dal.Rows.xml()=web2py.gluon.dal.Rows-class.html#xml,Method web2py.gluon.html.A.xml()=web2py.gluon.html.A-class.html#xml,Method web2py.gluon.html.CODE.xml()=web2py.gluon.html.CODE-class.html#xml,Method web2py.gluon.html.DIV.xml()=web2py.gluon.html.DIV-class.html#xml,Method web2py.gluon.html.FORM.xml()=web2py.gluon.html.FORM-class.html#xml,Method web2py.gluon.html.HTML.xml()=web2py.gluon.html.HTML-class.html#xml,Method web2py.gluon.html.INPUT.xml()=web2py.gluon.html.INPUT-class.html#xml,Method web2py.gluon.html.MARKMIN.xml()=web2py.gluon.html.MARKMIN-class.html#xml,Method web2py.gluon.html.MENU.xml()=web2py.gluon.html.MENU-class.html#xml,Method web2py.gluon.html.P.xml()=web2py.gluon.html.P-class.html#xml,Method web2py.gluon.html.SCRIPT.xml()=web2py.gluon.html.SCRIPT-class.html#xml,Method web2py.gluon.html.STYLE.xml()=web2py.gluon.html.STYLE-class.html#xml,Method web2py.gluon.html.XHTML.xml()=web2py.gluon.html.XHTML-class.html#xml,Method web2py.gluon.html.XML.xml()=web2py.gluon.html.XML-class.html#xml,Method web2py.gluon.html.XmlComponent.xml()=web2py.gluon.html.XmlComponent-class.html#xml,Method web2py.gluon.languages.lazyT.xml()=web2py.gluon.languages.lazyT-class.html#xml,Function web2py.gluon.serializers.xml()=web2py.gluon.serializers-module.html#xml,Method web2py.gluon.tools.Recaptcha.xml()=web2py.gluon.tools.Recaptcha-class.html#xml,Method web2py.gluon.tools.Service.xml()=web2py.gluon.tools.Service-class.html#xml"><a title="web2py.gluon.dal.Rows.xml
web2py.gluon.html.A.xml
web2py.gluon.html.CODE.xml
web2py.gluon.html.DIV.xml
web2py.gluon.html.FORM.xml
web2py.gluon.html.HTML.xml
web2py.gluon.html.INPUT.xml
web2py.gluon.html.MARKMIN.xml
web2py.gluon.html.MENU.xml
web2py.gluon.html.P.xml
web2py.gluon.html.SCRIPT.xml
web2py.gluon.html.STYLE.xml
web2py.gluon.html.XHTML.xml
web2py.gluon.html.XML.xml
web2py.gluon.html.XmlComponent.xml
web2py.gluon.languages.lazyT.xml
web2py.gluon.serializers.xml
web2py.gluon.tools.Recaptcha.xml
web2py.gluon.tools.Service.xml" class="py-name" href="#" onclick="return doclink('link-2527', 'xml', 'link-2527');">xml</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5798"></a><tt class="py-lineno">5798</tt>  <tt class="py-line"> </tt>
<a name="Rows.json"></a><div id="Rows.json-def"><a name="L5799"></a><tt class="py-lineno">5799</tt> <a class="py-toggle" href="#" id="Rows.json-toggle" onclick="return toggle('Rows.json');">-</a><tt class="py-line">    <tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal.Rows-class.html#json">json</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">mode</tt><tt class="py-op">=</tt><tt class="py-string">'object'</tt><tt class="py-op">,</tt> <tt class="py-param">default</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows.json-collapsed" style="display:none;" pad="++++" indent="++++++++"></div><div id="Rows.json-expanded"><a name="L5800"></a><tt class="py-lineno">5800</tt>  <tt class="py-line">        <tt class="py-docstring">"""</tt> </tt>
<a name="L5801"></a><tt class="py-lineno">5801</tt>  <tt class="py-line"><tt class="py-docstring">        serializes the table to a JSON list of objects</tt> </tt>
<a name="L5802"></a><tt class="py-lineno">5802</tt>  <tt class="py-line"><tt class="py-docstring">        """</tt> </tt>
<a name="L5803"></a><tt class="py-lineno">5803</tt>  <tt class="py-line">        <tt class="py-name">mode</tt> <tt class="py-op">=</tt> <tt class="py-name">mode</tt><tt class="py-op">.</tt><tt id="link-2528" class="py-name"><a title="web2py.gluon.dal.Expression.lower" class="py-name" href="#" onclick="return doclink('link-2528', 'lower', 'link-265');">lower</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L5804"></a><tt class="py-lineno">5804</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt class="py-name">mode</tt> <tt class="py-keyword">in</tt> <tt class="py-op">[</tt><tt class="py-string">'object'</tt><tt class="py-op">,</tt> <tt class="py-string">'array'</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt>
<a name="L5805"></a><tt class="py-lineno">5805</tt>  <tt class="py-line">            <tt class="py-keyword">raise</tt> <tt class="py-name">SyntaxError</tt><tt class="py-op">,</tt> <tt class="py-string">'Invalid JSON serialization mode: %s'</tt> <tt class="py-op">%</tt> <tt class="py-name">mode</tt> </tt>
<a name="L5806"></a><tt class="py-lineno">5806</tt>  <tt class="py-line"> </tt>
<a name="L5807"></a><tt class="py-lineno">5807</tt>  <tt class="py-line">        <tt class="py-keyword">def</tt> <tt class="py-def-name">inner_loop</tt><tt class="py-op">(</tt><tt class="py-param">record</tt><tt class="py-op">,</tt> <tt class="py-param">col</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5808"></a><tt class="py-lineno">5808</tt>  <tt class="py-line">            <tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">f</tt><tt class="py-op">)</tt> <tt class="py-op">=</tt> <tt class="py-name">col</tt><tt class="py-op">.</tt><tt class="py-name">split</tt><tt class="py-op">(</tt><tt class="py-string">'.'</tt><tt class="py-op">)</tt> </tt>
<a name="L5809"></a><tt class="py-lineno">5809</tt>  <tt class="py-line">            <tt class="py-name">res</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt>
<a name="L5810"></a><tt class="py-lineno">5810</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-keyword">not</tt> <tt id="link-2529" class="py-name"><a title="web2py.gluon.dal.table_field
web2py.gluon.sqlhtml.table_field" class="py-name" href="#" onclick="return doclink('link-2529', 'table_field', 'link-29');">table_field</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">col</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5811"></a><tt class="py-lineno">5811</tt>  <tt class="py-line">                <tt class="py-name">res</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">.</tt><tt class="py-name">_extra</tt><tt class="py-op">[</tt><tt class="py-name">col</tt><tt class="py-op">]</tt> </tt>
<a name="L5812"></a><tt class="py-lineno">5812</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5813"></a><tt class="py-lineno">5813</tt>  <tt class="py-line">                <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">record</tt><tt class="py-op">.</tt><tt id="link-2530" class="py-name"><a title="web2py.gluon.rocket.Headers.get" class="py-name" href="#" onclick="return doclink('link-2530', 'get', 'link-487');">get</a></tt><tt class="py-op">(</tt><tt class="py-name">t</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt id="link-2531" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2531', 'Row', 'link-600');">Row</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
<a name="L5814"></a><tt class="py-lineno">5814</tt>  <tt class="py-line">                    <tt class="py-name">res</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">[</tt><tt class="py-name">t</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt> </tt>
<a name="L5815"></a><tt class="py-lineno">5815</tt>  <tt class="py-line">                <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5816"></a><tt class="py-lineno">5816</tt>  <tt class="py-line">                    <tt class="py-name">res</tt> <tt class="py-op">=</tt> <tt class="py-name">record</tt><tt class="py-op">[</tt><tt class="py-name">f</tt><tt class="py-op">]</tt> </tt>
<a name="L5817"></a><tt class="py-lineno">5817</tt>  <tt class="py-line">            <tt class="py-keyword">if</tt> <tt class="py-name">mode</tt> <tt class="py-op">==</tt> <tt class="py-string">'object'</tt><tt class="py-op">:</tt> </tt>
<a name="L5818"></a><tt class="py-lineno">5818</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-op">(</tt><tt class="py-name">f</tt><tt class="py-op">,</tt> <tt class="py-name">res</tt><tt class="py-op">)</tt> </tt>
<a name="L5819"></a><tt class="py-lineno">5819</tt>  <tt class="py-line">            <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5820"></a><tt class="py-lineno">5820</tt>  <tt class="py-line">                <tt class="py-keyword">return</tt> <tt class="py-name">res</tt> </tt>
</div><a name="L5821"></a><tt class="py-lineno">5821</tt>  <tt class="py-line"> </tt>
<a name="L5822"></a><tt class="py-lineno">5822</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt class="py-name">mode</tt> <tt class="py-op">==</tt> <tt class="py-string">'object'</tt><tt class="py-op">:</tt> </tt>
<a name="L5823"></a><tt class="py-lineno">5823</tt>  <tt class="py-line">            <tt id="link-2532" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2532', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">dict</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">inner_loop</tt><tt class="py-op">(</tt><tt class="py-name">record</tt><tt class="py-op">,</tt> <tt class="py-name">col</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">col</tt> <tt class="py-keyword">in</tt> </tt>
<a name="L5824"></a><tt class="py-lineno">5824</tt>  <tt class="py-line">                     <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">record</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">]</tt> </tt>
<a name="L5825"></a><tt class="py-lineno">5825</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5826"></a><tt class="py-lineno">5826</tt>  <tt class="py-line">            <tt id="link-2533" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2533', 'items', 'link-266');">items</a></tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">[</tt><tt class="py-name">inner_loop</tt><tt class="py-op">(</tt><tt class="py-name">record</tt><tt class="py-op">,</tt> <tt class="py-name">col</tt><tt class="py-op">)</tt> <tt class="py-keyword">for</tt> <tt class="py-name">col</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">colnames</tt><tt class="py-op">]</tt> </tt>
<a name="L5827"></a><tt class="py-lineno">5827</tt>  <tt class="py-line">                     <tt class="py-keyword">for</tt> <tt class="py-name">record</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">]</tt> </tt>
<a name="L5828"></a><tt class="py-lineno">5828</tt>  <tt class="py-line">        <tt class="py-keyword">if</tt> <tt id="link-2534" class="py-name"><a title="web2py.gluon.dal.have_serializers" class="py-name" href="#" onclick="return doclink('link-2534', 'have_serializers', 'link-19');">have_serializers</a></tt><tt class="py-op">:</tt> </tt>
<a name="L5829"></a><tt class="py-lineno">5829</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt id="link-2535" class="py-name"><a title="web2py.gluon.serializers" class="py-name" href="#" onclick="return doclink('link-2535', 'serializers', 'link-18');">serializers</a></tt><tt class="py-op">.</tt><tt id="link-2536" class="py-name" targets="Method web2py.gluon.dal.Rows.json()=web2py.gluon.dal.Rows-class.html#json,Method web2py.gluon.globals.Response.json()=web2py.gluon.globals.Response-class.html#json,Function web2py.gluon.serializers.json()=web2py.gluon.serializers-module.html#json,Method web2py.gluon.tools.Service.json()=web2py.gluon.tools.Service-class.html#json"><a title="web2py.gluon.dal.Rows.json
web2py.gluon.globals.Response.json
web2py.gluon.serializers.json
web2py.gluon.tools.Service.json" class="py-name" href="#" onclick="return doclink('link-2536', 'json', 'link-2536');">json</a></tt><tt class="py-op">(</tt><tt id="link-2537" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2537', 'items', 'link-266');">items</a></tt><tt class="py-op">,</tt><tt class="py-name">default</tt><tt class="py-op">=</tt><tt class="py-name">default</tt> <tt class="py-keyword">or</tt> <tt id="link-2538" class="py-name"><a title="web2py.gluon.serializers" class="py-name" href="#" onclick="return doclink('link-2538', 'serializers', 'link-18');">serializers</a></tt><tt class="py-op">.</tt><tt id="link-2539" class="py-name" targets="Function web2py.gluon.serializers.custom_json()=web2py.gluon.serializers-module.html#custom_json"><a title="web2py.gluon.serializers.custom_json" class="py-name" href="#" onclick="return doclink('link-2539', 'custom_json', 'link-2539');">custom_json</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5830"></a><tt class="py-lineno">5830</tt>  <tt class="py-line">        <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt>
<a name="L5831"></a><tt class="py-lineno">5831</tt>  <tt class="py-line">            <tt class="py-keyword">import</tt> <tt class="py-name">simplejson</tt> </tt>
<a name="L5832"></a><tt class="py-lineno">5832</tt>  <tt class="py-line">            <tt class="py-keyword">return</tt> <tt class="py-name">simplejson</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt><tt id="link-2540" class="py-name"><a title="web2py.gluon.rocket.Headers.items" class="py-name" href="#" onclick="return doclink('link-2540', 'items', 'link-266');">items</a></tt><tt class="py-op">)</tt> </tt>
</div></div><a name="L5833"></a><tt class="py-lineno">5833</tt>  <tt class="py-line"> </tt>
<a name="Rows_unpickler"></a><div id="Rows_unpickler-def"><a name="L5834"></a><tt class="py-lineno">5834</tt> <a class="py-toggle" href="#" id="Rows_unpickler-toggle" onclick="return toggle('Rows_unpickler');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#Rows_unpickler">Rows_unpickler</a><tt class="py-op">(</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows_unpickler-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Rows_unpickler-expanded"><a name="L5835"></a><tt class="py-lineno">5835</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">loads</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5836"></a><tt class="py-lineno">5836</tt>  <tt class="py-line"> </tt>
<a name="Rows_pickler"></a><div id="Rows_pickler-def"><a name="L5837"></a><tt class="py-lineno">5837</tt> <a class="py-toggle" href="#" id="Rows_pickler-toggle" onclick="return toggle('Rows_pickler');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#Rows_pickler">Rows_pickler</a><tt class="py-op">(</tt><tt class="py-param">data</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="Rows_pickler-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="Rows_pickler-expanded"><a name="L5838"></a><tt class="py-lineno">5838</tt>  <tt class="py-line">    <tt class="py-keyword">return</tt> <tt id="link-2541" class="py-name" targets="Function web2py.gluon.dal.Rows_unpickler()=web2py.gluon.dal-module.html#Rows_unpickler"><a title="web2py.gluon.dal.Rows_unpickler" class="py-name" href="#" onclick="return doclink('link-2541', 'Rows_unpickler', 'link-2541');">Rows_unpickler</a></tt><tt class="py-op">,</tt> \ </tt>
<a name="L5839"></a><tt class="py-lineno">5839</tt>  <tt class="py-line">        <tt class="py-op">(</tt><tt class="py-name">cPickle</tt><tt class="py-op">.</tt><tt class="py-name">dumps</tt><tt class="py-op">(</tt><tt class="py-name">data</tt><tt class="py-op">.</tt><tt id="link-2542" class="py-name"><a title="web2py.gluon.dal.Rows.as_list" class="py-name" href="#" onclick="return doclink('link-2542', 'as_list', 'link-2500');">as_list</a></tt><tt class="py-op">(</tt><tt class="py-name">storage_to_dict</tt><tt class="py-op">=</tt><tt class="py-name">True</tt><tt class="py-op">,</tt> </tt>
<a name="L5840"></a><tt class="py-lineno">5840</tt>  <tt class="py-line">                                    <tt class="py-name">datetime_to_str</tt><tt class="py-op">=</tt><tt class="py-name">False</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt><tt class="py-op">)</tt> </tt>
</div><a name="L5841"></a><tt class="py-lineno">5841</tt>  <tt class="py-line"> </tt>
<a name="L5842"></a><tt class="py-lineno">5842</tt>  <tt class="py-line"><tt class="py-name">copy_reg</tt><tt class="py-op">.</tt><tt class="py-name">pickle</tt><tt class="py-op">(</tt><tt id="link-2543" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2543', 'Rows', 'link-679');">Rows</a></tt><tt class="py-op">,</tt> <tt id="link-2544" class="py-name" targets="Function web2py.gluon.dal.Rows_pickler()=web2py.gluon.dal-module.html#Rows_pickler"><a title="web2py.gluon.dal.Rows_pickler" class="py-name" href="#" onclick="return doclink('link-2544', 'Rows_pickler', 'link-2544');">Rows_pickler</a></tt><tt class="py-op">,</tt> <tt id="link-2545" class="py-name"><a title="web2py.gluon.dal.Rows_unpickler" class="py-name" href="#" onclick="return doclink('link-2545', 'Rows_unpickler', 'link-2541');">Rows_unpickler</a></tt><tt class="py-op">)</tt> </tt>
<a name="L5843"></a><tt class="py-lineno">5843</tt>  <tt class="py-line"> </tt>
<a name="L5844"></a><tt class="py-lineno">5844</tt>  <tt class="py-line"> </tt>
<a name="L5845"></a><tt class="py-lineno">5845</tt>  <tt class="py-line"><tt class="py-comment">################################################################################</tt> </tt>
<a name="L5846"></a><tt class="py-lineno">5846</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># dummy function used to define some doctests</tt> </tt>
<a name="L5847"></a><tt class="py-lineno">5847</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">################################################################################</tt> </tt>
<a name="L5848"></a><tt class="py-lineno">5848</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="test_all"></a><div id="test_all-def"><a name="L5849"></a><tt class="py-lineno">5849</tt> <a class="py-toggle" href="#" id="test_all-toggle" onclick="return toggle('test_all');">-</a><tt class="py-line"><tt class="py-keyword">def</tt> <a class="py-def-name" href="web2py.gluon.dal-module.html#test_all">test_all</a><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt>
</div><div id="test_all-collapsed" style="display:none;" pad="++++" indent="++++"></div><div id="test_all-expanded"><a name="L5850"></a><tt class="py-lineno">5850</tt>  <tt class="py-line">    <tt class="py-docstring">"""</tt> </tt>
<a name="L5851"></a><tt class="py-lineno">5851</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5852"></a><tt class="py-lineno">5852</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; if len(sys.argv)&lt;2: db = DAL(\"sqlite://test.db\")</tt> </tt>
<a name="L5853"></a><tt class="py-lineno">5853</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; if len(sys.argv)&gt;1: db = DAL(sys.argv[1])</tt> </tt>
<a name="L5854"></a><tt class="py-lineno">5854</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.define_table('users',\</tt> </tt>
<a name="L5855"></a><tt class="py-lineno">5855</tt>  <tt class="py-line"><tt class="py-docstring">              Field('stringf', 'string', length=32, required=True),\</tt> </tt>
<a name="L5856"></a><tt class="py-lineno">5856</tt>  <tt class="py-line"><tt class="py-docstring">              Field('booleanf', 'boolean', default=False),\</tt> </tt>
<a name="L5857"></a><tt class="py-lineno">5857</tt>  <tt class="py-line"><tt class="py-docstring">              Field('passwordf', 'password', notnull=True),\</tt> </tt>
<a name="L5858"></a><tt class="py-lineno">5858</tt>  <tt class="py-line"><tt class="py-docstring">              Field('uploadf', 'upload'),\</tt> </tt>
<a name="L5859"></a><tt class="py-lineno">5859</tt>  <tt class="py-line"><tt class="py-docstring">              Field('blobf', 'blob'),\</tt> </tt>
<a name="L5860"></a><tt class="py-lineno">5860</tt>  <tt class="py-line"><tt class="py-docstring">              Field('integerf', 'integer', unique=True),\</tt> </tt>
<a name="L5861"></a><tt class="py-lineno">5861</tt>  <tt class="py-line"><tt class="py-docstring">              Field('doublef', 'double', unique=True,notnull=True),\</tt> </tt>
<a name="L5862"></a><tt class="py-lineno">5862</tt>  <tt class="py-line"><tt class="py-docstring">              Field('datef', 'date', default=datetime.date.today()),\</tt> </tt>
<a name="L5863"></a><tt class="py-lineno">5863</tt>  <tt class="py-line"><tt class="py-docstring">              Field('timef', 'time'),\</tt> </tt>
<a name="L5864"></a><tt class="py-lineno">5864</tt>  <tt class="py-line"><tt class="py-docstring">              Field('datetimef', 'datetime'),\</tt> </tt>
<a name="L5865"></a><tt class="py-lineno">5865</tt>  <tt class="py-line"><tt class="py-docstring">              migrate='test_user.table')</tt> </tt>
<a name="L5866"></a><tt class="py-lineno">5866</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5867"></a><tt class="py-lineno">5867</tt>  <tt class="py-line"><tt class="py-docstring">   Insert a field</tt> </tt>
<a name="L5868"></a><tt class="py-lineno">5868</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5869"></a><tt class="py-lineno">5869</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.users.insert(stringf='a', booleanf=True, passwordf='p', blobf='0A',\</tt> </tt>
<a name="L5870"></a><tt class="py-lineno">5870</tt>  <tt class="py-line"><tt class="py-docstring">                       uploadf=None, integerf=5, doublef=3.14,\</tt> </tt>
<a name="L5871"></a><tt class="py-lineno">5871</tt>  <tt class="py-line"><tt class="py-docstring">                       datef=datetime.date(2001, 1, 1),\</tt> </tt>
<a name="L5872"></a><tt class="py-lineno">5872</tt>  <tt class="py-line"><tt class="py-docstring">                       timef=datetime.time(12, 30, 15),\</tt> </tt>
<a name="L5873"></a><tt class="py-lineno">5873</tt>  <tt class="py-line"><tt class="py-docstring">                       datetimef=datetime.datetime(2002, 2, 2, 12, 30, 15))</tt> </tt>
<a name="L5874"></a><tt class="py-lineno">5874</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5875"></a><tt class="py-lineno">5875</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5876"></a><tt class="py-lineno">5876</tt>  <tt class="py-line"><tt class="py-docstring">    Drop the table</tt> </tt>
<a name="L5877"></a><tt class="py-lineno">5877</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5878"></a><tt class="py-lineno">5878</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.users.drop()</tt> </tt>
<a name="L5879"></a><tt class="py-lineno">5879</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5880"></a><tt class="py-lineno">5880</tt>  <tt class="py-line"><tt class="py-docstring">    Examples of insert, select, update, delete</tt> </tt>
<a name="L5881"></a><tt class="py-lineno">5881</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5882"></a><tt class="py-lineno">5882</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.define_table('person',\</tt> </tt>
<a name="L5883"></a><tt class="py-lineno">5883</tt>  <tt class="py-line"><tt class="py-docstring">              Field('name'),\</tt> </tt>
<a name="L5884"></a><tt class="py-lineno">5884</tt>  <tt class="py-line"><tt class="py-docstring">              Field('birth','date'),\</tt> </tt>
<a name="L5885"></a><tt class="py-lineno">5885</tt>  <tt class="py-line"><tt class="py-docstring">              migrate='test_person.table')</tt> </tt>
<a name="L5886"></a><tt class="py-lineno">5886</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; person_id = db.person.insert(name=\"Marco\",birth='2005-06-22')</tt> </tt>
<a name="L5887"></a><tt class="py-lineno">5887</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; person_id = db.person.insert(name=\"Massimo\",birth='1971-12-21')</tt> </tt>
<a name="L5888"></a><tt class="py-lineno">5888</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5889"></a><tt class="py-lineno">5889</tt>  <tt class="py-line"><tt class="py-docstring">    commented len(db().select(db.person.ALL))</tt> </tt>
<a name="L5890"></a><tt class="py-lineno">5890</tt>  <tt class="py-line"><tt class="py-docstring">    commented 2</tt> </tt>
<a name="L5891"></a><tt class="py-lineno">5891</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5892"></a><tt class="py-lineno">5892</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; me = db(db.person.id==person_id).select()[0] # test select</tt> </tt>
<a name="L5893"></a><tt class="py-lineno">5893</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; me.name</tt> </tt>
<a name="L5894"></a><tt class="py-lineno">5894</tt>  <tt class="py-line"><tt class="py-docstring">    'Massimo'</tt> </tt>
<a name="L5895"></a><tt class="py-lineno">5895</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db(db.person.name=='Massimo').update(name='massimo') # test update</tt> </tt>
<a name="L5896"></a><tt class="py-lineno">5896</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5897"></a><tt class="py-lineno">5897</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db(db.person.name=='Marco').select().first().delete_record() # test delete</tt> </tt>
<a name="L5898"></a><tt class="py-lineno">5898</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5899"></a><tt class="py-lineno">5899</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5900"></a><tt class="py-lineno">5900</tt>  <tt class="py-line"><tt class="py-docstring">    Update a single record</tt> </tt>
<a name="L5901"></a><tt class="py-lineno">5901</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5902"></a><tt class="py-lineno">5902</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; me.update_record(name=\"Max\")</tt> </tt>
<a name="L5903"></a><tt class="py-lineno">5903</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; me.name</tt> </tt>
<a name="L5904"></a><tt class="py-lineno">5904</tt>  <tt class="py-line"><tt class="py-docstring">    'Max'</tt> </tt>
<a name="L5905"></a><tt class="py-lineno">5905</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5906"></a><tt class="py-lineno">5906</tt>  <tt class="py-line"><tt class="py-docstring">    Examples of complex search conditions</tt> </tt>
<a name="L5907"></a><tt class="py-lineno">5907</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5908"></a><tt class="py-lineno">5908</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db((db.person.name=='Max')&amp;(db.person.birth&lt;'2003-01-01')).select())</tt> </tt>
<a name="L5909"></a><tt class="py-lineno">5909</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5910"></a><tt class="py-lineno">5910</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db((db.person.name=='Max')&amp;(db.person.birth&lt;datetime.date(2003,01,01))).select())</tt> </tt>
<a name="L5911"></a><tt class="py-lineno">5911</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5912"></a><tt class="py-lineno">5912</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db((db.person.name=='Max')|(db.person.birth&lt;'2003-01-01')).select())</tt> </tt>
<a name="L5913"></a><tt class="py-lineno">5913</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5914"></a><tt class="py-lineno">5914</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; me = db(db.person.id==person_id).select(db.person.name)[0]</tt> </tt>
<a name="L5915"></a><tt class="py-lineno">5915</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; me.name</tt> </tt>
<a name="L5916"></a><tt class="py-lineno">5916</tt>  <tt class="py-line"><tt class="py-docstring">    'Max'</tt> </tt>
<a name="L5917"></a><tt class="py-lineno">5917</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5918"></a><tt class="py-lineno">5918</tt>  <tt class="py-line"><tt class="py-docstring">    Examples of search conditions using extract from date/datetime/time</tt> </tt>
<a name="L5919"></a><tt class="py-lineno">5919</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5920"></a><tt class="py-lineno">5920</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.birth.month()==12).select())</tt> </tt>
<a name="L5921"></a><tt class="py-lineno">5921</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5922"></a><tt class="py-lineno">5922</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.birth.year()&gt;1900).select())</tt> </tt>
<a name="L5923"></a><tt class="py-lineno">5923</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5924"></a><tt class="py-lineno">5924</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5925"></a><tt class="py-lineno">5925</tt>  <tt class="py-line"><tt class="py-docstring">    Example of usage of NULL</tt> </tt>
<a name="L5926"></a><tt class="py-lineno">5926</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5927"></a><tt class="py-lineno">5927</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.birth==None).select()) ### test NULL</tt> </tt>
<a name="L5928"></a><tt class="py-lineno">5928</tt>  <tt class="py-line"><tt class="py-docstring">    0</tt> </tt>
<a name="L5929"></a><tt class="py-lineno">5929</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.birth!=None).select()) ### test NULL</tt> </tt>
<a name="L5930"></a><tt class="py-lineno">5930</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5931"></a><tt class="py-lineno">5931</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5932"></a><tt class="py-lineno">5932</tt>  <tt class="py-line"><tt class="py-docstring">    Examples of search conditions using lower, upper, and like</tt> </tt>
<a name="L5933"></a><tt class="py-lineno">5933</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5934"></a><tt class="py-lineno">5934</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.name.upper()=='MAX').select())</tt> </tt>
<a name="L5935"></a><tt class="py-lineno">5935</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5936"></a><tt class="py-lineno">5936</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.name.like('%ax')).select())</tt> </tt>
<a name="L5937"></a><tt class="py-lineno">5937</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5938"></a><tt class="py-lineno">5938</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.person.name.upper().like('%AX')).select())</tt> </tt>
<a name="L5939"></a><tt class="py-lineno">5939</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5940"></a><tt class="py-lineno">5940</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(~db.person.name.upper().like('%AX')).select())</tt> </tt>
<a name="L5941"></a><tt class="py-lineno">5941</tt>  <tt class="py-line"><tt class="py-docstring">    0</tt> </tt>
<a name="L5942"></a><tt class="py-lineno">5942</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5943"></a><tt class="py-lineno">5943</tt>  <tt class="py-line"><tt class="py-docstring">    orderby, groupby and limitby</tt> </tt>
<a name="L5944"></a><tt class="py-lineno">5944</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5945"></a><tt class="py-lineno">5945</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; people = db().select(db.person.name, orderby=db.person.name)</tt> </tt>
<a name="L5946"></a><tt class="py-lineno">5946</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; order = db.person.name|~db.person.birth</tt> </tt>
<a name="L5947"></a><tt class="py-lineno">5947</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; people = db().select(db.person.name, orderby=order)</tt> </tt>
<a name="L5948"></a><tt class="py-lineno">5948</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5949"></a><tt class="py-lineno">5949</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; people = db().select(db.person.name, orderby=db.person.name, groupby=db.person.name)</tt> </tt>
<a name="L5950"></a><tt class="py-lineno">5950</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5951"></a><tt class="py-lineno">5951</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; people = db().select(db.person.name, orderby=order, limitby=(0,100))</tt> </tt>
<a name="L5952"></a><tt class="py-lineno">5952</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5953"></a><tt class="py-lineno">5953</tt>  <tt class="py-line"><tt class="py-docstring">    Example of one 2 many relation</tt> </tt>
<a name="L5954"></a><tt class="py-lineno">5954</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5955"></a><tt class="py-lineno">5955</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.define_table('dog',\</tt> </tt>
<a name="L5956"></a><tt class="py-lineno">5956</tt>  <tt class="py-line"><tt class="py-docstring">               Field('name'),\</tt> </tt>
<a name="L5957"></a><tt class="py-lineno">5957</tt>  <tt class="py-line"><tt class="py-docstring">               Field('birth','date'),\</tt> </tt>
<a name="L5958"></a><tt class="py-lineno">5958</tt>  <tt class="py-line"><tt class="py-docstring">               Field('owner',db.person),\</tt> </tt>
<a name="L5959"></a><tt class="py-lineno">5959</tt>  <tt class="py-line"><tt class="py-docstring">               migrate='test_dog.table')</tt> </tt>
<a name="L5960"></a><tt class="py-lineno">5960</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.dog.insert(name='Snoopy', birth=None, owner=person_id)</tt> </tt>
<a name="L5961"></a><tt class="py-lineno">5961</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5962"></a><tt class="py-lineno">5962</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5963"></a><tt class="py-lineno">5963</tt>  <tt class="py-line"><tt class="py-docstring">    A simple JOIN</tt> </tt>
<a name="L5964"></a><tt class="py-lineno">5964</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5965"></a><tt class="py-lineno">5965</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db(db.dog.owner==db.person.id).select())</tt> </tt>
<a name="L5966"></a><tt class="py-lineno">5966</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5967"></a><tt class="py-lineno">5967</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5968"></a><tt class="py-lineno">5968</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; len(db().select(db.person.ALL, db.dog.name,left=db.dog.on(db.dog.owner==db.person.id)))</tt> </tt>
<a name="L5969"></a><tt class="py-lineno">5969</tt>  <tt class="py-line"><tt class="py-docstring">    1</tt> </tt>
<a name="L5970"></a><tt class="py-lineno">5970</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5971"></a><tt class="py-lineno">5971</tt>  <tt class="py-line"><tt class="py-docstring">    Drop tables</tt> </tt>
<a name="L5972"></a><tt class="py-lineno">5972</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5973"></a><tt class="py-lineno">5973</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.dog.drop()</tt> </tt>
<a name="L5974"></a><tt class="py-lineno">5974</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.person.drop()</tt> </tt>
<a name="L5975"></a><tt class="py-lineno">5975</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5976"></a><tt class="py-lineno">5976</tt>  <tt class="py-line"><tt class="py-docstring">    Example of many 2 many relation and Set</tt> </tt>
<a name="L5977"></a><tt class="py-lineno">5977</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5978"></a><tt class="py-lineno">5978</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.define_table('author', Field('name'),\</tt> </tt>
<a name="L5979"></a><tt class="py-lineno">5979</tt>  <tt class="py-line"><tt class="py-docstring">                            migrate='test_author.table')</tt> </tt>
<a name="L5980"></a><tt class="py-lineno">5980</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.define_table('paper', Field('title'),\</tt> </tt>
<a name="L5981"></a><tt class="py-lineno">5981</tt>  <tt class="py-line"><tt class="py-docstring">                            migrate='test_paper.table')</tt> </tt>
<a name="L5982"></a><tt class="py-lineno">5982</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.define_table('authorship',\</tt> </tt>
<a name="L5983"></a><tt class="py-lineno">5983</tt>  <tt class="py-line"><tt class="py-docstring">            Field('author_id', db.author),\</tt> </tt>
<a name="L5984"></a><tt class="py-lineno">5984</tt>  <tt class="py-line"><tt class="py-docstring">            Field('paper_id', db.paper),\</tt> </tt>
<a name="L5985"></a><tt class="py-lineno">5985</tt>  <tt class="py-line"><tt class="py-docstring">            migrate='test_authorship.table')</tt> </tt>
<a name="L5986"></a><tt class="py-lineno">5986</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; aid = db.author.insert(name='Massimo')</tt> </tt>
<a name="L5987"></a><tt class="py-lineno">5987</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; pid = db.paper.insert(title='QCD')</tt> </tt>
<a name="L5988"></a><tt class="py-lineno">5988</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; tmp = db.authorship.insert(author_id=aid, paper_id=pid)</tt> </tt>
<a name="L5989"></a><tt class="py-lineno">5989</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5990"></a><tt class="py-lineno">5990</tt>  <tt class="py-line"><tt class="py-docstring">    Define a Set</tt> </tt>
<a name="L5991"></a><tt class="py-lineno">5991</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5992"></a><tt class="py-lineno">5992</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; authored_papers = db((db.author.id==db.authorship.author_id)&amp;(db.paper.id==db.authorship.paper_id))</tt> </tt>
<a name="L5993"></a><tt class="py-lineno">5993</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; rows = authored_papers.select(db.author.name, db.paper.title)</tt> </tt>
<a name="L5994"></a><tt class="py-lineno">5994</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; for row in rows: print row.author.name, row.paper.title</tt> </tt>
<a name="L5995"></a><tt class="py-lineno">5995</tt>  <tt class="py-line"><tt class="py-docstring">    Massimo QCD</tt> </tt>
<a name="L5996"></a><tt class="py-lineno">5996</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5997"></a><tt class="py-lineno">5997</tt>  <tt class="py-line"><tt class="py-docstring">    Example of search condition using  belongs</tt> </tt>
<a name="L5998"></a><tt class="py-lineno">5998</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L5999"></a><tt class="py-lineno">5999</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; set = (1, 2, 3)</tt> </tt>
<a name="L6000"></a><tt class="py-lineno">6000</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; rows = db(db.paper.id.belongs(set)).select(db.paper.ALL)</tt> </tt>
<a name="L6001"></a><tt class="py-lineno">6001</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; print rows[0].title</tt> </tt>
<a name="L6002"></a><tt class="py-lineno">6002</tt>  <tt class="py-line"><tt class="py-docstring">    QCD</tt> </tt>
<a name="L6003"></a><tt class="py-lineno">6003</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6004"></a><tt class="py-lineno">6004</tt>  <tt class="py-line"><tt class="py-docstring">    Example of search condition using nested select</tt> </tt>
<a name="L6005"></a><tt class="py-lineno">6005</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6006"></a><tt class="py-lineno">6006</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; nested_select = db()._select(db.authorship.paper_id)</tt> </tt>
<a name="L6007"></a><tt class="py-lineno">6007</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; rows = db(db.paper.id.belongs(nested_select)).select(db.paper.ALL)</tt> </tt>
<a name="L6008"></a><tt class="py-lineno">6008</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; print rows[0].title</tt> </tt>
<a name="L6009"></a><tt class="py-lineno">6009</tt>  <tt class="py-line"><tt class="py-docstring">    QCD</tt> </tt>
<a name="L6010"></a><tt class="py-lineno">6010</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6011"></a><tt class="py-lineno">6011</tt>  <tt class="py-line"><tt class="py-docstring">    Example of expressions</tt> </tt>
<a name="L6012"></a><tt class="py-lineno">6012</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6013"></a><tt class="py-lineno">6013</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; mynumber = db.define_table('mynumber', Field('x', 'integer'))</tt> </tt>
<a name="L6014"></a><tt class="py-lineno">6014</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db(mynumber.id&gt;0).delete()</tt> </tt>
<a name="L6015"></a><tt class="py-lineno">6015</tt>  <tt class="py-line"><tt class="py-docstring">    0</tt> </tt>
<a name="L6016"></a><tt class="py-lineno">6016</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; for i in range(10): tmp = mynumber.insert(x=i)</tt> </tt>
<a name="L6017"></a><tt class="py-lineno">6017</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db(mynumber.id&gt;0).select(mynumber.x.sum())[0](mynumber.x.sum())</tt> </tt>
<a name="L6018"></a><tt class="py-lineno">6018</tt>  <tt class="py-line"><tt class="py-docstring">    45</tt> </tt>
<a name="L6019"></a><tt class="py-lineno">6019</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6020"></a><tt class="py-lineno">6020</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db(mynumber.x+2==5).select(mynumber.x + 2)[0](mynumber.x + 2)</tt> </tt>
<a name="L6021"></a><tt class="py-lineno">6021</tt>  <tt class="py-line"><tt class="py-docstring">    5</tt> </tt>
<a name="L6022"></a><tt class="py-lineno">6022</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6023"></a><tt class="py-lineno">6023</tt>  <tt class="py-line"><tt class="py-docstring">    Output in csv</tt> </tt>
<a name="L6024"></a><tt class="py-lineno">6024</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6025"></a><tt class="py-lineno">6025</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; print str(authored_papers.select(db.author.name, db.paper.title)).strip()</tt> </tt>
<a name="L6026"></a><tt class="py-lineno">6026</tt>  <tt class="py-line"><tt class="py-docstring">    author.name,paper.title\r</tt> </tt>
<a name="L6027"></a><tt class="py-lineno">6027</tt>  <tt class="py-line"><tt class="py-docstring">    Massimo,QCD</tt> </tt>
<a name="L6028"></a><tt class="py-lineno">6028</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6029"></a><tt class="py-lineno">6029</tt>  <tt class="py-line"><tt class="py-docstring">    Delete all leftover tables</tt> </tt>
<a name="L6030"></a><tt class="py-lineno">6030</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6031"></a><tt class="py-lineno">6031</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; DAL.distributed_transaction_commit(db)</tt> </tt>
<a name="L6032"></a><tt class="py-lineno">6032</tt>  <tt class="py-line"><tt class="py-docstring"></tt> </tt>
<a name="L6033"></a><tt class="py-lineno">6033</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.mynumber.drop()</tt> </tt>
<a name="L6034"></a><tt class="py-lineno">6034</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.authorship.drop()</tt> </tt>
<a name="L6035"></a><tt class="py-lineno">6035</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.author.drop()</tt> </tt>
<a name="L6036"></a><tt class="py-lineno">6036</tt>  <tt class="py-line"><tt class="py-docstring">    &gt;&gt;&gt; db.paper.drop()</tt> </tt>
<a name="L6037"></a><tt class="py-lineno">6037</tt>  <tt class="py-line"><tt class="py-docstring">    """</tt> </tt>
</div><a name="L6038"></a><tt class="py-lineno">6038</tt>  <tt class="py-line"><tt class="py-comment">################################################################################</tt> </tt>
<a name="L6039"></a><tt class="py-lineno">6039</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># deprecated since the new DAL; here only for backward compatibility</tt> </tt>
<a name="L6040"></a><tt class="py-lineno">6040</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">################################################################################</tt> </tt>
<a name="L6041"></a><tt class="py-lineno">6041</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L6042"></a><tt class="py-lineno">6042</tt>  <tt class="py-line"><tt class="py-name">SQLField</tt> <tt class="py-op">=</tt> <tt id="link-2546" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2546', 'Field', 'link-430');">Field</a></tt> </tt>
<a name="L6043"></a><tt class="py-lineno">6043</tt>  <tt class="py-line"><tt class="py-name">SQLTable</tt> <tt class="py-op">=</tt> <tt id="link-2547" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2547', 'Table', 'link-1207');">Table</a></tt> </tt>
<a name="L6044"></a><tt class="py-lineno">6044</tt>  <tt class="py-line"><tt class="py-name">SQLXorable</tt> <tt class="py-op">=</tt> <tt id="link-2548" class="py-name"><a title="web2py.gluon.dal.Expression" class="py-name" href="#" onclick="return doclink('link-2548', 'Expression', 'link-431');">Expression</a></tt> </tt>
<a name="L6045"></a><tt class="py-lineno">6045</tt>  <tt class="py-line"><tt class="py-name">SQLQuery</tt> <tt class="py-op">=</tt> <tt id="link-2549" class="py-name"><a title="web2py.gluon.dal.Query" class="py-name" href="#" onclick="return doclink('link-2549', 'Query', 'link-432');">Query</a></tt> </tt>
<a name="L6046"></a><tt class="py-lineno">6046</tt>  <tt class="py-line"><tt class="py-name">SQLSet</tt> <tt class="py-op">=</tt> <tt id="link-2550" class="py-name"><a title="web2py.gluon.dal.Set" class="py-name" href="#" onclick="return doclink('link-2550', 'Set', 'link-676');">Set</a></tt> </tt>
<a name="L6047"></a><tt class="py-lineno">6047</tt>  <tt class="py-line"><tt class="py-name">SQLRows</tt> <tt class="py-op">=</tt> <tt id="link-2551" class="py-name"><a title="web2py.gluon.dal.Rows" class="py-name" href="#" onclick="return doclink('link-2551', 'Rows', 'link-679');">Rows</a></tt> </tt>
<a name="L6048"></a><tt class="py-lineno">6048</tt>  <tt class="py-line"><tt class="py-name">SQLStorage</tt> <tt class="py-op">=</tt> <tt id="link-2552" class="py-name"><a title="web2py.gluon.dal.Row" class="py-name" href="#" onclick="return doclink('link-2552', 'Row', 'link-600');">Row</a></tt> </tt>
<a name="L6049"></a><tt class="py-lineno">6049</tt>  <tt class="py-line"><tt class="py-name">SQLDB</tt> <tt class="py-op">=</tt> <tt id="link-2553" class="py-name" targets="Class web2py.gluon.dal.DAL=web2py.gluon.dal.DAL-class.html"><a title="web2py.gluon.dal.DAL" class="py-name" href="#" onclick="return doclink('link-2553', 'DAL', 'link-2553');">DAL</a></tt> </tt>
<a name="L6050"></a><tt class="py-lineno">6050</tt>  <tt class="py-line"><tt class="py-name">GQLDB</tt> <tt class="py-op">=</tt> <tt id="link-2554" class="py-name"><a title="web2py.gluon.dal.DAL" class="py-name" href="#" onclick="return doclink('link-2554', 'DAL', 'link-2553');">DAL</a></tt> </tt>
<a name="L6051"></a><tt class="py-lineno">6051</tt>  <tt class="py-line"><tt id="link-2555" class="py-name"><a title="web2py.gluon.dal.DAL" class="py-name" href="#" onclick="return doclink('link-2555', 'DAL', 'link-2553');">DAL</a></tt><tt class="py-op">.</tt><tt id="link-2556" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2556', 'Field', 'link-430');">Field</a></tt> <tt class="py-op">=</tt> <tt id="link-2557" class="py-name"><a title="web2py.gluon.dal.Field" class="py-name" href="#" onclick="return doclink('link-2557', 'Field', 'link-430');">Field</a></tt>  <tt class="py-comment"># was necessary in gluon/globals.py session.connect</tt> </tt>
<a name="L6052"></a><tt class="py-lineno">6052</tt>  <tt class="py-line"><tt id="link-2558" class="py-name"><a title="web2py.gluon.dal.DAL" class="py-name" href="#" onclick="return doclink('link-2558', 'DAL', 'link-2553');">DAL</a></tt><tt class="py-op">.</tt><tt id="link-2559" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2559', 'Table', 'link-1207');">Table</a></tt> <tt class="py-op">=</tt> <tt id="link-2560" class="py-name"><a title="web2py.gluon.dal.Table" class="py-name" href="#" onclick="return doclink('link-2560', 'Table', 'link-1207');">Table</a></tt>  <tt class="py-comment"># was necessary in gluon/globals.py session.connect</tt> </tt>
<a name="L6053"></a><tt class="py-lineno">6053</tt>  <tt class="py-line"> </tt>
<a name="L6054"></a><tt class="py-lineno">6054</tt>  <tt class="py-line"><tt class="py-comment">################################################################################</tt> </tt>
<a name="L6055"></a><tt class="py-lineno">6055</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># run tests</tt> </tt>
<a name="L6056"></a><tt class="py-lineno">6056</tt>  <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">################################################################################</tt> </tt>
<a name="L6057"></a><tt class="py-lineno">6057</tt>  <tt class="py-line"><tt class="py-comment"></tt> </tt>
<a name="L6058"></a><tt class="py-lineno">6058</tt>  <tt class="py-line"><tt class="py-keyword">if</tt> <tt class="py-name">__name__</tt> <tt class="py-op">==</tt> <tt class="py-string">'__main__'</tt><tt class="py-op">:</tt> </tt>
<a name="L6059"></a><tt class="py-lineno">6059</tt>  <tt class="py-line">    <tt class="py-keyword">import</tt> <tt class="py-name">doctest</tt> </tt>
<a name="L6060"></a><tt class="py-lineno">6060</tt>  <tt class="py-line">    <tt class="py-name">doctest</tt><tt class="py-op">.</tt><tt class="py-name">testmod</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt>
<a name="L6061"></a><tt class="py-lineno">6061</tt>  <tt class="py-line"> </tt><script type="text/javascript">
<!--
expandto(location.href);
// -->
</script>
</pre>
<br />
<!-- ==================== NAVIGATION BAR ==================== -->
<table class="navbar" border="0" width="100%" cellpadding="0"
       bgcolor="#a0c0ff" cellspacing="0">
  <tr valign="middle">
  <!-- Home link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="web2py.gluon-module.html">Home</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Tree link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="module-tree.html">Trees</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Index link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="identifier-index.html">Indices</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Help link -->
      <th>&nbsp;&nbsp;&nbsp;<a
        href="help.html">Help</a>&nbsp;&nbsp;&nbsp;</th>

  <!-- Project homepage -->
      <th class="navbar" align="right" width="100%">
        <table border="0" cellpadding="0" cellspacing="0">
          <tr><th class="navbar" align="center"
            ><a class="navbar" target="_top" href="http://www.web2py.com">web2py Web Framework</a></th>
          </tr></table></th>
  </tr>
</table>
<table border="0" cellpadding="0" cellspacing="0" width="100%%">
  <tr>
    <td align="left" class="footer">
    Generated by Epydoc 3.0beta1 on Thu Aug  4 00:47:07 2011
    </td>
    <td align="right" class="footer">
      <a href="http://epydoc.sourceforge.net">http://epydoc.sourceforge.net</a>
    </td>
  </tr>
</table>

<script type="text/javascript">
  <!--
  // Private objects are initially displayed (because if
  // javascript is turned off then we want them to be
  // visible); but by default, we want to hide them.  So hide
  // them unless we have a cookie that says to show them.
  checkCookie()
  // -->
</script>
  
</body>
</html>