db_common.html 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <!-- This file is generated by Nim. -->
  4. <html xmlns="https://www.w3.org/1999/xhtml" xml:lang="en" lang="en" data-theme="auto">
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  7. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  8. <title>src/db_connector/db_common</title>
  9. <!-- Google fonts -->
  10. <link href='https://fonts.googleapis.com/css?family=Lato:400,600,900' rel='stylesheet' type='text/css'/>
  11. <link href='https://fonts.googleapis.com/css?family=Source+Code+Pro:400,500,600' rel='stylesheet' type='text/css'/>
  12. <!-- Favicon -->
  13. <link rel="shortcut icon" href=""/>
  14. <link rel="icon" type="image/png" sizes="32x32" href="">
  15. <!-- CSS -->
  16. <link rel="stylesheet" type="text/css" href="nimdoc.out.css?v=2.3.1">
  17. <!-- JS -->
  18. <script type="text/javascript" src="dochack.js?v=2.3.1"></script>
  19. </head>
  20. <body>
  21. <div class="document" id="documentId">
  22. <div class="container">
  23. <h1 class="title">src/db_connector/db_common</h1>
  24. <div class="row">
  25. <div class="three columns">
  26. <div class="theme-select-wrapper">
  27. <label for="theme-select">Theme:&nbsp;</label>
  28. <select id="theme-select" onchange="setTheme(this.value)">
  29. <option value="auto">🌗 Match OS</option>
  30. <option value="dark">🌑 Dark</option>
  31. <option value="light">🌕 Light</option>
  32. </select>
  33. </div>
  34. <div id="global-links">
  35. <ul class="simple-boot">
  36. <li><a href="manual.html">Manual</a></li>
  37. <li><a href="lib.html">Standard library</a></li>
  38. <li> <a id="indexLink" href="theindex.html">Index</a></li>
  39. <li><a href="compiler/theindex.html">Compiler docs</a></li>
  40. <li><a href="https://nim-lang.github.io/fusion/theindex.html">Fusion docs</a></li>
  41. <li><a href="https://nim-lang.github.io/Nim/">devel</a>, <a href="https://nim-lang.org/documentation.html">stable</a></li>
  42. </ul>
  43. </div>
  44. <div id="searchInputDiv">
  45. Search: <input type="search" id="searchInput"
  46. oninput="search()" />
  47. </div>
  48. <ul class="simple simple-toc" id="toc-list">
  49. <li>
  50. <details open>
  51. <summary><a class="reference reference-toplevel" href="#7" id="57">Types</a></summary>
  52. <ul class="simple simple-toc-section">
  53. <li><a class="reference" href="#DbColumn" title="DbColumn = object
  54. name*: string ## name of the column
  55. tableName*: string ## name of the table the column belongs to (optional)
  56. typ*: DbType ## type of the column
  57. primaryKey*: bool ## is this a primary key?
  58. foreignKey*: bool ## is this a foreign key?">DbColumn</a></li>
  59. <li><a class="reference" href="#DbColumns" title="DbColumns = seq[DbColumn]">DbColumns</a></li>
  60. <li><a class="reference" href="#DbEffect" title="DbEffect = object of IOEffect">DbEffect</a></li>
  61. <li><a class="reference" href="#DbError" title="DbError = object of IOError">DbError</a></li>
  62. <li><a class="reference" href="#DbType" title="DbType = object
  63. kind*: DbTypeKind ## the kind of the described type
  64. notNull*: bool ## does the type contain NULL?
  65. name*: string ## the name of the type
  66. size*: Natural ## the size of the datatype; 0 if of variable size
  67. maxReprLen*: Natural ## maximal length required for the representation
  68. precision*, scale*: Natural ## precision and scale of the number
  69. min*, max*: BiggestInt ## the minimum and maximum of allowed values
  70. validValues*: seq[string] ## valid values of an enum or a set">DbType</a></li>
  71. <li><a class="reference" href="#DbTypeKind" title="DbTypeKind = enum
  72. dbUnknown, ## unknown datatype
  73. dbSerial, ## datatype used for primary auto-increment keys
  74. dbNull, ## datatype used for the NULL value
  75. dbBit, ## bit datatype
  76. dbBool, ## boolean datatype
  77. dbBlob, ## blob datatype
  78. dbFixedChar, ## string of fixed length
  79. dbVarchar, ## string datatype
  80. dbJson, ## JSON datatype
  81. dbXml, ## XML datatype
  82. dbInt, ## some integer type
  83. dbUInt, ## some unsigned integer type
  84. dbDecimal, ## decimal numbers (fixed-point number)
  85. dbFloat, ## some floating point type
  86. dbDate, ## a year-month-day description
  87. dbTime, ## HH:MM:SS information
  88. dbDatetime, ## year-month-day and HH:MM:SS information,
  89. ## plus optional time or timezone information
  90. dbTimestamp, ## Timestamp values are stored as the number of seconds
  91. ## since the epoch ('1970-01-01 00:00:00' UTC).
  92. dbTimeInterval, ## an interval [a,b] of times
  93. dbEnum, ## some enum
  94. dbSet, ## set of enum values
  95. dbArray, ## an array of values
  96. dbComposite, ## composite type (record, struct, etc)
  97. dbUrl, ## a URL
  98. dbUuid, ## a UUID
  99. dbInet, ## an IP address
  100. dbMacAddress, ## a MAC address
  101. dbGeometry, ## some geometric type
  102. dbPoint, ## Point on a plane (x,y)
  103. dbLine, ## Infinite line ((x1,y1),(x2,y2))
  104. dbLseg, ## Finite line segment ((x1,y1),(x2,y2))
  105. dbBox, ## Rectangular box ((x1,y1),(x2,y2))
  106. dbPath, ## Closed or open path (similar to polygon) ((x1,y1),...)
  107. dbPolygon, ## Polygon (similar to closed path) ((x1,y1),...)
  108. dbCircle, ## Circle &lt;(x,y),r&gt; (center point and radius)
  109. dbUser1, ## user definable datatype 1 (for unknown extensions)
  110. dbUser2, ## user definable datatype 2 (for unknown extensions)
  111. dbUser3, ## user definable datatype 3 (for unknown extensions)
  112. dbUser4, ## user definable datatype 4 (for unknown extensions)
  113. dbUser5 ## user definable datatype 5 (for unknown extensions)">DbTypeKind</a></li>
  114. <li><a class="reference" href="#ReadDbEffect" title="ReadDbEffect = object of DbEffect">ReadDbEffect</a></li>
  115. <li><a class="reference" href="#SqlQuery" title="SqlQuery = distinct string">SqlQuery</a></li>
  116. <li><a class="reference" href="#WriteDbEffect" title="WriteDbEffect = object of DbEffect">WriteDbEffect</a></li>
  117. </ul>
  118. </details>
  119. </li>
  120. <li>
  121. <details open>
  122. <summary><a class="reference reference-toplevel" href="#12" id="62">Procs</a></summary>
  123. <ul class="simple simple-toc-section">
  124. <ul class="simple nested-toc-section">dbError
  125. <li><a class="reference" href="#dbError%2Cstring" title="dbError(msg: string)">dbError(msg: string)</a></li>
  126. </ul>
  127. </ul>
  128. </details>
  129. </li>
  130. <li>
  131. <details open>
  132. <summary><a class="reference reference-toplevel" href="#18" id="68">Templates</a></summary>
  133. <ul class="simple simple-toc-section">
  134. <ul class="simple nested-toc-section">sql
  135. <li><a class="reference" href="#sql.t%2Cstring" title="sql(query: string): SqlQuery">sql(query: string): SqlQuery</a></li>
  136. </ul>
  137. </ul>
  138. </details>
  139. </li>
  140. </ul>
  141. </div>
  142. <div class="nine columns" id="content">
  143. <div id="tocRoot"></div>
  144. <p class="module-desc"><div class="admonition admonition-info"><span class="admonition-info-text"><b>Note:</b></span>
  145. In order to use this module, run <tt class="docutils literal"><span class="pre"><span class="Identifier">nimble</span> <span class="Identifier">install</span> <span class="Identifier">db_connector</span></span></tt>.</div>
  146. <p>Common datatypes and definitions for all <tt class="docutils literal"><span class="pre"><span class="Identifier">db_</span><span class="Operator">*.</span><span class="Identifier">nim</span></span></tt> ( <a class="reference external" href="db_mysql.html">db_mysql</a>, <a class="reference external" href="db_postgres.html">db_postgres</a>, and <a class="reference external" href="db_sqlite.html">db_sqlite</a>) modules.</p>
  147. </p>
  148. <div class="section" id="7">
  149. <h1><a class="toc-backref" href="#7">Types</a></h1>
  150. <dl class="item">
  151. <div id="DbColumn">
  152. <dt><pre><a href="db_common.html#DbColumn"><span class="Identifier">DbColumn</span></a> <span class="Other">=</span> <span class="Keyword">object</span>
  153. <span class="Identifier">name</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">string</span> <span class="Comment">## name of the column</span>
  154. <span class="Identifier">tableName</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">string</span> <span class="Comment">## name of the table the column belongs to (optional)</span>
  155. <span class="Identifier">typ</span><span class="Operator">*</span><span class="Other">:</span> <a href="db_common.html#DbType"><span class="Identifier">DbType</span></a> <span class="Comment">## type of the column</span>
  156. <span class="Identifier">primaryKey</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Comment">## is this a primary key?</span>
  157. <span class="Identifier">foreignKey</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Comment">## is this a foreign key?</span></pre></dt>
  158. <dd>
  159. information about a database column
  160. </dd>
  161. </div>
  162. <div id="DbColumns">
  163. <dt><pre><a href="db_common.html#DbColumns"><span class="Identifier">DbColumns</span></a> <span class="Other">=</span> <span class="Identifier">seq</span><span class="Other">[</span><a href="db_common.html#DbColumn"><span class="Identifier">DbColumn</span></a><span class="Other">]</span></pre></dt>
  164. <dd>
  165. </dd>
  166. </div>
  167. <div id="DbEffect">
  168. <dt><pre><a href="db_common.html#DbEffect"><span class="Identifier">DbEffect</span></a> <span class="Other">=</span> <span class="Keyword">object</span> <span class="Keyword">of</span> <span class="Identifier">IOEffect</span></pre></dt>
  169. <dd>
  170. effect that denotes a database operation
  171. </dd>
  172. </div>
  173. <div id="DbError">
  174. <dt><pre><a href="db_common.html#DbError"><span class="Identifier">DbError</span></a> <span class="Other">=</span> <span class="Keyword">object</span> <span class="Keyword">of</span> <span class="Identifier">IOError</span></pre></dt>
  175. <dd>
  176. exception that is raised if a database error occurs
  177. </dd>
  178. </div>
  179. <div id="DbType">
  180. <dt><pre><a href="db_common.html#DbType"><span class="Identifier">DbType</span></a> <span class="Other">=</span> <span class="Keyword">object</span>
  181. <span class="Identifier">kind</span><span class="Operator">*</span><span class="Other">:</span> <a href="db_common.html#DbTypeKind"><span class="Identifier">DbTypeKind</span></a> <span class="Comment">## the kind of the described type</span>
  182. <span class="Identifier">notNull</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Comment">## does the type contain NULL?</span>
  183. <span class="Identifier">name</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">string</span> <span class="Comment">## the name of the type</span>
  184. <span class="Identifier">size</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">Natural</span> <span class="Comment">## the size of the datatype; 0 if of variable size</span>
  185. <span class="Identifier">maxReprLen</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">Natural</span> <span class="Comment">## maximal length required for the representation</span>
  186. <span class="Identifier">precision</span><span class="Operator">*</span><span class="Other">,</span> <span class="Identifier">scale</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">Natural</span> <span class="Comment">## precision and scale of the number</span>
  187. <span class="Identifier">min</span><span class="Operator">*</span><span class="Other">,</span> <span class="Identifier">max</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">BiggestInt</span> <span class="Comment">## the minimum and maximum of allowed values</span>
  188. <span class="Identifier">validValues</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">seq</span><span class="Other">[</span><span class="Identifier">string</span><span class="Other">]</span> <span class="Comment">## valid values of an enum or a set</span></pre></dt>
  189. <dd>
  190. describes a database type
  191. </dd>
  192. </div>
  193. <div id="DbTypeKind">
  194. <dt><pre><a href="db_common.html#DbTypeKind"><span class="Identifier">DbTypeKind</span></a> <span class="Other">=</span> <span class="Keyword">enum</span>
  195. <span class="Identifier">dbUnknown</span><span class="Other">,</span> <span class="Comment">## unknown datatype</span>
  196. <span class="Identifier">dbSerial</span><span class="Other">,</span> <span class="Comment">## datatype used for primary auto-increment keys</span>
  197. <span class="Identifier">dbNull</span><span class="Other">,</span> <span class="Comment">## datatype used for the NULL value</span>
  198. <span class="Identifier">dbBit</span><span class="Other">,</span> <span class="Comment">## bit datatype</span>
  199. <span class="Identifier">dbBool</span><span class="Other">,</span> <span class="Comment">## boolean datatype</span>
  200. <span class="Identifier">dbBlob</span><span class="Other">,</span> <span class="Comment">## blob datatype</span>
  201. <span class="Identifier">dbFixedChar</span><span class="Other">,</span> <span class="Comment">## string of fixed length</span>
  202. <span class="Identifier">dbVarchar</span><span class="Other">,</span> <span class="Comment">## string datatype</span>
  203. <span class="Identifier">dbJson</span><span class="Other">,</span> <span class="Comment">## JSON datatype</span>
  204. <span class="Identifier">dbXml</span><span class="Other">,</span> <span class="Comment">## XML datatype</span>
  205. <span class="Identifier">dbInt</span><span class="Other">,</span> <span class="Comment">## some integer type</span>
  206. <span class="Identifier">dbUInt</span><span class="Other">,</span> <span class="Comment">## some unsigned integer type</span>
  207. <span class="Identifier">dbDecimal</span><span class="Other">,</span> <span class="Comment">## decimal numbers (fixed-point number)</span>
  208. <span class="Identifier">dbFloat</span><span class="Other">,</span> <span class="Comment">## some floating point type</span>
  209. <span class="Identifier">dbDate</span><span class="Other">,</span> <span class="Comment">## a year-month-day description</span>
  210. <span class="Identifier">dbTime</span><span class="Other">,</span> <span class="Comment">## HH:MM:SS information</span>
  211. <span class="Identifier">dbDatetime</span><span class="Other">,</span> <span class="Comment">## year-month-day and HH:MM:SS information,</span>
  212. <span class="Comment">## plus optional time or timezone information</span>
  213. <span class="Identifier">dbTimestamp</span><span class="Other">,</span> <span class="Comment">## Timestamp values are stored as the number of seconds</span>
  214. <span class="Comment">## since the epoch ('1970-01-01 00:00:00' UTC).</span>
  215. <span class="Identifier">dbTimeInterval</span><span class="Other">,</span> <span class="Comment">## an interval [a,b] of times</span>
  216. <span class="Identifier">dbEnum</span><span class="Other">,</span> <span class="Comment">## some enum</span>
  217. <span class="Identifier">dbSet</span><span class="Other">,</span> <span class="Comment">## set of enum values</span>
  218. <span class="Identifier">dbArray</span><span class="Other">,</span> <span class="Comment">## an array of values</span>
  219. <span class="Identifier">dbComposite</span><span class="Other">,</span> <span class="Comment">## composite type (record, struct, etc)</span>
  220. <span class="Identifier">dbUrl</span><span class="Other">,</span> <span class="Comment">## a URL</span>
  221. <span class="Identifier">dbUuid</span><span class="Other">,</span> <span class="Comment">## a UUID</span>
  222. <span class="Identifier">dbInet</span><span class="Other">,</span> <span class="Comment">## an IP address</span>
  223. <span class="Identifier">dbMacAddress</span><span class="Other">,</span> <span class="Comment">## a MAC address</span>
  224. <span class="Identifier">dbGeometry</span><span class="Other">,</span> <span class="Comment">## some geometric type</span>
  225. <span class="Identifier">dbPoint</span><span class="Other">,</span> <span class="Comment">## Point on a plane (x,y)</span>
  226. <span class="Identifier">dbLine</span><span class="Other">,</span> <span class="Comment">## Infinite line ((x1,y1),(x2,y2))</span>
  227. <span class="Identifier">dbLseg</span><span class="Other">,</span> <span class="Comment">## Finite line segment ((x1,y1),(x2,y2))</span>
  228. <span class="Identifier">dbBox</span><span class="Other">,</span> <span class="Comment">## Rectangular box ((x1,y1),(x2,y2))</span>
  229. <span class="Identifier">dbPath</span><span class="Other">,</span> <span class="Comment">## Closed or open path (similar to polygon) ((x1,y1),...)</span>
  230. <span class="Identifier">dbPolygon</span><span class="Other">,</span> <span class="Comment">## Polygon (similar to closed path) ((x1,y1),...)</span>
  231. <span class="Identifier">dbCircle</span><span class="Other">,</span> <span class="Comment">## Circle &lt;(x,y),r&gt; (center point and radius)</span>
  232. <span class="Identifier">dbUser1</span><span class="Other">,</span> <span class="Comment">## user definable datatype 1 (for unknown extensions)</span>
  233. <span class="Identifier">dbUser2</span><span class="Other">,</span> <span class="Comment">## user definable datatype 2 (for unknown extensions)</span>
  234. <span class="Identifier">dbUser3</span><span class="Other">,</span> <span class="Comment">## user definable datatype 3 (for unknown extensions)</span>
  235. <span class="Identifier">dbUser4</span><span class="Other">,</span> <span class="Comment">## user definable datatype 4 (for unknown extensions)</span>
  236. <span class="Identifier">dbUser5</span> <span class="Comment">## user definable datatype 5 (for unknown extensions)</span></pre></dt>
  237. <dd>
  238. a superset of datatypes that might be supported.
  239. </dd>
  240. </div>
  241. <div id="ReadDbEffect">
  242. <dt><pre><a href="db_common.html#ReadDbEffect"><span class="Identifier">ReadDbEffect</span></a> <span class="Other">=</span> <span class="Keyword">object</span> <span class="Keyword">of</span> <a href="db_common.html#DbEffect"><span class="Identifier">DbEffect</span></a></pre></dt>
  243. <dd>
  244. effect that denotes a read operation
  245. </dd>
  246. </div>
  247. <div id="SqlQuery">
  248. <dt><pre><a href="db_common.html#SqlQuery"><span class="Identifier">SqlQuery</span></a> <span class="Other">=</span> <span class="Keyword">distinct</span> <span class="Identifier">string</span></pre></dt>
  249. <dd>
  250. an SQL query string
  251. </dd>
  252. </div>
  253. <div id="WriteDbEffect">
  254. <dt><pre><a href="db_common.html#WriteDbEffect"><span class="Identifier">WriteDbEffect</span></a> <span class="Other">=</span> <span class="Keyword">object</span> <span class="Keyword">of</span> <a href="db_common.html#DbEffect"><span class="Identifier">DbEffect</span></a></pre></dt>
  255. <dd>
  256. effect that denotes a write operation
  257. </dd>
  258. </div>
  259. </dl>
  260. </div>
  261. <div class="section" id="12">
  262. <h1><a class="toc-backref" href="#12">Procs</a></h1>
  263. <dl class="item">
  264. <div id="dbError-procs-all">
  265. <div id="dbError,string">
  266. <dt><pre><span class="Keyword">proc</span> <a href="#dbError%2Cstring"><span class="Identifier">dbError</span></a><span class="Other">(</span><span class="Identifier">msg</span><span class="Other">:</span> <span class="Identifier">string</span><span class="Other">)</span> {.<span class="Identifier">noreturn</span><span class="Other">,</span> <span class="Identifier">noinline</span><span class="Other">,</span> <span><span class="Other pragmadots">...</span></span><span class="pragmawrap"><span class="Identifier">raises</span><span class="Other">:</span> <span class="Other">[</span><span class="Identifier">DbError</span><span class="Other">]</span><span class="Other">,</span> <span class="Identifier">tags</span><span class="Other">:</span> <span class="Other">[</span><span class="Other">]</span><span class="Other">,</span>
  267. <span class="Identifier">forbids</span><span class="Other">:</span> <span class="Other">[</span><span class="Other">]</span></span>.}</pre></dt>
  268. <dd>
  269. raises an DbError exception with message <tt class="docutils literal"><span class="pre"><span class="Identifier">msg</span></span></tt>.
  270. </dd>
  271. </div>
  272. </div>
  273. </dl>
  274. </div>
  275. <div class="section" id="18">
  276. <h1><a class="toc-backref" href="#18">Templates</a></h1>
  277. <dl class="item">
  278. <div id="sql-templates-all">
  279. <div id="sql.t,string">
  280. <dt><pre><span class="Keyword">template</span> <a href="#sql.t%2Cstring"><span class="Identifier">sql</span></a><span class="Other">(</span><span class="Identifier">query</span><span class="Other">:</span> <span class="Identifier">string</span><span class="Other">)</span><span class="Other">:</span> <a href="db_common.html#SqlQuery"><span class="Identifier">SqlQuery</span></a></pre></dt>
  281. <dd>
  282. <p>constructs a SqlQuery from the string <tt class="docutils literal"><span class="pre"><span class="Identifier">query</span></span></tt>. This is supposed to be used as a raw-string-literal modifier: <tt class="docutils literal"><span class="pre"><span class="RawData">sql&quot;update user set counter = counter + 1&quot;</span></span></tt></p>
  283. <p>If assertions are turned off, it does nothing. If assertions are turned on, later versions will check the string for valid syntax.</p>
  284. </dd>
  285. </div>
  286. </div>
  287. </dl>
  288. </div>
  289. </div>
  290. </div>
  291. <div class="twelve-columns footer">
  292. <span class="nim-sprite"></span>
  293. <br>
  294. <small style="color: var(--hint);">Made with Nim. Generated: 2025-02-03 14:57:37 UTC</small>
  295. </div>
  296. </div>
  297. </div>
  298. <script defer data-domain="nim-lang.org" src="https://plausible.io/js/plausible.js"></script>
  299. </body>
  300. </html>