Как сгруппировать личные сообщения?

Всем доброго времени суток! У меня на сайте есть система обмена личными сообщениями. Скажите, можно ли как-то вывести по блоку на каждого уникального собеседника? Как например в вконтакте/фейсбуке. То есть, есть блок с послежним сообщением от некого пользователя, при клике на блок попадаю на страницу со всеми сообщениями от него.
<?php
    if(empty($_GET['to'])){
        echo "Please select message-user!";
        $my_id = $user_data['user_id'];
        $query = mysql_query("SELECT * FROM `messages` WHERE `from` = $my_id ORDER BY `id` DESC") or die(mysql_error());
        $row = mysql_fetch_array($query);
        echo '<br>Last message <br>';
        echo $row['message'];
    }
    if(isset($_POST['send_message'])){
        $message = $_POST['message'];
        $to = $_POST['to'];
        $from = $user_data['user_id'];
        $date = date('Y.m.d');
        $time = date("H:i:s");
        $query = mysql_query("INSERT INTO `messages` (`to`,`from`,`message`,`date`,`time`) VALUES ('$to','$from','$message','$date','$time')") or die(mysql_error());
    }
                    if(!empty($_GET['to'])){
                        $to_user = $_GET['to'];
                        $query = mysql_query("SELECT * FROM users where user_id = $to_user") or die(mysql_error());
                        $row = mysql_fetch_assoc($query);
                        if(!empty($row['username'])){
                            $username = $row['username'];
                            echo "Dialog with <a href='user/$username'>$username</a>:";
                            $from = $user_data['user_id'];
                            $to = $_GET['to'];
                            $query = mysql_query("SELECT * FROM `messages` WHERE `from` = $from AND `to` = $to OR `from` = $to AND `to` = $from ORDER BY `id` DESC") or die(mysql_error());
                            $messages = mysql_fetch_array($query);?>
                            <div class="messages-box">
<?php
                                if(!empty($messages)){
                                    do{
                                        $from_username_id = $messages['from'];
                                        $query_get_name = mysql_query("SELECT * FROM `users` WHERE `user_id` = '$from_username_id'") or die(mysql_error());
                                        $row = mysql_fetch_assoc($query_get_name);
                                        $from_username = $row['username'];
                                        echo "<div class='message'>";
                                        echo "<div class='right'>";
                                        echo $messages['date'];
                                        echo '</div>';
                                        echo "<a href='user/$from_username'>";
                                        echo $from_username;
                                        echo '</a>:<br>';
                                        echo $messages['message'];?>
                                        <div class='right'>
                                        <?php
                                        echo $messages['time'];
                                        echo "</div>";
                                        echo "</div>";
                                    }while($messages = mysql_fetch_array($query));
                                }else{
                                        echo "Dialog is empty!";
                                    }?>
                            </div>
                                <form action="" method="POST">
                                    <div align='center'>
                                        <textarea name="message" id="" cols="45" rows="7"></textarea>
                                    </div>
                                    <input type="hidden" name="to" value="<? echo $_GET['to'];?>">
                                    <input type="Submit" name="send_message" value="send">
                                </form>
<?php
                        }

Надеюсь суть ясна. Скажите пожалуйста, как реализовать мою задумку? Заранее спасибо!
  • Вопрос задан
  • 486 просмотров
Решения вопроса 1
scherbuk
@scherbuk
сгрупируйте сообщения с помощью GROUP BY, чтоб получить список диалогов
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Могу кусок кода привести, с выборки сообщений по диалогам:
$criteria = new CDbCriteria;
$criteria->select = "t.* ,(SELECT COUNT(*) FROM {{messages}} WHERE IF(t.userTo=:userid,userTo,userFrom)=t.userTo AND IF(t.userTo=:userid,userFrom,userTo)=t.userFrom AND isNew=1) AS newMessagesdialog";
$criteria->join = "JOIN (SELECT IF(userTo=:userid,userFrom,userTo) AS user_id_other, MAX(creationDate) AS date_time_max FROM pdb_messages 
WHERE (userTo=:userid OR userFrom=:userid) AND IF(userTo=:userid,hideOnUserTo,hideOnUserFrom)=0  AND moderated_status=1 AND IF(type='s' AND userFrom=:userid,false,true) GROUP BY IF(userTo=:userid,userFrom,userTo)) AS d ON IF(userTo=:userid,userFrom,userTo)=user_id_other AND creationDate=date_time_max ";
$criteria->addCondition('userTo=:userid OR userFrom=:userid');
$criteria->order = 'newMessagesdialog DESC,t.creationDate DESC';
$criteria->params = array(':userid' => $userid);

Код заточен под Yii, но в общем если разобраться то суть в выборке видна
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы