django 解決自定義序列化返回處理數(shù)據(jù)為null的問題
在接口返回數(shù)據(jù)時,如果數(shù)據(jù)庫表中查詢出來的某些字段為null時,在前端需要多處理一些數(shù)據(jù)異常的情況。
django可以自定義序列化返回處理,將返回的內(nèi)容限制和預(yù)處理再返回到前端。
1.未處理時返回
如圖上,有email、mobile這兩個字段是有可以為空且默認(rèn)值為null的。
2.to_representation處理
在模型序列化類增加, to_representation方法,以自定義數(shù)據(jù)處理限制
from rest_framework import serializersfrom .models import UserInfoclass UserInfoSerializer(serializers.ModelSerializer): class Meta: model = UserInfo # fields = ’__all__’ fields = ( ’id’, ’email’, ’date_create’, ’mobile’, ’email’, ’notice_voice’, ’notice_email’, ’notice_sms’, ’notice_push’) def to_representation(self, instance): data = super().to_representation(instance) if not data[’email’]: data[’email’] = '' if not data[’mobile’]: data[’mobile’] = '' return data
3.處理后前端獲取
補充知識:Django query查詢正常,返回對象為空QuerySet
我出現(xiàn)這個錯誤的前提條件:
數(shù)據(jù)為導(dǎo)入的數(shù)據(jù),并不是正常從前端添加入庫的。
問題現(xiàn)象:
views里獲取數(shù)據(jù)庫查詢對象集合 obj= models.表名.objects.filter(**kwargs)
控制臺debug發(fā)現(xiàn) obj為QuerySet<[]>
拿著query到數(shù)據(jù)庫里執(zhí)行sql ,還能查出數(shù)據(jù),就是沒返回
解決問題:
查看數(shù)據(jù)庫字段是否符合models中定義的格式,如,是否有默認(rèn)值,
將數(shù)據(jù)庫為空字段修改成和models一樣的,有個快速比對的方法,從前端向數(shù)據(jù)庫添加一條數(shù)據(jù),拿這個正式數(shù)據(jù)和導(dǎo)入數(shù)據(jù)做比對,哪里不一樣,修改哪里即可。
以上這篇django 解決自定義序列化返回處理數(shù)據(jù)為null的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP新手必備的基礎(chǔ)知識2. .NET 中配置從xml轉(zhuǎn)向json方法示例詳解3. 微信小程序?qū)崿F(xiàn)商品分類頁過程結(jié)束4. vue-electron中修改表格內(nèi)容并修改樣式5. 推薦一個好看Table表格的css樣式代碼詳解6. ASP常用日期格式化函數(shù) FormatDate()7. 利用FastReport傳遞圖片參數(shù)在報表上展示簽名信息的實現(xiàn)方法8. phpstudy apache開啟ssi使用詳解9. HTML中的XML數(shù)據(jù)島記錄編輯與添加10. 以PHP代碼為實例詳解RabbitMQ消息隊列中間件的6種模式
