Python Django 循环插入到 MongoDB数据库中

陈占占
• 阅读 1047

二级标题单对单表关联:

开始先循环插入数据到MongoDB中,然后把表1的ID放到表2中,然后就可以通过表2来查看表1了

import random
import pymongo
'''DBRef关联的表'''
from bson.dbref import DBRef
from django.http import HttpResponse
from bson.objectid import ObjectId


def Circular_Insertion(request):
    # 链接mongo
    client = pymongo.MongoClient("127.0.0.1:27017")
    # mongo 数据库名字
    db = client.Chen

    cursor1 = db.zhan1.find({})
    cursor2 = db.zhan2.find({})

    '''循环插入到数据库的表中'''
    # 姓
    first_name = ["赵", "钱", "孙", "李", "周", "吴", "郑", "王", "冯", "陈", "褚", "卫", "蒋", "沈", "韩", "杨", "朱", "秦", "尤", "许",
                  "何", "吕", "施", "张"]
    # 循环插入的数量
    for i in range(3):
        first=random.sample(first_name,1)
        # 名  随机一万个字符
        last_names = chr(random.randint(0x4e00, 0x9fbf))
        name=first[0]+last_names
        # 成绩
        score1 = random.randint(0, 100)
        score2 = random.randint(0, 100)
        score3 = random.randint(0, 100)
        # 插入到数据库中的zhan1表中
        db.zhan1.insert_many([{'names': name, 'Subject': {"score1":score1,"score2":score2,"score3":score3,}}])
    # 遍历zhan1表
    for cur in cursor1:
        # 遍历zhan1表中的"_id"
        str1 = (cur["_id"])
        # 打印zhan1表
        print(cur)
        # 循环插入的数量
        for i in range(3):
            # 电话
            phone=('13' + str(random.randrange(4, 10)) + ''.join(str(random.choice(range(10))) for _ in range(8)))
            # 班级
            grade = random.randint(1, 3)
            # 年龄
            age = random.randint(1, 100)
            # 插入到数据库中的zhan2的表
            db.zhan2.insert_many([{'ref':DBRef(collection="zhan1",id=str1),'grades': grade,'ages': age,'phones': phone}])
            break

    print('-'*200)
    # 通过zhan2打印zhan1的信息
    for j in cursor2:
        show = db[j['ref'].collection].find({"_id": ObjectId(j['ref'].id)})
        for pt in show:
            print(pt)
            break
        print(j)
    return HttpResponse("数据插入成功!")

打印的数据:

Python Django 循环插入到 MongoDB数据库中

在mongo的cmd中打印的数据:

Python Django 循环插入到 MongoDB数据库中

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Easter79 Easter79
2年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
Wesley13 Wesley13
2年前
oracle查询表数据并重新插入到本表
oracle查询表数据并重新插入到本表CreateTime2018年5月17日10:30:10Author:Marydon1.情景描述查询表中数据SELECTFROMat_aut
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
ThinkPHP 根据关联数据查询 hasWhere 的使用实例
很多时候,模型关联后需要根据关联的模型做查询。场景:广告表(ad),广告类型表(ad\_type),现在需要筛选出广告类型表中id字段为1且广告表中status为1的列表先看关联的设置部分 publicfunctionadType(){return$thisbelongsTo('A
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这