q05.sql 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. \set tag '\'Sikh_Empire\''
  2. -- materialize=> \i q05.sql
  3. -- person.id | replycount | likecount | messagecount | score
  4. -- ----------------+------------+-----------+--------------+-------
  5. -- 8796093023472 | 2 | 176 | 1 | 1765
  6. -- 2199023258140 | 2 | 134 | 1 | 1345
  7. -- 4398046515963 | 3 | 89 | 1 | 897
  8. -- 17592186051306 | 0 | 55 | 1 | 551
  9. -- 19791209305553 | 1 | 52 | 2 | 524
  10. -- 21990232561529 | 2 | 29 | 1 | 295
  11. -- 6574 | 0 | 18 | 1 | 181
  12. -- 8796093023990 | 7 | 16 | 1 | 175
  13. -- 13194139533461 | 2 | 16 | 1 | 165
  14. -- 8796093026421 | 15 | 0 | 2 | 32
  15. -- 21990232557614 | 12 | 0 | 3 | 27
  16. -- 8796093026744 | 11 | 0 | 1 | 23
  17. -- 24189255813538 | 10 | 0 | 2 | 22
  18. -- 8796093026743 | 5 | 1 | 1 | 21
  19. -- 6597069767028 | 9 | 0 | 2 | 20
  20. -- 21990232562293 | 8 | 0 | 2 | 18
  21. -- 26388279075120 | 3 | 1 | 2 | 18
  22. -- 2199023264490 | 8 | 0 | 1 | 17
  23. -- 6597069774335 | 8 | 0 | 1 | 17
  24. -- 8796093022752 | 3 | 1 | 1 | 17
  25. -- 28587302326226 | 7 | 0 | 2 | 16
  26. -- 3451 | 7 | 0 | 1 | 15
  27. -- 4961 | 2 | 1 | 1 | 15
  28. -- 19791209301861 | 7 | 0 | 1 | 15
  29. -- 24189255813464 | 7 | 0 | 1 | 15
  30. -- 24189255813906 | 2 | 1 | 1 | 15
  31. -- 4398046513670 | 6 | 0 | 1 | 13
  32. -- 6597069776679 | 6 | 0 | 1 | 13
  33. -- 10995116280719 | 1 | 1 | 1 | 13
  34. -- 10995116287958 | 6 | 0 | 1 | 13
  35. -- 13194139541085 | 6 | 0 | 1 | 13
  36. -- 21990232556570 | 1 | 1 | 1 | 13
  37. -- 21990232561742 | 6 | 0 | 1 | 13
  38. -- 21990232565214 | 6 | 0 | 1 | 13
  39. -- 26388279072028 | 6 | 0 | 1 | 13
  40. -- 35184372092938 | 6 | 0 | 1 | 13
  41. -- 361 | 5 | 0 | 1 | 11
  42. -- 7244 | 0 | 1 | 1 | 11
  43. -- 8892 | 5 | 0 | 1 | 11
  44. -- 4398046517444 | 5 | 0 | 1 | 11
  45. -- 8796093030183 | 5 | 0 | 1 | 11
  46. -- 10995116279521 | 5 | 0 | 1 | 11
  47. -- 13194139541181 | 0 | 1 | 1 | 11
  48. -- 13194139541221 | 5 | 0 | 1 | 11
  49. -- 13194139541373 | 5 | 0 | 1 | 11
  50. -- 15393162794711 | 5 | 0 | 1 | 11
  51. -- 21990232561531 | 0 | 1 | 1 | 11
  52. -- 32985348839886 | 5 | 0 | 1 | 11
  53. -- 35184372091084 | 5 | 0 | 1 | 11
  54. -- 35184372098900 | 5 | 0 | 1 | 11
  55. -- 5099 | 4 | 0 | 2 | 10
  56. -- 17592186045301 | 4 | 0 | 2 | 10
  57. -- 2199023259253 | 4 | 0 | 1 | 9
  58. -- 4398046520094 | 4 | 0 | 1 | 9
  59. -- 6597069767319 | 4 | 0 | 1 | 9
  60. -- 6597069767925 | 4 | 0 | 1 | 9
  61. -- 8796093027822 | 4 | 0 | 1 | 9
  62. -- 8796093030655 | 4 | 0 | 1 | 9
  63. -- 10995116283381 | 4 | 0 | 1 | 9
  64. -- 10995116283874 | 4 | 0 | 1 | 9
  65. -- 13194139535015 | 4 | 0 | 1 | 9
  66. -- 15393162797132 | 4 | 0 | 1 | 9
  67. -- 17592186046214 | 4 | 0 | 1 | 9
  68. -- 17592186053687 | 4 | 0 | 1 | 9
  69. -- 19791209306158 | 4 | 0 | 1 | 9
  70. -- 21990232556400 | 4 | 0 | 1 | 9
  71. -- 21990232561740 | 4 | 0 | 1 | 9
  72. -- 30786325581075 | 4 | 0 | 1 | 9
  73. -- 32985348837969 | 4 | 0 | 1 | 9
  74. -- 35184372098666 | 4 | 0 | 1 | 9
  75. -- 4398046519516 | 3 | 0 | 2 | 8
  76. -- 3819 | 3 | 0 | 1 | 7
  77. -- 6394 | 3 | 0 | 1 | 7
  78. -- 8726 | 3 | 0 | 1 | 7
  79. -- 8796093025681 | 3 | 0 | 1 | 7
  80. -- 8796093027283 | 3 | 0 | 1 | 7
  81. -- 8796093032299 | 3 | 0 | 1 | 7
  82. -- 10995116283026 | 3 | 0 | 1 | 7
  83. -- 17592186044948 | 3 | 0 | 1 | 7
  84. -- 17592186047799 | 3 | 0 | 1 | 7
  85. -- 17592186048641 | 3 | 0 | 1 | 7
  86. -- 19791209302281 | 3 | 0 | 1 | 7
  87. -- 21990232560723 | 3 | 0 | 1 | 7
  88. -- 24189255817882 | 3 | 0 | 1 | 7
  89. -- 26388279073672 | 3 | 0 | 1 | 7
  90. -- 26388279073849 | 3 | 0 | 1 | 7
  91. -- 26388279074975 | 3 | 0 | 1 | 7
  92. -- 26388279075052 | 3 | 0 | 1 | 7
  93. -- 28587302324452 | 3 | 0 | 1 | 7
  94. -- 30786325580327 | 3 | 0 | 1 | 7
  95. -- 32985348841715 | 3 | 0 | 1 | 7
  96. -- 35184372094081 | 3 | 0 | 1 | 7
  97. -- 35184372099063 | 3 | 0 | 1 | 7
  98. -- 24189255812191 | 2 | 0 | 2 | 6
  99. -- 217 | 2 | 0 | 1 | 5
  100. -- 2174 | 2 | 0 | 1 | 5
  101. -- 8018 | 2 | 0 | 1 | 5
  102. -- 2199023258226 | 2 | 0 | 1 | 5
  103. -- 2199023261155 | 2 | 0 | 1 | 5
  104. -- 2199023262487 | 2 | 0 | 1 | 5
  105. -- (100 rows)
  106. --
  107. -- Time: 17582.355 ms (00:17.582)
  108. /* Q5. Most active posters in a given topic
  109. \set tag '\'Abbas_I_of_Persia\''
  110. */
  111. WITH detail AS (
  112. SELECT Message.CreatorPersonId AS CreatorPersonId
  113. , sum(coalesce(Cs.c, 0)) AS replyCount
  114. , sum(coalesce(Plm.c, 0)) AS likeCount
  115. , count(Message.MessageId) AS messageCount
  116. FROM Tag
  117. JOIN Message_hasTag_Tag
  118. ON Message_hasTag_Tag.TagId = Tag.id
  119. JOIN Message
  120. ON Message.MessageId = Message_hasTag_Tag.MessageId
  121. LEFT JOIN (SELECT ParentMessageId, count(*) FROM Message c WHERE ParentMessageId IS NOT NULL GROUP BY ParentMessageId) Cs(id, c) ON Cs.id = Message.MessageId
  122. LEFT JOIN (SELECT MessageId, count(*) FROM Person_likes_Message GROUP BY MessageId) Plm(id, c) ON Plm.id = Message.MessageId
  123. WHERE Tag.name = :tag
  124. GROUP BY Message.CreatorPersonId
  125. )
  126. SELECT CreatorPersonId AS "person.id"
  127. , replyCount
  128. , likeCount
  129. , messageCount
  130. , 1*messageCount + 2*replyCount + 10*likeCount AS score
  131. FROM detail
  132. ORDER BY score DESC, CreatorPersonId
  133. LIMIT 100
  134. ;