считать сообщения, отправленные пользователями в моем чате - PullRequest
0 голосов
/ 25 декабря 2018

сначала у меня есть скрипт чата, и у каждого пользователя в моем чате есть свой профиль и некоторая информация в его профиле, например, страна, возраст, точильщик, его фотография и его друзья, каким-то образом мне нужно отобразить счетчик всех его сообщенийчто он отправил в чат, и я сделаю новое поле в его профиле, чтобы вставить этот номер.

поэтому здесь у меня есть эта функция, которая хранит сообщения для пользователей в базе данных.

    function userPostChat($content, $snum = ''){
    global $mysqli, $data;
    $lact = calMinutes(3);
    $style = escape($data['bccolor'] . ' ' . $data['bcbold']);
    $mysqli->query("INSERT INTO `my_chat` (post_date, user_id, post_message, post_roomid, type, snum, tcolor) VALUES ('" . time() . "', '{$data['user_id']}', '$content', '{$data['user_roomid']}', 'public', '$snum', '$style')");
    $last_id = $mysqli->insert_id;
    $mysqli->query("UPDATE my_users SET caction = caction + 1 WHERE user_roomid = '{$data['user_roomid']}' and last_action > '$lact'");
    if($snum != ''){
        $user_post = array(
            'post_id'=> $last_id,
            'type'=> 'public',
            'post_date'=> time(),
            'tcolor'=> $style,
            'post_message'=> $content,
        );
        $post = array_merge($data, $user_post);
        if(!empty($post)){
            return createLog($data, $post);
        }
    }
}

я забыл сказать, что функция уже считает сообщения от всех пользователей и сохраняет их в столбце таблицы my_users, называемой «caction», но эта функция считает сообщения для всех пользователей одновременно, как если бы у меня было 0 баллов и кто-то отправилсообщение в чате, оно будет считать это сообщение для меня и для него и всех пользователей в чате, и я не хочу этого, я хочу функцию подсчета сообщений для каждого пользователя и отображения числа.

вот мойтаблицы:

Таблица my_users

user_id
user_name
password
user_photo
user_email
room_id
caction

Таблица my_chat

post_id
user_id
post_date
post_message
post_roomid
type
snum
tcolor

и вот у меня есть мой чаt_file.php

function userPostChatFile($content, $file_name, $type, $file_name2 = ''){
    global $mysqli, $data;
    $lact = calMinutes(3);
    $mysqli->query("INSERT INTO `my_chat` (post_date, user_id, post_message, post_roomid, type, file) VALUES ('" . time() . "', '{$data['user_id']}', '$content', '{$data['user_roomid']}', 'public', '1')");
    $rel = $mysqli->insert_id;
    $mysqli->query("UPDATE my_users SET caction = caction + 1 WHERE user_roomid = '{$data['user_roomid']}' and last_action > '$lact'");
    if($file_name2 != ''){
        $mysqli->query("INSERT INTO `my_upload` (file_name, date_sent, file_user, file_zone, file_type, relative_post) VALUES
        ('$file_name', '" . time() . "', '{$data['user_id']}', 'chat', '$type', '$rel'),
        ('$file_name2', '" . time() . "', '{$data['user_id']}', 'chat', '$type', '$rel')
        ");
    }
    else {
        $mysqli->query("INSERT INTO `my_upload` (file_name, date_sent, file_user, file_zone, file_type, relative_post) VALUES ('$file_name', '" . time() . "', '{$data['user_id']}', 'chat', '$type', '$rel')");
    }
    return true;
}

if(!myAllow($data['allow_image']) || muted() || roomMuted()){ 
    die();
}
if (isset($_FILES["file"])){
    ini_set('memory_limit','128M');
    $info = pathinfo($_FILES["file"]["name"]);
    $extension = $info['extension'];
    $origin = escape(filterOrigin($info['filename']) . '.' . $extension);
    if ( fileError() ){
        echo 1;
        die();
    }
    if (isImage($extension)){
        $imginfo = getimagesize($_FILES["file"]["tmp_name"]);
        if ($imginfo !== false) {

            $width = $imginfo[0];
            $height = $imginfo[1];
            $type = $imginfo['mime'];

            $fname = encodeFileTumb($extension);
            $file_name = $fname['full'];
            $file_tumb = $fname['tumb'];

            move_uploaded_file(preg_replace('/\s+/', '', $_FILES["file"]["tmp_name"]), "../upload/chat/" . $file_name);

            $source = '../upload/chat/' . $file_name;
            $tumb = '../upload/chat/' . $file_tumb;
            $img_path = $data['domain'] . "/upload/chat/" . $file_name;
            $tumb_path = $data['domain'] . "/upload/chat/" . $file_tumb;

            $create = imageTumb($source, $tumb, $type, 180);
            if(file_exists($source) && file_exists($tumb)){
                $check_tumb = getimagesize($tumb);
                if ($check_tumb !== false) {
                    $myimage = tumbLinking($img_path, $tumb_path);
                    userPostChatFile($myimage, $file_name, 'image', $file_tumb);
                }
                else {
                    $myimage = linking($img_path);
                    userPostChatFile($myimage, $file_name, 'image');
                }
            }
            else {
                $myimage = linking($img_path);
                userPostChatFile($myimage, $file_name, 'image');
            }
            echo 5;
            die();


        }
        else {
            echo 1;
            die();
        }
    }
    else if (isFile($extension)){
        $file_name = encodeFile($extension);
        move_uploaded_file(preg_replace('/\s+/', '', $_FILES["file"]["tmp_name"]), "../upload/chat/" . $file_name);
        $myfile = $data['domain'] . "/upload/chat/" . $file_name;
        $myfile =  fileProcess($myfile, $origin);
        userPostChatFile($myfile, $file_name, 'file');
        echo 5;
        die();
    }
    else if (isMusic($extension)){
        $file_name = encodeFile($extension);
        move_uploaded_file(preg_replace('/\s+/', '', $_FILES["file"]["tmp_name"]), "../upload/chat/" . $file_name);
        $myfile = $data['domain'] . "/upload/chat/" . $file_name;
        $myfile =  musicProcess($myfile, $origin);
        userPostChatFile($myfile, $file_name, 'music');
        echo 5;
        die();
    }
    else {
        echo 1;
    }
}
else {
    echo 1;
}
?> 

, так как я могу создать функцию для подсчета сообщений для каждого пользователя и сохранения ее в столбце в таблице my_users .

1 Ответ

0 голосов
/ 25 декабря 2018

Запустив этот запрос, вы получите количество сообщений, отправленных каждым пользователем.Вы можете либо отобразить счет на его странице, либо сохранить его где-нибудь и отобразить его.

SELECT COUNT(*) AS no_messages FROM my_chat WHERE user_id = <user id here>
...