django 内置 JSON 字段 使用场景

news2025/1/23 22:44:56

Django 内置的 JSON 字段(JSONField)是在 Django 3.1 版本中引入的,用于处理 JSON 格式的数据。JSONField 允许在数据库表中存储和查询 JSON 数据,并且在与 Python 代码交互时自动转换为合适的 Python 数据类型。以下是一些常见的使用场景:

1. 存储动态结构的数据

当你需要存储结构不固定的数据时,JSONField 非常有用。例如,某个表中的某些记录可能具有不同的属性和值。在这种情况下,可以使用 JSONField 来灵活地存储这些数据,而不需要为每个可能的属性创建单独的数据库列。

from django.db import models

class Product(models.Model):
    name = models.CharField(max_length=100)
    attributes = models.JSONField()

在上面的例子中,attributes 字段可以存储任意 JSON 数据,例如:

{
    "color": "red",
    "size": "M",
    "weight": "1.5kg"
}

2. 配置数据的存储

JSONField 非常适合存储配置数据或其他设置,这些数据可能在应用的不同部分被使用和修改。

class UserSettings(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    settings = models.JSONField()

例如,用户设置可能包含通知偏好、界面定制等:

{
    "notifications": {
        "email": true,
        "sms": false
    },
    "theme": "dark"
}

3. API 数据的存储

在处理从外部 API 获取的数据时,通常数据格式为 JSON。将这些数据直接存储在 JSONField 中,可以减少解析和重新组装数据的开销。

class ApiResponse(models.Model):
    response_data = models.JSONField()

这样你可以直接将整个 API 响应存储在数据库中,方便以后检索和分析。

4. 日志和事件数据

对于一些应用来说,日志和事件数据可能是高度动态和嵌套的结构。JSONField 可以方便地存储这些信息。

class EventLog(models.Model):
    timestamp = models.DateTimeField(auto_now_add=True)
    event_type = models.CharField(max_length=100)
    details = models.JSONField()

例如,事件详情可能包含各种不同的字段和嵌套结构:

{
    "user_id": 123,
    "action": "login",
    "metadata": {
        "ip_address": "192.168.1.1",
        "device": "mobile"
    }
}

5. 分析和报表

在某些情况下,你可能需要存储复杂的分析结果或报表数据,这些数据通常也是动态的和结构化的。JSONField 可以帮助你高效地存储和查询这些数据。

6. 简单对象存储

当需要在模型中存储一个简单的对象(例如,字典、列表)时,JSONField 是一个简单而有效的解决方案。

生产案例

使用django 接收统计普罗米修斯的告警,直接使用JSON 字段保存数据
在这里插入图片描述
在这里插入图片描述
数据结构语句:

CREATE TABLE `zabbix_prometheusalert` (
	`id` BIGINT(20) NOT NULL AUTO_INCREMENT,
	`status` VARCHAR(50) NOT NULL COLLATE 'utf8mb4_general_ci',
	`labels` JSON NOT NULL,
	`annotations` JSON NOT NULL,
	`starts_at` DATETIME(6) NOT NULL,
	`ends_at` DATETIME(6) NULL DEFAULT NULL,
	`generator_url` VARCHAR(1000) NOT NULL COLLATE 'utf8mb4_general_ci',
	`fingerprint` VARCHAR(50) NOT NULL COLLATE 'utf8mb4_general_ci',
	`recorded_time` DATETIME(6) NOT NULL COMMENT '记录时间',
	PRIMARY KEY (`id`) USING BTREE
)
COMMENT='prometheus alert'
COLLATE='utf8mb4_general_ci'
ENGINE=InnoDB
AUTO_INCREMENT=3200
;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1789169.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

成都欣丰洪泰文化传媒有限公司好不好?

在数字经济的浪潮中,电商行业以其独特的魅力和无限的发展潜力,吸引了越来越多的企业和个人投身其中。作为电商服务领域的佼佼者,成都欣丰洪泰文化传媒有限公司凭借专业的团队、优质的服务和创新的理念,不断引领电商新风尚&#xf…

INT202 例题

算法复杂度 O(n):表示算法的渐进上界。如果一个算法的运行时间是O(n),那么它的运行时间最多与输入规模n成正比。换句话说,当输入规模n增加时,算法的运行时间不会超过某个常数倍的n。比如,如果一个算法的时间复杂度是O(…

AndroidStudio使用高德地图API获取手机定位

一、高德地图API申请 首先去高德注册开发者账号 下面这两个选项,也是我们项目成功的关键 1.1怎么获取SHA1指纹密码 ①使用AS自带的签名文件 你的用户文件下面会有一个.android文件夹,进入文件夹,在这个路径下打开cmd 如果.android下面没有签名文件参考创建文章 …

【管理咨询宝藏124】通过BLM打通前端业务与财务的双轨制设计方案

本报告首发于公号“管理咨询宝藏”,如需阅读完整版报告内容,请查阅公号“管理咨询宝藏”。 【管理咨询宝藏124】通过BLM打通前端业务与财务的双轨制设计方案 【格式】PDF版本 【关键词】BLM、组织架构设计、流程优化 【核心观点】 - 运用“拉通业务财务…

【原创】springboot+mysql大学生综合素质测评管理系统设计与实现

个人主页:程序猿小小杨 个人简介:从事开发多年,Java、Php、Python、前端开发均有涉猎 博客内容:Java项目实战、项目演示、技术分享 文末有作者名片,希望和大家一起共同进步,你只管努力,剩下的交…

【python】成功解决“ValueError: Expected 2D array, got 1D array instead”错误的全面指南

成功解决“ValueError: Expected 2D array, got 1D array instead”错误的全面指南 一、引言 在Python的数据分析和机器学习领域,尤其是使用NumPy、Pandas、scikit-learn等库时,经常会遇到各种类型错误。其中,“ValueError: Expected 2D arr…

MP-SPDZ的学习与运用

目录 MP-SPDZ 的介绍主要功能典型应用场景 MP-SPDZ 的安装实验环境准备环境安装MP-SPDZ 下载和编译 MP-SPDZ 的使用测试程序第三方求和三方计算测试冒泡排序比较运算函数语法详解——Sint语法详解——Array基于AES电路实现OPRFORAM隐私集合求交实现两台虚拟机之间进行MPC简单实…

视觉SLAM十四讲:从理论到实践(Chapter8:视觉里程计2)

前言 学习笔记,仅供学习,不做商用,如有侵权,联系我删除即可 一、目标 1.理解光流法跟踪特征点的原理。 2.理解直接法是如何估计相机位姿的。 3.实现多层直接法的计算。 特征点法存在缺陷: 二、光流(Optical Flow) …

SEO之关键词扩展(二)

初创企业搭建网站的朋友看1号文章;想学习云计算,怎么入门看2号文章谢谢支持: 1、我给不会敲代码又想搭建网站的人建议 2、新手上云 (接上一篇。。。) 5、各种形式的变体 1.同义词 假设核心关键词是酒店,…

Python版《消消乐》,附源码

曾经风靡一时的消消乐,至今坐在地铁上都可以看到很多人依然在玩,想当年我也是大军中的一员,那家伙,吃饭都在玩,进入到高级的那种胜利感还是很爽的,连续消,无限消,哈哈,现…

Kotlin中的StateFlow和SharedFlow有什么区别?

本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点 在Kotlin的协程库kotlinx.coroutines中,StateFlow和SharedFlow是两种用于处理事件流的API,它们有相似之处,但…

MySQL中获取时间的方法

大家好,在MySQL数据库开发中,获取时间是一个常见的需求。MySQL提供了多种方法来获取当前日期、时间和时间戳,并且可以对时间进行格式化、计算和转换。 以下是一些常用的MySQL时间函数及其示例: 1、NOW():用于获取当前…

GPT-4与GPT-4O的区别详解:面向小白用户

1. 模型介绍 在人工智能的语言模型领域,OpenAI的GPT-4和GPT-4O是最新的成员。这两个模型虽然来源于相同的基础技术,但在功能和应用上有着明显的区别。 GPT-4:这是一个通用型语言模型,可以理解和生成自然语言。无论是写作、对话还…

MySQL 关键特性一:插入缓冲、双写缓冲

前言 ​ 本文主要介绍 mysql 的几大特性之几,如:双写缓冲和插入缓存。 双写缓冲 基本概念 ​ 双写缓冲(doublewrite buffer)是MySQL/InnoDB中用于支持原子页面更新的一种机制。在传统的数据库系统中,为了保证数据的…

小米商城格式化检测点

小米商城格式化检测点: var a function () {var x !0;return function (a, t) {var e x ? function () {if (t) {var x t.apply(a, arguments);t null;return x;}} : function () {};x !1;return e;};}();var t {};function e(n) {var r a(this, function…

数据持久化第七课-URL重写与Ajax

数据持久化第七课-URL重写与Ajax 一.预习笔记 1.URL重写(对网页地址进行保护) 首先编写module,实现对网络地址的处理 其次就是module的配置 最后验证url重写技术 2.Ajax数据交互 编写后端响应数据 处理跨域的配置问题 运行项目得到后端响应数据的地址 编写前端ajax进行数据请…

珈和科技携手浙江省气候中心,打造农业气象数字化服务新标杆!

古谚有云:春耕夏种秋收冬藏,皆在天时。可天有不测风云,农有“旦夕祸福”。寒潮、干旱、洪涝等气象灾害频繁发生,给农业生产带来了巨大挑战。 气候变化直接影响着农业生产,数字化时代,如何依靠科技手段降低…

解决 clickhouse jdbc 偶现 failed to respond 问题

背景 Clickhouse集群版本为 Github Clickhouse 22.3.5.5, clickhouse-jdbc 版本为 0.2.4。 问题表现 随着业务需求的扩展,基于Clickhouse 需要支持更多任务在期望的时效内完成,于是将业务系统和Clickhouse交互的部分都提交给可动态调整核心…

【面试笔记】单片机软件工程师,工业控制方向(储能)

文章目录 1. 基础知识1.1 C语言笔试题1.1.1 用宏定义得到一个数组所含的元素个数1.1.2 定义函数指针从程序固定地址(0)开始执行1.1.3 volatile的含义及作用1.1.4 32位系统,整数7和-7,分别以大端和小端存储,请示意说明 1.2 嵌入式基础1.2.1 简…

知识图谱应用---智慧金融

文章目录 智慧金融典型应用 智慧金融 智慧金融作为一个有机整体,知识图谱提供了金融领域知识提取、融合、分析、推断、决策等功能,如下图所示。在场景方面,智慧金融涵盖智慧支付、智慧财富管理、智慧银行、智慧证券、智慧保险、智慧风控等诸多…