Python的web框架Django的ORM数据库操作分析
admin
2023-06-29 03:42:27
0

1.建表
首先引用下,可model设定的各种字段类型
在model中建立一个表
from django.db import models

Create your models here.

class Person(models.Model):
#定义一个用户名字段,不能重复
username = models.CharField(max_length=10,unique=True)
password = models.CharField(max_length=10)
#默认值设定1
age = models.IntegerField()
#False 代表男 True 代表女 女为1 男为0
sex = models.BooleanField(default=False)
#可通过指定属性,来设定生成的列名,但在使用类中还是p_des
p_des = models.CharField(max_length=100,db_column='des')
create_date = models.DateTimeField(auto_now=True)
class Meta:
#指定生成表名,不指定默认生成格式为APP+类名
db_table = 'user'
python manage.py makemigrations
python manage.py migrate
通过代码随机生成些数据,这里有个小坑,也许会碰到=。=
def addUser(request):
for i in range(5):
person = Person()
num = random.randrange(100)
person.username = 'sola%d' % num
person.password = 'pass%d' % num
person.age = num
person.sex = num % 2
person.save()
return HttpResponse("success")
2.条件查询
可用过filter与exclude来链式查询。
def getUser(request):
#可以通过filter来查询(满足),可以继续链式多个条件。
#users = Person.objects.filter(usernamecontains="5").filter(usernamecontains=3)
#也可以用通过exclude(不满足),来查询
users = Person.objects.exclude(usernamecontains="5").filter(usernamecontains="9")
for user in users:
print(user.username)
print(user.create_date)
return HttpResponse("success")
3.另一种添加方法 
def addUserTwo(request):
user = Person.objects.create(username='rui~',password='rui!',age=18)
user.save()
return HttpResponse("success")
4.排序
def getUser(request):
#直接加入order_by即可根据字段排序,默认是正序,前面加减号为倒叙
users = Person.objects.filter(agein=['73','34','84']).order_by("-username")
for user in users:
print(user.username)
print(user.create_date)
return HttpResponse("success")
5.将数据转成字典(转成Map)
def getUser(request):
#values可以直接把结果转换成字典,字典可通过工具直接转成JSON
users = Person.objects.filter(age
in=['63','50','36','11']).values()
for user in users:
print(user.username)
print(user.create_date)
print(user.sex)
return HttpResponse("success")
6.二次查询(查询结果再次查询)
def getUser(request):
users = Person.objects.filter(age__in=['63','50','36','11'])
#可以再一次进行查询
users = users.filter(age='50')
for user in users:
print(user.username)
print(user.create_date)
print(user.sex)
return HttpResponse("success")
7.切片查询
def getUser(request):
#切片查询,从第四条开始,到第五条,不能有负数
users = Person.objects.all()[3:5]
for user in users:
print(user.username)
print(user.create_date)
print(user.sex)
return HttpResponse("success")
8.忽略大小写查询
查询前加入i即可
9.更改时间区域设定 
默认Django有一套自定义的时区,与一般的数据库不匹配,会造成查询不准确,需要去setting中关闭它
#默认是True,改为False即可
USE_TZ = False
10.聚合函数
def getUser(request):
#聚合函数,Avg平均,Count数量,Max最大,Min最小,Sum求和;参数填入字段
avgNum = Person.objects.aggregate(Avg("age"))
print(avgNum)
return HttpResponse("success")
11.某一条字段进行对比
def getUser(request):
#一条数据中某字段进行对比,可进行大小等于,包含等
#users = Person.objects.filter(age=F("id"))
#也可以这么写,age 大于 id+1
users = Person.objects.filter(agegt=F("id")+1)
function(){ //点值计算器http://www.fx61.com/dotpoint.html
print(users.values())
return HttpResponse("success")
12.逻辑运算符的查询写法
def getUser(request):
users = Person.objects.filter(Q(age
gt=90) & Q(age__lt=100))
print(users.values())
return HttpResponse("success")
13.封装某些默认查询条件
因为查询方法是通过Django在model中自动生成查询objectsManager,我们可以建立一个类继承于Manager,并重写他的查询方法,再给Model类中赋予对象给objects参数,再通过调用objects参数进行查询,就会过滤想默认过滤的条件。
model
#歌曲类管理
class SongManager(models.Manager):
def get_queryset(self):
return super(SongManager,self).get_queryset().filter(is_deleter=1)
#继承歌曲管理类
class Song(models.Model):
name = models.CharField(max_length=50)

length = models.CharField(max_length=10)
is_deleter = models.IntegerField(max_length=1,default=0)
singer = models.CharField(max_length=30) 
objects = SongManager()

views
def getSong(request):
songs = Song.objects.all()
for song in songs:
print(song.name)
return HttpResponse("success")
原文链接:blog.csdn.net/jiulanhao/article/details/103027355

相关内容

热门资讯

解放军少将质问日方:有没有资格... 【环球时报-环球网报道 记者 郭媛丹 苏雅瑄】 “殷鉴不远,今天的世界又处在新的十字路口,我们必须警...
《给阿嬷的情书》导演被网友二创... 《给阿嬷的情书》这段解读直接破防!网友二创还原木生守桥的画面,把邮差落水,弄丢写有真相的讣告信件,解...
伊朗最高领袖顾问批特朗普背弃外... 据凤凰卫视报道,美伊谈判前景不明,伊朗最高领袖顾问雷扎伊5月30日指责美国总统特朗普第三次背弃外交原...
免去南开大学陈某院长、中山大学... 刚刚,南开大学和中山大学发布情况通报。南开大学:免去陈某院长职务南开大学通报中指出,论文第一作者郑某...
绿色算力全栈AI平台在呼和浩特...   新华社呼和浩特5月30日电(记者侯维轶)30日,绿色算力全栈AI平台——内蒙古词元交易平台在内蒙...
北京太空智算研究院在北京亦庄成... 红星资本局5月30日消息,近日,北京太空智算研究院在北京经济技术开发区(简称“北京经开区”,又称“北...
第二届西部医学科技创新学术大会... 封面新闻记者 邱添 2026年5月30日,在第十个全国科技工作者日来临之际,一场汇聚医学前沿智慧与创...
地博光电取得存储自动化料库专利... 国家知识产权局信息显示,昆山地博光电材料有限公司取得一项名为“一种存储自动化料库”的专利,授权公告号...
香港政务司司长谈黎家盈:香港由... 据凤凰卫视报道,首位来自香港的载荷专家黎家盈早前随神舟二十三号载人飞船升空。香港政务司司长陈国基表示...
亚美尼亚大选在即,俄方突然召回... 【文/观察者网 阮佳琪】当地时间周五(5月29日),在哈萨克斯坦首都阿斯塔纳,亚美尼亚由副总理格里戈...