python之路_django ORM相关补充

Posted 骑猪走秀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python之路_django ORM相关补充相关的知识,希望对你有一定的参考价值。

一、非django项目文件执行ORM

  在不启动django项目的情况下,我们是否可以进行ORM操作呢?当然不行。因为所有的ORM操作都必须是要连接数据库的。但是我们有这样的一个需求:想在一个文件中执行ORM。该如何实现呢?参考如下实例:

import os
import sys
import django
sys.path.append(rC:\Users\Administrator\PycharmProjects\s6day109)    #将当前djang项目路径添加到环境

os.chdir(rC:\Users\Administrator\PycharmProjects\s6day109)
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "s6day109.settings")
django.setup()                                                         #启动django

from crm import models

v = models.Customer.objects.all()
print(v)

二、django中ORM的Q介绍

  Q方法主要为了解决复杂条件查询的情况。

方式一:

Q(nid__gt=10)                                            #nid>10
Q(nid=8) | Q(nid__gt=10)                                 #nid=8或者nid>10
Q(nid=8) | Q(nid__gt=10) &Q(caption="root")              #nid=8或者nid>10且caption="root"

# 应用示例:(非Q条件放在Q条件后面,为且的关系。如status=2)
customer_list = models.Customer.objects.filter(Q(recv_date__lt=)|Q(last_consult_date__lt=no_follow),status=2)

方式二:

q1=Q()
q1.connector = "OR"
q1.children.append((id,1))
q1.children.append((id__gt,3))
#q1中要求id=1或者id>3,例:models.UserInfo.objects.filter(q1)

q2=Q()
q2.connector = "OR"
q2.children.append((title__contain,""))
q2.children.append((nid,2))
#q2中要求title字段包含“高”或者nid=2,例:models.UserInfo.objects.filter(q2)

con=Q()
con.add(q1,"AND")
con.add(q2,"AND")
#con要求q1和q2的结果为且的关系,例:models.UserInfo.objects.filter(con)

 

以上是关于python之路_django ORM相关补充的主要内容,如果未能解决你的问题,请参考以下文章

django-课程目录

Python全栈之路--Django ORM详解

python-django框架-orm相关继续&ORM的增删改查操作_20191110

Python之路第十七篇:Django进阶篇

Python之路第十七篇:Django进阶篇

Python菜鸟之路:Django 路由模板ORM