diff --git a/src/common/connection.py b/src/common/connection.py
index f3627cfae9987bcf9caa3bbbe5ae66066ade3422..fac387aeed3c4f1f13b2bb6e34ca64a5a2ebc818 100644
--- a/src/common/connection.py
+++ b/src/common/connection.py
@@ -2304,7 +2304,8 @@ class Connection(CommonConnection, ConnectionHandlers):
                 room_id=resp.getTag('unique').getData()))
         self.connection.SendAndCallForResponse(iq, _on_response)
 
-    def join_gc(self, nick, room_jid, password, change_nick=False):
+    def join_gc(self, nick, room_jid, password, change_nick=False,
+    rejoin=False):
         # FIXME: This room JID needs to be normalized; see #1364
         if not gajim.account_is_connected(self.name):
             return
@@ -2353,6 +2354,10 @@ class Connection(CommonConnection, ConnectionHandlers):
                 last_date = time.strftime('%Y-%m-%dT%H:%M:%SZ', time.gmtime(
                     last_date))
                 tags['since'] = last_date
+                if rejoin:
+                    tags['since'] = time.strftime('%Y-%m-%dT%H:%M:%SZ',
+                    time.gmtime(gajim.logger.get_last_date_that_has_logs(
+                    room_jid, is_room=True) + 1))
             nb = gajim.config.get('muc_restore_lines')
             if nb >= 0:
                 tags['maxstanzas'] = nb
diff --git a/src/groupchat_control.py b/src/groupchat_control.py
index 469d1a640b40da3ec6eb36258cd0e5d26b325b4b..9581124f39f2a3222f88f3e952c1af8c3ccd9058 100644
--- a/src/groupchat_control.py
+++ b/src/groupchat_control.py
@@ -1274,7 +1274,7 @@ class GroupchatControl(ChatControlBase):
         gajim.gc_connected[obj.conn.name][self.room_jid]:
             return
         password = gajim.gc_passwords.get(self.room_jid, '')
-        obj.conn.join_gc(self.nick, self.room_jid, password)
+        obj.conn.join_gc(self.nick, self.room_jid, password, rejoin=True)
 
     def _nec_decrypted_message_received(self, obj):
         if obj.conn.name != self.account:
@@ -1351,7 +1351,7 @@ class GroupchatControl(ChatControlBase):
             return False
         password = gajim.gc_passwords.get(self.room_jid, '')
         gajim.connections[self.account].join_gc(self.nick, self.room_jid,
-            password)
+            password, rejoin=True)
         return True
 
     def draw_roster(self):