Maison  >  Article  >  Java  >  Comment implémenter les fonctions de commentaire et de réponse en Java

Comment implémenter les fonctions de commentaire et de réponse en Java

WBOY
WBOYavant
2023-05-25 14:46:223315parcourir

Affichage des effets

Comment implémenter les fonctions de commentaire et de réponse en Java

Il existe deux niveaux de réponses au total (réponse aux commentaires, réponse aux réponses sous commentaires)

Conception de la base de données

Table des commentaires (TFW_Comments) et table du contenu des réponses (TFW_UserResponse) et table des relations entre les réponses aux commentaires (TFW_MsgRelation)

Comment implémenter les fonctions de commentaire et de réponse en Java

Comment implémenter les fonctions de commentaire et de réponse en Java

Idées de conception de base de données :

Remarque : les lecteurs ignorent automatiquement le champ ID de l'organisation de service de la table des commentaires. Ce champ est équivalent à la publication dans laquelle se trouve ce commentaire (sous l'article)

. 1. Selon l'ID de l'article ou C'est l'ID de la publication qui interroge la table des commentaires pour obtenir des commentaires (l'ID de l'organisation de service de cet article). Le premier niveau (commentaires)

Pour obtenir la réponse de deuxième niveau (commentsId), vous devez interroger dans la table de relation en fonction de l'ID du commentaire et le type de réponse est égal à 1. La deuxième couche (réponse sous le commentaire)

obtient les informations de réponse de la troisième couche dans la table de relations en fonction de l'ID du commentaire, du type de réponse 2 et de l'ID de réponse. Le troisième niveau (réponse dans la réponse sous le commentaire) Remarque : l'ID de réponse est son supérieur

Code source de la classe d'implémentation

@Override
    public Map<String, Object> findComments(JSONObject jsonObject) {
        data.clear();
        String userId = jsonObject.getString("userId");
 
        String role = this.role(jsonObject);
        if (role.equals("-1")){
            //没有权限
            data.put("error","-1");
            data.put("msg","当前用户没有权限");
            return data;
        }
 
        List<Map<String, Object>> info = commentsDao.findComment(jsonObject.getString("fWJLID"),null);
        //查询点赞次数
        int countTag = 0;
        MsgRelationTag msgRelationTag = new MsgRelationTag();
 
        for (Map item : info){
            item.put("inputShow",false);
            int commentsId = (int) item.get("commentsId");
            //查询点赞次数
             countTag = msgRelationDao.findCountTagByTagId(commentsId,1);
            item.put("countTag",countTag);
            //设置点赞状态
            msgRelationTag.setTagId(commentsId);
            msgRelationTag.setTagType(1);
            msgRelationTag.setTagUserId(Integer.parseInt(userId));
            MsgRelationTag msgTag = msgRelationDao.findMsgTag(msgRelationTag);
            if (msgTag != null) {
                item.put("tagStatus",msgTag.getStatus());
            }else {
                item.put("tagStatus","");
            }
            //如果有@id
            if (item.get("atId") != null){
                String content = item.get("content").toString();
                StringBuffer tmrAtId = findUserName(item.get("atId").toString());
                item.put("content",content+&#39;@&#39;+tmrAtId);
            }
            //二级回复数据
            List<Map<String, Object>> twoReply = new ArrayList<>();
            //所有数据
            List<Map<String, Object>> userResponse = userResponseDao.findUserResponse(commentsId, null, "","",null);
            for (Map userResponseInfo :userResponse){
                int userResponseIds = Integer.parseInt(userResponseInfo.get("userResponseId").toString());
                //查询点赞次数
                countTag = msgRelationDao.findCountTagByTagId(userResponseIds,2);
                //设置点赞状态
                msgRelationTag.setTagId(userResponseIds);
                msgRelationTag.setTagType(2);
                msgTag = msgRelationDao.findMsgTag(msgRelationTag);
                if (msgTag != null) {userResponseInfo.put("tagStatus",msgTag.getStatus());}else {userResponseInfo.put("tagStatus","");}
                userResponseInfo.put("countTag",countTag);
                userResponseInfo.put("inputShow",false);
                Integer responseType = (Integer) userResponseInfo.get("responseType");
                for (Map stairReplyInfo : userResponse){
                    Integer  userResponseId = (Integer) stairReplyInfo.get("userResponseId");
                    int msgRelationId = Integer.parseInt(stairReplyInfo.get("msgRelationId").toString());
                    //接受者id*/
                    twoReply = userResponseDao.findUserResponse(msgRelationId, userResponseId,"1","",null); //二级回复数据
                    for (Map twoReplyItem : twoReply){
                        int twoReplyId = Integer.parseInt(twoReplyItem.get("userResponseId").toString());
                        twoReplyItem.put("inputShow",false);
                        //查询点赞次数
                        countTag = msgRelationDao.findCountTagByTagId(twoReplyId,2);
                        twoReplyItem.put("countTag",countTag);
                        //设置点赞状态
                        msgRelationTag.setTagId(twoReplyId);
                        msgTag = msgRelationDao.findMsgTag(msgRelationTag);
                        if (msgTag != null) {twoReplyItem.put("tagStatus",msgTag.getStatus());}else {twoReplyItem.put("tagStatus","");}
                        String userRepContent = twoReplyItem.get("userRepContent").toString();
                        if (twoReplyItem.get("tmrAtId") != null){
                            StringBuffer tmrAtId = findUserName(twoReplyItem.get("tmrAtId").toString());
                            twoReplyItem.put("userRepContent",userRepContent+&#39;@&#39;+tmrAtId);
                        }
 
                    }
                    stairReplyInfo.put("twoReply",twoReply);
                }
            }
            item.put("stairReply",userResponse);
        }
        data.put("data",info);
        data.put("error",0);
        data.put("msg","查询成功");
        return data;
    }

Les autres codes peuvent être ignorés. Les phrases principales sont :

Obtenez les commentaires sous le post

 List<Map<String, Object>> info = commentsDao.findComment(jsonObject.getString("fWJLID"),null);

L'image ci-dessus obtient les commentaires basés sur FWJLID. (Ceci peut être utilisé comme ID de la publication pour obtenir les commentaires sous la publication) Affichage de niveau un

correspond à l'instruction SQL (OPT est ma table utilisateur)

select tc.content ,tc.commentsId,convert(varchar(19),tc.startTime,120) as startTime,tc.recipientId ,tc.operatorId,zo.NAME as operatorName,tc.atId,zo.HeadImgUrl as operatorHeadImgUrl
         from TFW_Comments tc
         left join zd_opt zo on zo.AID = tc.operatorId where tc.FWJLID = 5101

Résultats de la requête :

Comment implémenter les fonctions de commentaire et de réponse en Java

Obtenez la réponse sous le commentaire

List<Map<String, Object>> userResponse = userResponseDao.findUserResponse(commentsId, null, "","",null);

L'image ci-dessus obtient les réponses sous les commentaires en fonction de l'ID des commentaires. (Obtenez la réponse en fonction de l'ID du commentaire) L'affichage de deuxième niveau

correspond à l'instruction SQL

select
 	 tur.userResponseId,tur.operatorId,tur.recipientId,convert(varchar(19),tur.startTime,120) as startTime,tur.userRepContent,tmr.atId as tmrAtId,
 	 tmr.msgRelationId ,tmr.responseType,tmr.replyId,
        zo.NAME as operatorName,
        zo1.NAME as recipientName,
        zo.HeadImgUrl as operatorHeadImgUrl,
        zo1.HeadImgUrl as recipientHeadImgUrl
        from TFW_MsgRelation tmr
        left join TFW_UserResponse tur on tur.userResponseId = tmr.userResponseId
        left join zd_opt zo on zo.AID = tur.operatorId
        left join zd_opt zo1 on zo1.AID = tur.recipientId where tmr.commentsId = 47

Le résultat de la requête

Comment implémenter les fonctions de commentaire et de réponse en Java

Obtenez la réponse de deuxième niveau

 twoReply = userResponseDao.findUserResponse(msgRelationId, userResponseId,"1","",null); //二级回复数据

L'image ci-dessus sert à obtenir la deuxième Réponse au niveau basée sur l'ID de commentaire (msgRelationId) et la réponse au niveau de l'ID de réponse (userResponseId). L'ID de réponse est également la classe parent. C'est l'ID de la réponse. L'affichage de la troisième couche

correspond aux résultats de la requête sql

select
 	 tur.userResponseId,tur.operatorId,tur.recipientId,convert(varchar(19),tur.startTime,120) as startTime,tur.userRepContent,tmr.atId as tmrAtId,
 	 tmr.msgRelationId ,tmr.responseType,tmr.replyId,
        zo.NAME as operatorName,
        zo1.NAME as recipientName,
        zo.HeadImgUrl as operatorHeadImgUrl,
        zo1.HeadImgUrl as recipientHeadImgUrl
        from TFW_MsgRelation tmr
        left join TFW_UserResponse tur on tur.userResponseId = tmr.userResponseId
        left join zd_opt zo on zo.AID = tur.operatorId
        left join zd_opt zo1 on zo1.AID = tur.recipientId where tmr.commentsId = 136 and tmr.replyId = 155

Comment implémenter les fonctions de commentaire et de réponse en Java

affichage de la page de retour et affichage du corps de retour

Comment implémenter les fonctions de commentaire et de réponse en Java

Comment implémenter les fonctions de commentaire et de réponse en Java

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer