package caqti
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Unified interface to relational database libraries
Install
dune-project
Dependency
Authors
Maintainers
Sources
caqti-v2.1.1.tbz
sha256=483a535f41e2641917fc1832ce4ad15ffc3f4e8283b1b3018a2617349583090a
sha512=6a1222c0c55cb16a9d409980f9f2400340689b87e21aafed2d7459fd7feaeb109c2dfaf77f55f8422fbb7d3772342565ced7fed78a7b77af5aedab5bfd5ae882
doc/src/caqti/caqti_type_sig.ml.html
Source file caqti_type_sig.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252(* Copyright (C) 2018--2023 Petter A. Urkedal <paurkedal@gmail.com> * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or (at your * option) any later version, with the LGPL-3.0 Linking Exception. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public * License for more details. * * You should have received a copy of the GNU Lesser General Public License * and the LGPL-3.0 Linking Exception along with this library. If not, see * <http://www.gnu.org/licenses/> and <https://spdx.org>, respectively. *) (** Signatures for {!Caqti_type}. *) (** Standard type descriptors. *) module type Std = sig type 'a t (** {3 Field Types} The following types correspond to what usually fits in a single field of a result row or input parameter set. *) val bool : bool t (** A [bool] mapped to [boolean] on the SQL side if supported, otherwise mapped to an integer. *) val int : int t (** An [int] mapped to a sufficiently wide integer on the SQL side. *) val int16 : int t (** An [int] mapped to a [smallint] (16 bits) on the SQL side. *) val int32 : int32 t (** An [int32] mapped to an [integer] (32 bits) on the SQL side. *) val int64 : int64 t (** An [int64] mapped to a [bigint] (64 bits) on the SQL side. *) val float : float t (** A [float] mapped to [double precision] or (best alternative) on the SQL side. Serialization may be lossy (e.g. base 10 may be used), so even if both sides support IEEE 754 double precision numbers, there may be discrepancies in the last digits of the binary representaton. *) val string : string t (** An UTF-8 string. The database should accept UTF-8 if non-ASCII characters are present. *) val octets : string t (** A [string] mapped to whichever type is used to represent binary data on the SQL side. *) val pdate : Ptime.t t (** A time truncated to a date and mapped to the SQL [date] type. *) val ptime : Ptime.t t (** An absolute time with driver-dependent precision. This corresponds to an SQL [timestamp with time zone] or a suitable alternative where not available: - MariaDB has [datetime] which is similar to the SQL [timestamp] and [timestamp] which is similar to the SQL [timestamp with time zone], but the driver does not make the distinction. Caqti sets the session time zone to UTC to avoid misinterpretation, since time values are passed in both directions without time zones. Values have microsecond precision, but you will need to specify the desired precision in the database schema to avoid truncation. - PostgreSQL supports this type and it's a good option to avoid any time zone issues if used conistently both on the client side, in SQL expressions, and in the database schema. Note that [timestamp with time zone] is stored as UTC without time zone, taking up no more space then [timestamp]. The PostgreSQL [timestamp] type is problematic since how conversions work and the manual indicate that it is meant to be a local time, and since database columns of this type stores the value without conversion to UTC, it becomes prone to time zone changes. To mitigate the issue, Caqti sets the time zone of sessions to UTC. - Sqlite3 does not have a dedicated type for absolute time. The date and time is sent as strings expressed at the UTC time zone using same format that the SQLite {{:https://sqlite.org/lang_datefunc.html} datetime} function and [CURRENT_TIMESTAMP] return, except for an additional three decimals to achive millisecond precision. It might seem better to use standard RFC3339 format, since it is accepted by the SQLite functions, but that would misorder some time values if mixed with the results of these functions, even just the "Z" suffix would misorder values with different precision. Date and time values which comes from the database without time zone are interpreted as UTC. This is not necessarily correct, and it is highly recommended to use SQL types which are transmitted with time zone information, even if this is UTC. *) val ptime_span : Ptime.span t (** A period of time. If the database lacks a dedicated representation, the integer number of seconds is used. *) val enum : encode: ('a -> string) -> decode: (string -> ('a, string) result) -> string -> 'a t (** [enum ~encode ~decode name] creates an enum type which on the SQL side is named [name], with cases which are converted with [encode] and [decode] functions. This is implemented in terms of the {!Caqti_type.Field.Enum} field type. *) (** {3 Composite Types} *) type ('a, 'i) product val product : 'i -> ('a, 'i) product -> 'a t val proj : 'b t -> ('a -> 'b) -> ('a, 'i) product -> ('a, 'b -> 'i) product val proj_end : ('a, 'a) product (** Given a set of projection functions [p1 : t -> t1], ..., [pN : t -> tN] and a function [intro : t1 -> ... -> tN -> t] to reconstruct values of [t] from the projections, {[ product intro @@ proj t1 p1 @@ ... @@ proj tN pN @@ proj_end ]} defines a Caqti type for [t], which on the database side will be represented by a consecutive list of fields corresponding to the types [t1], ..., [tN], each of which may be represented by multiple fields. That is, [intro [project1 x] ... [projectN x]] is equivalent to [x] according to an enforced or effective abstraction of [t] deemed adequate for the application logic. [intro] may raise {!Caqti_type.Reject} to indicate that a value cannot be constructed from the given arguments. Projection operators may also raise this exception to indicate that an object cannot be represented in the database, e.g. due to an overflow. The above only states that [intro] is a left (pseudo-)inverse of the projections, which is what matters for a faithful representation of OCaml values. The opposite (projection functions being the left inverse of [intro]) may be relevant if the application needs preserve the database representation when updating objects. *) val custom : encode: ('a -> ('b, string) result) -> decode: ('b -> ('a, string) result) -> 'b t -> 'a t (** [custom ~encode ~decode rep] creates a custom type represented by [rep], where [encode] is used to encode parameters into [rep] and [decode] is used to decode result rows from [rep]. *) val option : 'a t -> 'a option t (** [option t] turns a set of fields encoded as [t] into a correspending set of nullable fields. The encoder will encode [None] as into a tuple of [NULL] values and the decoder will return [None] if all fields are [NULL]. If the type [t] itself is [option t'] for some [t'], or contains nested tuples and options such that all field types are nested under an option type, then it would have been possible to decode an all-[NULL] segment of a row as [Some x] where [x] is a corresponding tuple-option-tree terminating in [None] values. The above paragraph resolves this ambiguity since it implies that the outermost option possible will be decoded as [None]. *) val redacted : 'a t -> 'a t (** [redacted t] is the same type as [t] but sealed as potentially containing sensitive information to be redacted from pretty-printers and logs. *) (** {3 Tuple Types} As a common case of composite types, constructors for tuples up to 12 components are predefined here. Higher tuples can be created with {!val-product}. *) val unit : unit t (** A type holding no fields. This is used to pass no parameters and as the result for queries which does not return any rows. It can also be nested in tuples, in which case it will not contribute to the total number of fields. *) val t2 : 'a1 t -> 'a2 t -> ('a1 * 'a2) t (** Creates a pair type. *) val t3 : 'a1 t -> 'a2 t -> 'a3 t -> ('a1 * 'a2 * 'a3) t (** Creates a 3-tuple type. *) val t4 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> ('a1 * 'a2 * 'a3 * 'a4) t (** Creates a 4-tuple type. *) val t5 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5) t (** Creates a 5-tuple type. *) val t6 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6) t (** Creates a 6-tuple type. *) val t7 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> 'a7 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7) t (** Creates a 7-tuple type. *) val t8 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> 'a7 t -> 'a8 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8) t (** Creates a 8-tuple type. *) val t9 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> 'a7 t -> 'a8 t -> 'a9 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9) t (** Creates a 9-tuple type. *) val t10 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> 'a7 t -> 'a8 t -> 'a9 t -> 'a10 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10) t (** Creates a 10-tuple type. *) val t11 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> 'a7 t -> 'a8 t -> 'a9 t -> 'a10 t -> 'a11 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10 * 'a11) t (** Creates a 11-tuple type. *) val t12 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> 'a5 t -> 'a6 t -> 'a7 t -> 'a8 t -> 'a9 t -> 'a10 t -> 'a11 t -> 'a12 t -> ('a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10 * 'a11 * 'a12) t (** Creates a 12-tuple type. *) (**/**) val tup2 : 'a1 t -> 'a2 t -> ('a1 * 'a2) t [@@deprecated "Renamed to t2."] val tup3 : 'a1 t -> 'a2 t -> 'a3 t -> ('a1 * 'a2 * 'a3) t [@@deprecated "Renamed to t3."] val tup4 : 'a1 t -> 'a2 t -> 'a3 t -> 'a4 t -> ('a1 * 'a2 * 'a3 * 'a4) t [@@deprecated "Renamed to t4."] end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>