|
| 1 | +-- Member |
| 2 | +INSERT INTO member ( |
| 3 | + roll_no, name, email, sex, year, hostel, mac_address, discord_id, group_id |
| 4 | +) |
| 5 | +SELECT |
| 6 | + 'R' || LPAD(i::TEXT, 4, '0'), |
| 7 | + CASE |
| 8 | + WHEN i % 5 = 0 THEN 'John Doe ' || i |
| 9 | + WHEN i % 5 = 1 THEN 'Jane Smith ' || i |
| 10 | + WHEN i % 5 = 2 THEN 'Alex Johnson ' || i |
| 11 | + WHEN i % 5 = 3 THEN 'Emily Davis ' || i |
| 12 | + ELSE 'Chris Brown ' || i |
| 13 | + END, |
| 14 | + CASE |
| 15 | + WHEN i % 5 = 0 THEN 'john.doe' || i || '@example.com' |
| 16 | + WHEN i % 5 = 1 THEN 'jane.smith' || i || '@example.com' |
| 17 | + WHEN i % 5 = 2 THEN 'alex.johnson' || i || '@example.com' |
| 18 | + WHEN i % 5 = 3 THEN 'emily.davis' || i || '@example.com' |
| 19 | + ELSE 'chris.brown' || i || '@example.com' |
| 20 | + END, |
| 21 | + CASE |
| 22 | + WHEN i % 2 = 0 THEN 'M'::sex_type |
| 23 | + ELSE 'F'::sex_type |
| 24 | + END, |
| 25 | + (i % 4) + 1, |
| 26 | + 'Hostel ' || ((i % 5) + 1), |
| 27 | + '00:14:22:01:' || LPAD(TO_HEX(i), 2, '0') || ':' || LPAD(TO_HEX(i + 60), 2, '0'), |
| 28 | + 'discord_user_' || i, |
| 29 | + (i % 8) + 1 |
| 30 | +FROM generate_series(1, 60) AS i |
| 31 | +ON CONFLICT (roll_no) DO NOTHING; |
| 32 | + |
| 33 | + |
| 34 | +-- Attendance |
| 35 | +INSERT INTO Attendance ( |
| 36 | + member_id, date, is_present, time_in, time_out |
| 37 | +) |
| 38 | +SELECT |
| 39 | + m.member_id, |
| 40 | + CURRENT_DATE - ((i * 3) % 30), |
| 41 | + rnd.is_present, |
| 42 | + CASE WHEN rnd.is_present THEN rnd.time_in ELSE NULL END, |
| 43 | + CASE WHEN rnd.is_present THEN rnd.time_out ELSE NULL END |
| 44 | +FROM generate_series(1, 600) AS i |
| 45 | +JOIN ( |
| 46 | + SELECT generate_series(1, 60) AS idx, member_id |
| 47 | + FROM member |
| 48 | +) AS m ON (i % 60) + 1 = m.idx |
| 49 | +JOIN ( |
| 50 | + SELECT |
| 51 | + TRUE AS is_present, |
| 52 | + '08:30'::TIME + (INTERVAL '1 minute' * (random() * 60)) AS time_in, |
| 53 | + '17:00'::TIME + (INTERVAL '1 minute' * (random() * 60)) AS time_out |
| 54 | + UNION ALL |
| 55 | + SELECT FALSE, NULL, NULL |
| 56 | +) AS rnd ON TRUE |
| 57 | +WHERE (random() < 0.75) |
| 58 | +ON CONFLICT (member_id, date) DO NOTHING; |
| 59 | + |
| 60 | + |
| 61 | +-- AttendanceSummary |
| 62 | +INSERT INTO AttendanceSummary ( |
| 63 | + member_id, year, month, days_attended |
| 64 | +) |
| 65 | +SELECT |
| 66 | + m.member_id, |
| 67 | + 2025, |
| 68 | + (i % 12) + 1, |
| 69 | + FLOOR(random() * 26 + 3)::INT |
| 70 | +FROM generate_series(1, 400) AS i |
| 71 | +JOIN ( |
| 72 | + SELECT generate_series(1, 60) AS idx, member_id |
| 73 | + FROM member |
| 74 | +) AS m ON (i % 60) + 1 = m.idx |
| 75 | +ON CONFLICT (member_id, year, month) DO NOTHING; |
| 76 | + |
| 77 | + |
| 78 | +-- StatusUpdateStreak |
| 79 | +INSERT INTO StatusUpdateStreak ( |
| 80 | + member_id, current_streak, max_streak |
| 81 | +) |
| 82 | +SELECT |
| 83 | + member_id, |
| 84 | + FLOOR(random() * 10 + 1)::INT, |
| 85 | + FLOOR(random() * 30 + 10)::INT |
| 86 | +FROM member |
| 87 | +ON CONFLICT (member_id) DO NOTHING; |
| 88 | + |
| 89 | + |
| 90 | +-- Project |
| 91 | +INSERT INTO Project ( |
| 92 | + member_id, title |
| 93 | +) |
| 94 | +SELECT |
| 95 | + (i % 60) + 1, |
| 96 | + CASE |
| 97 | + WHEN i % 3 = 0 THEN 'Machine Learning Project ' || i |
| 98 | + WHEN i % 3 = 1 THEN 'Web Development Project ' || i |
| 99 | + ELSE 'Data Analysis Project ' || i |
| 100 | + END |
| 101 | +FROM generate_series(1, 200) AS i |
| 102 | +WHERE NOT EXISTS ( |
| 103 | + SELECT 1 FROM Project |
| 104 | + WHERE member_id = (i % 60) + 1 AND title = CASE |
| 105 | + WHEN i % 3 = 0 THEN 'Machine Learning Project ' || i |
| 106 | + WHEN i % 3 = 1 THEN 'Web Development Project ' || i |
| 107 | + ELSE 'Data Analysis Project ' || i |
| 108 | + END |
| 109 | +); |
| 110 | + |
| 111 | + |
| 112 | +-- StatusUpdateHistory |
| 113 | +INSERT INTO StatusUpdateHistory ( |
| 114 | + member_id, date, is_updated |
| 115 | +) |
| 116 | +SELECT |
| 117 | + m.member_id, |
| 118 | + CURRENT_DATE - ((i * 2) % 30), |
| 119 | + i % 2 = 0 |
| 120 | +FROM generate_series(1, 500) AS i |
| 121 | +JOIN ( |
| 122 | + SELECT generate_series(1, 60) AS idx, member_id |
| 123 | + FROM member |
| 124 | +) AS m ON (i % 60) + 1 = m.idx |
| 125 | +ON CONFLICT (member_id, date) DO NOTHING; |
0 commit comments