postgresql数据库对json数据的处理

1. 两种数据形式存储 json,jsonb

(1)json存储快,使用慢; 存的时候不做处理,使用时再解析
(2)jsonb存储稍慢,存储时就做了解析,使用时速度较快
(3)两者的部分函数很相似,稍有区别

2.使用例子

(1)创建学生表
CREATE TABLE if not exists public.student
        (
          name varchar,
          user_card varchar,
          age int,
          info jsonb,
          CONSTRAINT student_pkey PRIMARY KEY (user_card)
        );
        insert into public.student values('tom', '1234567890', 11,'{"key1":[1,2,4,["a","b","c"]],"key2":[2,5,7,["a","d","e"]]}');
        insert into public.student values('katty', '1234509890', 20,'{"key1":[8,10,4,["j","n","c"]],"key2":[9,5,19,["a","m","e"]]}');
(2)根据条件获取json
select info from public.student where name='tom'

+————————————————————————–+
| info |
+————————————————————————–+
| {“key1”: [1, 2, 4, [“a”, “b”, “c”]], “key2”: [2, 5, 7, [“a”, “d”, “e”]]} |
+————————————————————————–+

(3) 根据key获取数据
select info->'key1'  as info_list from public.student;

+—————————–+
| info_list |
+—————————–+
| [1, 2, 4, [“a”, “b”, “c”]] |
| [8, 10, 4, [“j”, “n”, “c”]] |
+—————————–+
2 rows in set

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 创建一个Django项目和应用程序 首先,我们需要创建一个Django项目和应用程序。在终端中输入以下命令: ``` django-admin startproject myproject cd myproject python manage.py startapp myapp ``` 2. 安装必要的库 我们需要安装 psycopg2 和 django-jsonfield 库。在终端中输入以下命令: ``` pip install psycopg2 django-jsonfield ``` 3. 配置数据库 在 settings.py 文件中,我们需要配置数据库连接。在 DATABASES 字典中添加以下内容: ``` DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql', 'NAME': 'mydatabase', 'USER': 'mydatabaseuser', 'PASSWORD': 'mypassword', 'HOST': 'localhost', 'PORT': '5432', } } ``` 4. 创建模型 在 models.py 文件中,我们需要创建一个模型来存储 JSON 数据。以下是一个示例模型: ``` from django.db import models from jsonfield import JSONField class MyModel(models.Model): data = JSONField() ``` 5. 迁移数据库 在终端中输入以下命令,创建数据库表: ``` python manage.py makemigrations python manage.py migrate ``` 6. 存储 JSON 数据 在视图函数中,我们可以使用以下代码将 JSON 数据存储到数据库中: ``` from myapp.models import MyModel import json def my_view(request): data = {'name': 'John', 'age': 30} json_data = json.dumps(data) my_model = MyModel(data=json_data) my_model.save() ``` 7. 读取 JSON 数据 在视图函数中,我们可以使用以下代码从数据库中读取 JSON 数据: ``` from myapp.models import MyModel import json def my_view(request): my_model = MyModel.objects.first() json_data = my_model.data data = json.loads(json_data) print(data['name']) # 输出 John ``` 这就是将 JSON 数据存储到 PostgreSQL 数据库中的完整过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值