Django 模型层 orm 多表操作

表关系总结:

跟SQL的 关系 一样。注意在一对多中,应该把外键定义在多的当中。

  • 一对一:models.OneToOneField(to='表名', to_field='字段名', on_delete=models.CASCADE)
    定义在哪个类中都可以
    例如:员工基本信息类-员工详细信息类. 员工工号
  • 一对多:models.ForeignKey(to='表名', to_field='字段名', on_delete=models.CASCADE) 定义在多的类中。
    例如:新闻类-新闻类型类 体育新闻 国际新闻
  • 多对多:models.ManyToManyField() 定义在哪个类中都可以。
    例如:书籍类-作者类

应用场景

db_column='name'
primary_key=True
verbose_name='别名或者注释'
unique=True
null=True,blank=True
db_index=True 给表单建立索引
help_text='' 表单中显示帮助信息

一对一

  • 创建表
from django.db import models


# Create your models here.
class Account(models.Model):  # 账户信息
    id = models.AutoField(primary_key=True, verbose_name=u'用户id')
    username = models.CharField(max_length=20, null=True, blank=True, verbose_name=u'用户名')
    password = models.CharField(max_length=40, null=True, blank=True, verbose_name=u'密码')
    register_date = models.DateField(auto_now_add=True, null=True, blank=True, verbose_name=u'注册时间')

    class Meta():
        # 指定表名,如果不指定则会将类名默认成表表名,并在前面加上app都名称
        db_table = 'Account'


# 一对一关系,每个账户都会有一个用户详情
class UserInfo(models.Model):  # 用户详细信息
    id = models.AutoField(primary_key=True)  # 用户id
    id_card = models.IntegerField()  # 身份证号
    addr = models.CharField(max_length=32)  # 家庭地址
    user = models.OneToOneField(to="Account", to_field="id", on_delete=models.CASCADE)
    # user作为外键,会被Django自动添加 "_id"来创建数据库中的列名,如果写成user_id ,则会在数据库展示user_id_id
    # 对于Django2.0版本,一对多(models.ForeignKey)和一对一(models.OneToOneField)要加上 on_delete=models.CASCADE 这个属性
    # on_delete=models.CASCADE 当Account中的一条数据被删除的时候,与之对应的UserInfo数据也会被删除

python manage.py makemigrations  #在app01/migrations下会生成数据迁移脚本
python manage.py migrate  #应用到db生成数据表
  • 增、删、改、查
from django.http import HttpResponse
from Applications.models import *
import datetime

# 获取当前年月日
yesterday = datetime.date.today() + datetime.timedelta(-1)


def add_user(request):
    # 添加一条数据
    # 先在主表中创建一条记录,并实例化对象
    detail_obj = Account.objects.create(username='15607241351', password='321321', register_date=yesterday)
    # 在详情表中添加一条记录,并将上面的实力赋值给外键
    UserInfo.objects.create(id_card='421281199512111717', addr='上海市.', user=detail_obj)

    return HttpResponse("增加数据成功")


def sel_user(request):
    #  查询 username 为15607241351 的 用户名与地址
    user_details = Account.objects.filter(username='15607241351').first()
    user_name = user_details.username  # 用户名
    user_addr = user_details.userinfo.addr  # 用户地址
    return HttpResponse("查询数据成功 username:%s,addr:%s" % (user_name, user_addr))


def update_user(request):
    # 将 username=15607241351 的 username 改为 15607241355
    Account.objects.filter(username='15607241351').update(username='15607241355')
    return HttpResponse("更新数据成功")


def del_user(request):
    # 删除username 为 15607241355的数据
    Account.objects.filter(username='15607241355').delete()
    return HttpResponse("删除数据成功")


一对多

  • 建表
# 这里用一个简单的博客举例,每篇文章会有一个或多个评论
class Blog(models.Model):
    '''
    博客
    '''
    id = models.AutoField(primary_key=True)
    title = models.CharField(max_length=100, verbose_name=u'标题')
    content = models.TextField(default='', verbose_name=u'正文')
    create_time = models.DateTimeField(verbose_name=u'创建时间')


class Comment(models.Model):
    '''
    评论 一个博客对应多条评论
    '''
    user_name = models.CharField(max_length=20, verbose_name=u'姓名')
    content = models.TextField(verbose_name=u'内容')
    create_time = models.DateTimeField(auto_now_add=True, verbose_name=u'创建时间')
    Blog = models.ForeignKey(to='Blog', to_field='id', on_delete=models.CASCADE, verbose_name=u'博客')

  • 增、删、改、查
# 一对多

def add_blog(request):
    # 增加文章
    blog_obj = Blog.objects.create(title='Django 一对多增加博客,并且增加评论', content='这是内容', create_time=yesterday)
    # 在文章下增加评论
    Comment.objects.create(user_name='别动我名字', content='文章很棒哦', Blog=blog_obj)

    Blog.objects.create(title='Django 一对多 增加博客,不增加评论', content='这是内容', create_time=yesterday)
    return HttpResponse('add_Blog~~')


def update_blog(request):
    # 更新文章
    Blog.objects.filter(title='Django 一对多增加博客,并且增加评论').update(title=' 更新 Django 一对多增加博客,并且增加评论')

    return HttpResponse('update_Blog')


def sel_blog(request):
    # 查询文章
    blog_content=Blog.objects.filter(title=' 更新 Django 一对多增加博客,并且增加评论')[0].content
    return HttpResponse('sel_Blog~~【 更新 Django 一对多增加博客,并且增加评论】的内容为: %s' % blog_content)


def del_blog(request):
    # 删除文章的时候会自动删除对应的评论
    Blog.objects.filter(title=' 更新 Django 一对多增加博客,并且增加评论').delete()
    return HttpResponse('del_Blog')


多对对

  • 建表
#  多对多  书籍与作者 (每本书籍都会有多个作者,每个作者也会写多本书)
class Author(models.Model):
    author_name = models.CharField(max_length=16, verbose_name='作者名称')
    age = models.IntegerField(verbose_name='年龄')


class Book(models.Model):
    book_name = models.CharField(max_length=16, verbose_name='书名')
    publish = models.CharField(max_length=16, verbose_name='出版社')
    pub_data = models.DateField(auto_now_add=True, verbose_name='出版时间')
    authors = models.ManyToManyField('Author')
    # 书籍表关联作者表,ManyToManyField 会自动创建第三张表,记录也无法操作

  • 增、删、改、查


def add_author(request):
    # 先创建作者信息
    # Author.objects.create(author_name='别动我名字呀', age=24)
    # 创建作者信息
    # book_obj=Book.objects.create(book_name='Django 开发', publish='上海出版社')
    # 查询指定作者
    author_obj = Author.objects.filter(author_name='别动我名字呀')
    # 获取指定书 将作者赋值给书籍对  authors 字段
    Book.objects.get(book_name='Django 开发').authors.add(*author_obj)
    # 现在在第三张表(关联表)内可查看到数据到关联关系

    return HttpResponse('add_author')


def sel_author(request):
    # 查询Django 是哪个作者写的:在作者表中过滤 book实例 book_name 字段等于'Django 开发'的记录
    # 这里是querySet 所以添加下标,正常应该循环遍历
    # Django提供了一种使用双下划线__的查询语法
    book_obj=Author.objects.filter(book__book_name='Django 开发')[0].author_name
    print(book_obj)

    # 查询 别动我名字呀 写的所有书籍名称
    book_name=Book.objects.filter(authors__author_name='别动我名字呀')[0].book_name
    print(book_name)
    return HttpResponse('sel_author')


def update_author(request):
    # 将 别动我名字呀 写的数据出版时间跟新为当前时间
    Book.objects.filter(authors__author_name='别动我名字呀').update(pub_data=yesterday)
    return HttpResponse('update_author')

def del_author(request):
    # 删除  别动我名字呀  写的书籍
    Book.objects.filter(authors__author_name='别动我名字呀').delete()
    return HttpResponse('del_author')

Django 2.0 官方中文文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 一、前期概要 1.1 名词解释 关系:事物之间相互作用、相互联系的状态。 关联:名词:表示对象(数据库表)之间的关...
    唯老阅读 920评论 0 4
  • 文章内容大部分参考官方文档,以作者理解叙述Django中模型是你的数据的唯一的,确定的信息源.它包含你所存储数据所...
    da_yu阅读 2,047评论 0 3
  • Django 模型定义 Django 模型是使用 Python 代码对数据库中数据的描述,是数据的结构,包含数据的...
    Am3阅读 1,309评论 0 2
  • Django 准备 “虚拟环境为什么需要虚拟环境:到目前位置,我们所有的第三方包安装都是直接通过 pip inst...
    33jubi阅读 1,315评论 0 5
  • 因为入了Reece&Steve两位“神编剧兼主演”的坑,4月的大部分时间都在刷这二位的剧,强烈推荐这两位的代表性剧...
    浅水地阅读 2,111评论 0 2