8.Django模型类例子

本文详细介绍了如何使用Django的ORM进行数据库操作,包括创建模型、生成数据库表、注册模型到管理界面的过程。通过实例讲解了作者、作者详情、出版商及书籍之间的关系建立,适合初学者学习。

 

 

这里定义4个模型

作者:一个作者有姓名

作者详情:包括性别,email,出生日期,

出版商:名称,地址,城市,省,国家,网站

书籍:名称,日期

 

分析:

作者详情和作者一对一的关系

一本书可以有多个作者,一个作者可以写多本书,作者和书籍多对多关系

一本书只由一个出版商出版,一个出版商可以出版多本书,所以出版商和是一对多

 

步骤:

1.编写models.py文件:

from django.db import models

# Create your models here.
class Publisher(models.Model):
name = models.CharField(max_length=30, verbose_name="名称")
address = models.CharField("地址", max_length=50)
city = models.CharField("城市", max_length=60)
state_province = models.CharField(max_length=30)
country = models.CharField(max_length=50)
website = models.URLField()

class Meta:
verbose_name = '出版商'
verbose_name_plural = verbose_name

def __str__(self):
return self.name

class Author(models.Model):
name = models.CharField(max_length=30)

class AuthorDetail(models.Model):
sex = models.BooleanField(max_length=1, choices=((0, '男'),(1, '女'),))
email = models.EmailField()
address = models.CharField(max_length=50)
birthday = models.DateField()
author = models.OneToOneField(Author)

class Book(models.Model):
title = models.CharField(max_length=100)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField()

2.生成数据库表  

  manage.py makemigrations  (创建脚本)

  manage.py migrate  (执行脚本)

  

3.在hello_django\hello\admin.py加入管理

from django.contrib import admin
from hello.models import *

# Register your models here.
admin.site.register(Author)
admin.site.register(AuthorDetail)
admin.site.register(Publisher)
admin.site.register(Book)

4.在localhost:8000/admin中查看

这里表明中“出版商”为中文形式,是因为Meta起的作用,点add进去下一个页面

这里的几个中文是因为verbose_name起的作用。如果在上个页面直接点击“出版商”到展示表内容界面

这里能够显示中文是因为__str__()函数的作用

转载于:https://www.cnblogs.com/413xiaol/p/6501832.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值