about summary refs log tree commit diff
path: root/src/libstore/schema.sql
blob: e2413294309290c0308c3ed447679f1697811db8 (plain) (blame)
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
pragma foreign_keys = on;

create table if not exists ValidPaths (
    path             text primary key not null,
    hash             text not null,
    registrationTime integer not null
);

create table if not exists Refs (
    referrer  text not null,
    reference text not null,
    primary key (referrer, reference),
    foreign key (referrer) references ValidPaths(path)
      on delete cascade
      deferrable initially deferred,
    foreign key (reference) references ValidPaths(path)
      on delete restrict
      deferrable initially deferred
);

create table if not exists FailedDerivations (
    path text primary key not null,
    time integer not null
);

create index IndexReferrer on Refs(referrer);
create index IndexReference on Refs(reference);