Django的models模型的具体使用
作者:lemon 发布时间:2022-08-13 07:57:04
model的常用字段
V=models.CharField(max_length=None[, **options])#varchar
V=models.EmailField([max_length=75, **options])#varchar
V=models.URLField([verify_exists=True, max_length=200, **options])#varchar
V=models.FileField(upload_to=None[, max_length=100, **options])#varchar
#upload_to指定保存目录可带格式,
V=models.ImageField(upload_to=None[, height_field=None, width_field=None, max_length=100, **options])
V=models.IPAddressField([**options])#varchar
V=models.FilePathField(path=None[, match=None, recursive=False, max_length=100, **options])#varchar
V=models.SlugField([max_length=50, **options])#varchar,标签,内含索引
V=models.CommaSeparatedIntegerField(max_length=None[, **options])#varchar
V=models.IntegerField([**options])#int
V=models.PositiveIntegerField([**options])#int 正整数
V=models.SmallIntegerField([**options])#smallint
V=models.PositiveSmallIntegerField([**options])#smallint 正整数
V=models.AutoField(**options)#int;在Django代码内是自增
V=models.DecimalField(max_digits=None, decimal_places=None[, **options])#decimal
V=models.FloatField([**options])#real
V=models.BooleanField(**options)#boolean或bit
V=models.NullBooleanField([**options])#bit字段上可以设置上null值
V=models.DateField([auto_now=False, auto_now_add=False, **options])#date
#auto_now最后修改记录的日期;auto_now_add添加记录的日期
V=models.DateTimeField([auto_now=False, auto_now_add=False, **options])#datetime
V=models.TimeField([auto_now=False, auto_now_add=False, **options])#time
V=models.TextField([**options])#text
V=models.XMLField(schema_path=None[, **options])#text
——————————————————————————–
V=models.ForeignKey(othermodel[, **options])#外键,关联其它模型,创建关联索引
V=models.ManyToManyField(othermodel[, **options])#多对多,关联其它模型,创建关联表
V=models.OneToOneField(othermodel[, parent_link=False, **options])#一对一,字段关联表属性
经典情景示例
书籍,作者,出版社之间的关系,这里为了便于演示,我们尽量精简了表中的字段,书籍表具有书名,出版社同出版社表建立一对多的关系[foreign key],一本书可以具有多个作者,又同作者表建立多对多的关系[many-to-many],作者表有名称,年龄,出版社表有出版社名称。
from django.db import models
class Publisher(models.Model):
name = models.CharField(max_length=30)
def __str__(self):
return self.name
class Author(models.Model):
name = models.CharField(max_length=30)
age = models.IntegerField()
def __str__(self):
return self.name
class Book(models.Model):
title = models.CharField(max_length=100)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher,on_delete=models.CASCADE)
def __str__(self):
return self.title
选择对象
获取全体对象
Publisher.objects.all() #获取所有对象
筛选对象
Publisher.objects.filter(name='人们教育出版社') #获取的是一个对象列表
dict = {'name':'lemon','age':18}
Author.objects.filter(**dict) #列表传参的方法
获取单个对象
Publisher.objects.get(name='机械工业出版社') #找不到会报错!!!
对象排序
Author.objects.order_by("name","-age") #可以按照多个字段排序,- 表示逆向排序
连查
Author.objects.filter(name='lemon').order_by('-age')[0]
批量更新
Author.objects.all().update(age='18')
删除对象
Author.objects.filter(name='lemon').delete()
外键和多对多操作
访问外键
Book.objects.get(id=1).publisher #得到书籍的出版社
反向查询
models.Publisher.objects.get(id=1).book_set.all() #反向查询,得到的是一个queryset对象列表
多对多操作
Book.objects.get(id=1).authors.all() #得到queryset对象列表
自定义models方法
class Author(models.Model):
name = models.CharField(max_length=30)
age = models.IntegerField()
def __str__(self):
return self.name
def status(self):
if self.name=='lemon':
return '帅哥'
运行结果:
aa = models.Author.objects.get(id=1)
print(aa.status())
———————————————运行结果——————————————————
帅哥
自定义manager管理器
class AuthorManager(models.Manager):
def name_count(self,str_name):
return self.filter(name__icontains=str_name).count()
class Author(models.Model):
name = models.CharField(max_length=30)
age = models.IntegerField()
def __str__(self):
return self.name
def status(self):
if self.name=='lemon':
return '帅哥'
#一旦定义了新的管理器,默认管理器需要显示声明出来才可以使用
objects = models.Manger() #默认管理器
object=AuthorManager() #新定义管理器
执行结果:
aa = models.Author.object.name_count('lemon')
print(aa) #——————》2
自定义sql语句
class AuthorManager(models.Manager):
def age_stat(self, age_int):
cursor = connection.cursor()
cursor.execute("""
SELECT NAME
FROM app2_author
WHERE age = %s""", [age_int])
#fetchall()返回的是元组的列表
return [row[0] for row in cursor.fetchall()]
class Author(models.Model):
name = models.CharField(max_length=30)
age = models.IntegerField()
# objects =models.Manager()
object=AuthorManager()
def __str__(self):
return self.name
执行结果:
aa = models.Author.object.age_stat(18)
print(aa)
-----------------
['lemon', 'Luouo']
过滤字段发方法
__exact 精确等于 like 'aaa'
__iexact 精确等于 忽略大小写 ilike 'aaa'
__contains 包含 like '%aaa%'
__icontains 包含 忽略大小写 ilike '%aaa%',但是对于sqlite来说,contains的作用效果等同于icontains。
__gt 大于
__gte 大于等于
__lt 小于
__lte 小于等于
__in 存在于一个list范围内
__startswith 以...开头
__istartswith 以...开头 忽略大小写
__endswith 以...结尾
__iendswith 以...结尾,忽略大小写
__range 在...范围内
__year 日期字段的年份
__month 日期字段的月份
__day 日期字段的日
__isnull=True/False
来源:https://segmentfault.com/a/1190000019758612
猜你喜欢
- <!doctype><html><head><title>新闻图片轮换类</title
- 这次主要介绍字符串常用操作方法及例子1.python字符串在python中声明一个字符串,通常有三种方法:在它的两边加上单引号、双引号或者三
- 代码如下:function HTMLEncode(fString) fString=Replace(fString,&q
- 今天跟大家分享下selenium中根据父子、兄弟、相邻节点定位的方法,很多人在实际应用中会遇到想定位的节点无法直接定位,需要通过附近节点来相
- 前言在Python中,enumrate和range都常用于for循环中,enumrate函数用于同时循环列表和元素,而range()函数可以
- 这篇文章详细的介绍了Oracle数据库SQL语句性能调整的基本原则,具体内容请参考下文。一、问题的提出在应用系统开发初期,由于开发数据库数据
- 楔子上一篇文章我们探讨了 GIL 的原理,以及如何释放 GIL 实现并行,做法是将函数声明为 nogil,然后使用 with nogil 上
- 前言本文介绍在 pandas 中如何读取数据行列的方法。数据由行和列组成,在数据库中,一般行被称作记录 (record),列被称作字段 (f
- 服务端监听端口 listen()方法:net.listen({监听类型},{监听的ip和端口})(conn, err){}返回值:conn是
- Chrome的CSS支持程度 :Green / √ means current support.Orange / Δ means that
- 本文实例讲述了Python Scrapy框架:通用爬虫之CrawlSpider用法。分享给大家供大家参考,具体如下:步骤01: 创建爬虫项目
- 本文实例讲述了Python实现简单截取中文字符串的方法。分享给大家供大家参考。具体如下:web应用难免会截取字符串的需求,Python中截取
- 目录1.需求2.代码实现总结1.需求发现项目本地所有带别名的URL,组成一个有序字典,方便后续调用;定向排除部分URL,如Django自带的
- 问题描述使用pandas库的read_excel()方法读取外部excel文件报错, 截图如下好像是缺少了什么方法的样子问题分析分析个啥,
- 第1题:Python里面如何实现tuple和list的转换?函数tuple(seq)可以把所有可迭代的(iterable)序列转换成一个tu
- 在Python编程中,导入文本文件是常见的操作之一。Python提供了丰富的标准库,使得文件操作变得十分简单。那么,如何在Python中导入
- 换脸!这段时间,deepfakes搞得火热,比方说把《射雕英雄传》里的朱茵换成了杨幂,看下面的图!毫无违和感!其实早在之前,基于AI换脸的技
- 在分析python的参数传递是如何进行的之前,我们需要先来了解一下,python变量和赋值的基本原理,这样有助于我们更好的理解参数传递。py
- <%'asp事务处理。'测试数据库为sql server,服务器为本机,数据库名为test,表名为a,两个字段id(i
- 简介Closure所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。闭