91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

django數據庫返回queryset實現封裝為字典的方式

發布時間:2020-07-23 15:20:55 來源:億速云 閱讀:292 作者:小豬 欄目:開發技術

這篇文章主要講解了django數據庫返回queryset實現封裝為字典的方式,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

默認情況下,Python DB API會返回不帶字段的結果,這意味著你得到的是一個列表,而不是一個字典。花費一點性能代價之后,你可以返回一個字典形式的結果,像這樣:

def dictfetchall(cursor):
 "Returns all rows from a cursor as a dict"
 desc = cursor.description
 return [
  dict(zip([col[0] for col in desc], row))
  for row in cursor.fetchall()
 ]

demo:

from django.db import connection
if __name__ == '__main__':
  """db=db_operate()
  sql='select DISTINCT t1.HostName,t2.IpAddress,t2.RegName,t2.AppUser,t2.`Desc` from machineinfo as t1,asset_appregioninfo as t2 where t1.IpAddress=t2.IpAddress;'
  result=db.mysql_command(settings.conn, sql)
  dic=dict(result)
  print dic
  """
  cur=connection.cursor()
  cur.execute('select DISTINCT t1.HostName,t2.IpAddress,t2.RegName,t2.AppUser,t2.`Desc` from machineinfo as t1,asset_appregioninfo as t2 where t1.IpAddress=t2.IpAddress;')
  dic=dictfetchall(cur)
  print dic

這樣在前臺,就可以通過

{%for i in dic%}
{i.字段}

生成列表了

補充知識:[django] queryset系列化3種方式model_to_dict、serializers

我就廢話不多說了,大家還是直接看代碼吧!

# 序列化方式1:
from django.forms.models import model_to_dict
import json
data=[]
for obj in book_list:
  data.append(model_to_dict(obj))
print(data)
return HttpResponse("ok")

# 序列化方式2:
data=serializers.serialize("json",book_list)
return HttpResponse(data)

# 序列化方式3:
bs=BookSerializers(book_list,many=True)
return Response(bs.data)

看完上述內容,是不是對django數據庫返回queryset實現封裝為字典的方式有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永新县| 阜康市| 汨罗市| 芜湖县| 思茅市| 军事| 亚东县| 通州区| 巴彦县| 交城县| 阿荣旗| 开阳县| 景德镇市| 孙吴县| 关岭| 蕲春县| 科技| 芦溪县| 乌鲁木齐县| 凤凰县| 大埔区| 固镇县| 温州市| 永登县| 新沂市| 武义县| 抚州市| 贵港市| 德钦县| 改则县| 邵阳县| 奈曼旗| 曲沃县| 丘北县| 郓城县| 密山市| 连南| 河曲县| 伊宁县| 汉寿县| 四子王旗|