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.處理后前端獲取
補(bǔ)充知識: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. Java類加載機(jī)制實現(xiàn)步驟解析2. python3實現(xiàn)往mysql中插入datetime類型的數(shù)據(jù)3. python爬蟲實戰(zhàn)之制作屬于自己的一個IP代理模塊4. moment轉(zhuǎn)化時間戳出現(xiàn)Invalid Date的問題及解決5. python如何實現(xiàn)word批量轉(zhuǎn)HTML6. PHP如何打印跟蹤調(diào)試信息7. Java8內(nèi)存模型PermGen Metaspace實例解析8. ASP動態(tài)網(wǎng)頁制作技術(shù)經(jīng)驗分享9. ASP腳本組件實現(xiàn)服務(wù)器重啟10. ASP中if語句、select 、while循環(huán)的使用方法
