django 遞歸查詢評論的示例詳解
更新時(shí)間:2025年01月03日 09:47:37 作者:像風(fēng)一樣的男人@
文章介紹了將表數(shù)據(jù)轉(zhuǎn)換為樹狀結(jié)構(gòu)以及如何處理扁平化數(shù)據(jù)的方法,探討了在數(shù)據(jù)管理中的應(yīng)用和實(shí)現(xiàn)技術(shù),感興趣的朋友一起看看吧
表數(shù)據(jù)
樹狀結(jié)構(gòu)
@action(methods=('GET', ), detail=False) def get_info_pinglun(self, request, *args, **kwargs) -> Response: ''' 根據(jù)評論id查所有回復(fù) @params wenxian_pinglun_id --> 評論id; ''' wenxian_pinglun_id = self.request.GET.get('wenxian_pinglun_id') results = self._recursion_get_reply(wenxian_pinglun_id) return Response({ 'code': 0, 'msg': 'success', 'results': results }) def _recursion_get_reply(self, wenxian_pinglun_id: int): '''遞歸查該評論底下的所有回復(fù)''' results = [] queryset = WenxianPinglun.objects.filter(other_pinglun_id=wenxian_pinglun_id) # 獲取該評論下所有回復(fù) for instance in queryset: user = User.objects.get(user_id=instance.user_id) other = User.objects.get(user_id=instance.other_id) results.append({ 'wenxian_pinglun_id': instance.wenxian_pinglun_id, 'user__img': user.img, 'user__nicheng': user.nicheng, 'other__nicheng': other.nicheng, 'text': instance.text, 'children': self._recursion_get_reply(instance.wenxian_pinglun_id) }) return results
扁平化處理
@action(methods=('GET', ), detail=False) def get_info_pinglun(self, request, *args, **kwargs) -> Response: ''' 根據(jù)評論id查所有回復(fù) @params wenxian_pinglun_id --> 評論id; ''' wenxian_pinglun_id = self.request.GET.get('wenxian_pinglun_id') results = self._recursion_get_reply(wenxian_pinglun_id) return Response({ 'code': 0, 'msg': 'success', 'results': results }) def _recursion_get_reply(self, wenxian_pinglun_id: int): '''遞歸查該評論底下的所有回復(fù)''' results = [] queryset = WenxianPinglun.objects.filter(other_pinglun_id=wenxian_pinglun_id) # 獲取該評論下所有回復(fù) for instance in queryset: user = User.objects.get(user_id=instance.user_id) other = User.objects.get(user_id=instance.other_id) results.append({ 'wenxian_pinglun_id': instance.wenxian_pinglun_id, 'user__img': user.img, 'user__nicheng': user.nicheng, 'other__nicheng': other.nicheng, 'text': instance.text }) for instance in queryset: results.extend(self._recursion_get_reply(instance.wenxian_pinglun_id)) return results
到此這篇關(guān)于django 遞歸查詢評論的示例詳解的文章就介紹到這了,更多相關(guān)django 評論內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java運(yùn)行錯(cuò)誤A JNI error的解決方案
這篇文章主要介紹了java運(yùn)行錯(cuò)誤A JNI error的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08Java?中導(dǎo)入excel時(shí)使用?trim()?無法去除空格的問題解決方案
這篇文章主要介紹了Java中導(dǎo)入excel時(shí)使用trim()無法去除空格的解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06Spring Boot解決項(xiàng)目啟動時(shí)初始化資源的方法
這篇文章主要給大家介紹了關(guān)于Spring Boot如何解決項(xiàng)目啟動時(shí)初始化資源的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05Java+Swing實(shí)現(xiàn)經(jīng)典五子棋游戲
五子棋是世界智力運(yùn)動會競技項(xiàng)目之一,是一種兩人對弈的純策略型棋類游戲,是世界智力運(yùn)動會競技項(xiàng)目之一。本文將采用Java Swing實(shí)現(xiàn)這一經(jīng)典游戲,需要的可以參考一下2022-01-01IDEA提示內(nèi)存不足 low memory的完美解決方法(親測好用)
這篇文章主要介紹了IDEA提示內(nèi)存不足 low memory的完美解決方法(親測好用),這里以IDEA2022版本為例,在IDE中 幫助(help)–>change memory setting(改變內(nèi)存設(shè)置),具體設(shè)置辦法文中給大家詳細(xì)講解,需要的朋友可以參考下2023-01-01