لا أعتقد أن المدخلات التي سرّدتُها تتطابق مع المخرجات التي تأمل في الحصول عليها. إذا كنت ترغب في الحصول على بيانات لمستخدم واحد، فقد يعمل استعلام مثل ما يلي كنقطة انطلاق. يستخدم الاستعلام تعبيرات الجدول المشترك (Common Table Expressions) لجعل الاستعلام أسهل في القراءة والكتابة. يمكن اتباع النمط نفسه لإضافة المزيد من البيانات إلى النتائج.
شيء واحد لم أكن متأكدًا منه هو ما إذا كنت تريد مجموع البيانات ليوم معين، أم عدد الإجراءات التي تمت في كل يوم. على سبيل المثال، هل تريد معرفة أنه في 2019-10-31 أنشأ المستخدم إجماليًا 20 منشورًا في جميع الأيام التي كان فيها على الموقع، أم تريد معرفة أنه في 2019-10-31 أنشأ المستخدم بالضبط 3 منشورات؟ الطريقة التي تم بها هيكلة الاستعلام حاليًا تعيد النتيجة الثانية.
--[params]
-- string :username
-- date :start_date
WITH target_user AS (SELECT id FROM users WHERE username = :username),
days AS (
SELECT day::date
FROM GENERATE_SERIES(:start_date, NOW()::date, INTERVAL '1 day') AS day
),
topics_created AS(
SELECT
tu.id,
day,
COUNT(tu.id) AS topics
FROM topics t
JOIN target_user tu
ON tu.id = t.user_id
JOIN days
ON t.created_at::date = day
WHERE t.archetype = 'regular'
AND t.deleted_at IS NULL
GROUP BY day, tu.id
),
posts_created AS(
SELECT
tu.id,
day,
COUNT(tu.id) AS posts,
SUM(array_length(regexp_split_to_array(raw, '\s'), 1)) AS word_count
FROM posts p
JOIN target_user tu
ON tu.id = p.user_id
JOIN days
ON p.created_at::date = day
WHERE p.post_type = 1
AND p.deleted_at IS NULL
GROUP BY day, tu.id
),
likes_received AS (
SELECT tu.id,
day,
COUNT(tu.id) AS likes_received_count
FROM user_actions ua
JOIN target_user tu
ON tu.id = ua.user_id
JOIN days
ON ua.created_at::date = day
WHERE ua.action_type = 2
GROUP BY day, tu.id
)
SELECT
d.day,
COALESCE(topics, 0) AS topics,
COALESCE(posts, 0) AS posts,
COALESCE(word_count, 0) AS word_count,
COALESCE(likes_received_count, 0) AS likes_received
FROM days d
LEFT JOIN topics_created tc
ON tc.day = d.day
LEFT JOIN posts_created pc
ON pc.day = d.day
LEFT JOIN likes_received lc
ON lc.day = d.day
ORDER BY d.day
لزيادة نشاط المستخدمين، نخطط لإقامة تحدي لتحديد أكثر المستخدمين نشاطًا في منتدانا، ومنحهم مكافآت.
لذلك، أردنا الحصول على بيانات إضافية لجعل التحدي أكثر إثارة.
البيانات المتوفرة لدينا، باستخدام الاستعلام من @simon، تشمل: المواضيع، المنشورات، عدد الكلمات، واللايكات المستلمة
تشمل البيانات الإضافية ما يلي:
اللايكات الممنوحة: عدد اللايكات التي قدمها المستخدم.
الزيارات: عدد المرات التي فتح فيها المستخدم المنتدى.
وقت القراءة: المدة التي يقضيها المستخدم في المنتدى.
المتابَعون والمتابعون.
معاينات المواضيع: عدد مرات معاينة المواضيع التي أنشأها المستخدم.
ردود المواضيع: عدد الردود (المنشورات) التي تلقاها المستخدم في جميع المواضيع التي أنشأها.
يرجى مساعدتنا للحصول على هذه البيانات الإضافية.
بالنسبة لوزن كل عنصر، نخطط لاستخدام Excel. هل لديكم أي نصائح حول كيفية وزن كل عنصر لتحديد الفائز؟
نريد جعل هذا التحدي جادًا وممتعًا في آن واحد. أفضل المستخدمين هم من يجمعون بين الأكثر نشاطًا، والأكثر فائدة، والأكثر شعبية.
مرة أخرى، شكرًا جزيلًا لكم على مساعدتكم.
ملاحظة: هل يمكننا الحصول على البيانات على شكل مجموعات، بحيث ندخل فقط معرف المجموعة؟ خطتنا هي وضع جميع المشاركين في مجموعة واحدة. حاليًا، يجب إدخال معرف المستخدم لكل مشارك على حدة.