blob: b02e1f00e69358f87c973021490b62d225063205 (
plain)
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
|
sequence s
table t : { Id : int, Parent : option int, Nam : string }
PRIMARY KEY Id,
CONSTRAINT F FOREIGN KEY Parent REFERENCES t (Id) ON DELETE CASCADE
open TreeFun.Make(struct
val tab = t
end)
fun row r = <xml>
#{[r.Id]}: {[r.Nam]} <a link={del r.Id}>[Delete]</a>
<form>
Add child: <textbox{#Nam}/> <submit action={add (Some r.Id)}/>
</form>
</xml>
and main () =
xml <- tree row None;
return <xml><body>
{xml}
<form>
Add a top-level node: <textbox{#Nam}/> <submit action={add None}/>
</form>
</body></xml>
and add parent r =
id <- nextval s;
dml (INSERT INTO t (Id, Parent, Nam) VALUES ({[id]}, {[parent]}, {[r.Nam]}));
main ()
and del id =
dml (DELETE FROM t WHERE Id = {[id]});
main ()
|