forked from mariadb-operator/mariadb-operator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsqljob_03-stars.yaml
52 lines (52 loc) · 1.95 KB
/
sqljob_03-stars.yaml
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
46
47
48
49
50
51
52
apiVersion: k8s.mariadb.com/v1alpha1
kind: SqlJob
metadata:
name: 03-stars
spec:
dependsOn:
- name: 01-users
- name: 02-repos
mariaDbRef:
name: mariadb
schedule:
cron: "*/1 * * * *"
suspend: false
timeZone: "UTC"
username: mariadb
passwordSecretKeyRef:
name: mariadb
key: password
database: mariadb
sql: |
CREATE TABLE IF NOT EXISTS stars (
id bigint PRIMARY KEY AUTO_INCREMENT,
user_id bigint NOT NULL,
repo_id bigint NOT NULL,
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
FOREIGN KEY (repo_id) REFERENCES repos(id) ON DELETE CASCADE,
UNIQUE KEY (user_id, repo_id)
);
INSERT INTO stars(user_id, repo_id)
VALUES((SELECT id FROM users ORDER BY RAND() LIMIT 1), (SELECT id FROM repos ORDER BY RAND() LIMIT 1))
ON DUPLICATE KEY UPDATE id=id;
INSERT INTO stars(user_id, repo_id)
VALUES((SELECT id FROM users ORDER BY RAND() LIMIT 1), (SELECT id FROM repos ORDER BY RAND() LIMIT 1))
ON DUPLICATE KEY UPDATE id=id;
INSERT INTO stars(user_id, repo_id)
VALUES((SELECT id FROM users ORDER BY RAND() LIMIT 1), (SELECT id FROM repos ORDER BY RAND() LIMIT 1))
ON DUPLICATE KEY UPDATE id=id;
INSERT INTO stars(user_id, repo_id)
VALUES((SELECT id FROM users ORDER BY RAND() LIMIT 1), (SELECT id FROM repos ORDER BY RAND() LIMIT 1))
ON DUPLICATE KEY UPDATE id=id;
INSERT INTO stars(user_id, repo_id)
VALUES((SELECT id FROM users ORDER BY RAND() LIMIT 1), (SELECT id FROM repos ORDER BY RAND() LIMIT 1))
ON DUPLICATE KEY UPDATE id=id;
DELETE FROM stars WHERE id = (SELECT id FROM stars ORDER BY RAND() LIMIT 1);
DELETE FROM stars WHERE id = (SELECT id FROM stars ORDER BY RAND() LIMIT 1);
DELETE FROM stars WHERE id = (SELECT id FROM stars ORDER BY RAND() LIMIT 1);
SELECT r.name AS repo, COUNT(*) AS stars
FROM stars s
JOIN repos r
ON s.repo_id = r.id
GROUP BY r.id
ORDER BY stars DESC;