Mercurial > meta
changeset 26:c1da0e3749b3
Sql.listify
author | Adam Chlipala <adam@chlipala.net> |
---|---|
date | Sun, 13 May 2012 14:13:18 -0400 (2012-05-13) |
parents | 9f56676e7c4e |
children | ca1c07d49b5e |
files | lib.urp sql.ur sql.urs |
diffstat | 3 files changed, 20 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/lib.urp Sun May 06 15:16:27 2012 -0400 +++ b/lib.urp Sun May 13 14:13:18 2012 -0400 @@ -6,7 +6,7 @@ eq variant json +record sql parse html -record
--- a/sql.ur Sun May 06 15:16:27 2012 -0400 +++ b/sql.ur Sun May 13 14:13:18 2012 -0400 @@ -60,3 +60,16 @@ oneOrNoRows1 (SELECT t.{{otherCols}} FROM t WHERE {@selector [#T] ! kfl kinj (vs --- _)}) + +fun listify [lead :: Name] [cols ::: {Type}] [rest ::: {{Type}}] [[lead] ~ rest] + (fl : folder cols) (eqs : $(map eq cols)) (q : sql_query [] [] ([lead = cols] ++ rest) []) = + query q + (fn r acc => + return (case acc of + [] => (r.lead, (r -- lead) :: []) :: [] + | (key, ls) :: acc' => + if @Record.equal eqs fl r.lead key then + (key, (r -- lead) :: ls) :: acc' + else + (r.lead, (r -- lead) :: []) :: acc)) + []
--- a/sql.urs Sun May 06 15:16:27 2012 -0400 +++ b/sql.urs Sun May 13 14:13:18 2012 -0400 @@ -39,3 +39,9 @@ -> sql_table (keyCols ++ otherCols) ([Pkey = map (fn _ => ()) keyCols] ++ otherKeys) -> $keyCols -> transaction (option $otherCols) (* Get the further columns associated with a table key. *) + +val listify : lead :: Name -> cols ::: {Type} -> rest ::: {{Type}} -> [[lead] ~ rest] + => folder cols -> $(map eq cols) + -> sql_query [] [] ([lead = cols] ++ rest) [] + -> transaction (list ($cols * list $(map (fn ts => $ts) rest))) +(* Shrink a set of table rows by summarizing into lists, keyed off of a lead table *)