Mercurial > urweb
view demo/refFun.ur @ 420:9119a5920106
Prose for Ref and Metaform
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Thu, 23 Oct 2008 17:52:04 -0400 |
parents | cb5897276abf |
children | c471345f5165 |
line wrap: on
line source
functor Make(M : sig type data val inj : sql_injectable data end) = struct type ref = int sequence s table t : { Id : int, Data : M.data } fun new d = id <- nextval s; () <- dml (INSERT INTO t (Id, Data) VALUES ({id}, {d})); return id fun read r = o <- oneOrNoRows (SELECT t.Data FROM t WHERE t.Id = {r}); return (case o of None => error <xml>You already deleted that ref!</xml> | Some r => r.T.Data) fun write r d = dml (UPDATE t SET Data = {d} WHERE Id = {r}) fun delete r = dml (DELETE FROM t WHERE Id = {r}) end