-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinit.cql
45 lines (36 loc) · 1.32 KB
/
init.cql
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
create keyspace scyllax with replication = {'class': 'SimpleStrategy','replication_factor': 1};
use scyllax;
create table if not exists person (
id timeuuid primary key,
email text,
age int,
data text, -- json type
kind int,
-- camel case for the sake of backwards compat
"createdAt" timestamp
);
create materialized view if not exists person_by_email as
select *
from person
where email is not null and id is not null
primary key (email, id);
create materialized view if not exists "person_by_createdAt" as
select *
from person
where "createdAt" is not null and id is not null
primary key (id, "createdAt");
insert into person(id, email, age, data, kind, "createdAt") values (e01e84d6-414c-11ee-be56-0242ac120002, '[email protected]', 25, '{"foo":"bar"}', 0, toUnixTimestamp(now()));
insert into person(id, email, age, kind, "createdAt") values (e01e880a-414c-11ee-be56-0242ac120002, '[email protected]', 25, 1, toUnixTimestamp(now()));
create table if not exists person_login (
id timeuuid,
person_id uuid,
count counter,
primary key ((id), person_id)
);
update person_login set count = count + 0 where id = 42dcfcde-5420-11ee-8c99-0242ac120002 and person_id = e01e84d6-414c-11ee-be56-0242ac120002;
create table if not exists post (
id timeuuid primary key,
title text,
likes text,
created_at timestamp
);