笔记6-django模型

本文档详细介绍了如何使用Django创建项目和应用程序,定义模型并生成数据库表,以及如何显示图书信息。从创建项目、配置INSTALLED_APPS、启动服务,到设计数据表、执行迁移,再到编写视图函数、配置URL,最后实现数据在网页上的展示。同时,还提及了抽象函数的使用和过滤器的概念。
摘要由CSDN通过智能技术生成

创建一个 Django 项目与一个应用程序

django-admin startproject webtest 
cd webtest 
python manage.py startapp book 

在生成的webtest/webtest/init.py文件下添加

import pymysql 
pymysql.install_as_MySQLdb()

打开 settings.py 文件,修改 INSTALLED_APPS 以完成对应用的配置

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'book'
]

创建一个数据库,数据库protest必须先存在才能使用

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'protest', # 数据库名
        'HOST':'localhost',
        'USER':'root',
        'PASSWORD':'123456789',
        'PORT':3306
    }
}

启动服务 如果不加IP和端口号,url默认127.0.0.1 端口号为8000

pythonmanage.pyrunserver 

,打开浏览器并在地址栏输入 http://127.0.0.1:8000,显示如下效果则表示成功

定义与创建模型

设计并生成数据表
生成的数据表名称默认为 应用名_类名, 如果想修改名称可在类的下面在建立一个类Meta, 执行verbose_name_plural=“表名” 对表名进行修改

from django.db import models
# 自定义类:图书类
class BookInfo(models.Model):
    bname = models.CharField("书名",max_length=20)
    bpub_date = models.DateField("出版日期")
    bpage = models.IntegerField(verbose_name='总页数',default=0)
    is_delete=models.BooleanField(default=False)
    # 定义str
    def __str__(self):
        return self.bname + "," + str(self.bpub_date) + "," + str(self.bpage)
  # class Meta:
       # 2.修改表名
       # verbose_name_plural = "图书"

# 自定义作者类
class AuthorInfo(models.Model):
    aname = models.CharField("姓名",max_length=10)
    agender = models.BooleanField(verbose_name='性别', default=True)
    acontent = models.CharField(verbose_name='简介', max_length=200)
    abook = models.ForeignKey('BookInfo', verbose_name='相关书籍')
    is_delete=models.BooleanField(default=False)
       # # 定义str
    def __str__(self):
        return self.aname

生成数据表,则需要先执行如下命令用于生成迁移文件和执行迁移文件

python manage.py makemigrations
pythonmanage.pymigrate

添加数据,可就直接到MySQL下直接添加数据,也可在python脚本下添加数据,以下是直接在MySQL下添加数据的代码
向book_bookinfo添加数据

insert into book_bookinfo(bname,bpub_date,bpage,is_delete) values ("Python 从入门到精通","2017-6-3",431,0), 
("Python 经典案例 100 例","2018-9-7",154,0), 
("疯狂的程序员","2007-3-4",310,0);

向book_authorinfo添加数据

insert into book_authorinfo(aname,agender,acontent,is_delete,abook_id)
values ("李军",1,"实战开发",0,1), 
("叶维忠",1,"大学教授",0,1), 
("方哥",1,"实战开发",0,2), 
("叶子美",0,"大学讲师",0,2), 
("绝影",1,"博客博主",0,3);

图书信息显示

通过访问“http://127.0.0.1:8000/index”展示出数据。首先,找到 webtest/ webtest 目录下的 urls.py 文件,如下内容:

from django.conf.urls import url,include 
from django.contrib import admin
urlpatterns=[ 
	url(r'^admin/',admin.site.urls),
	url(r"^",include("book.urls")) ] 

创建 templates 目录,并创建 templates/mybook/index.html 文件
此时需要在settings.py文件下修改配置路径

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR,"templates")],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

在 webtest/book/views.py 文件下编写视图函数代码

from django.shortcuts import render
from .models import BookInfo
# Create your views here.
def index(request):
#1.获取所有图书信息
    books = BookInfo.objects.all()
    # data=[1,2,3,4,5]
# #2.获取模板文件
    return render(request,"book/index.html",{"books":books})

编写视图函数完成后,配置主路由和子路由url
子路由: book/urls.py 文件进行 url 配置(自己创建)

from django.conf.urls import url
from .views import *
urlpatterns=[
    url(r"^index/",index),# 显示图书信息
]

主路由配置:在webtest/webtest/urls.py文件下

from django.contrib import admin
from django.conf.urls import url,include
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^book/', include("book.urls")),
]

最后,来把上述数据库中的关于图书的信息显示在网页中

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>hello world</h1>
<ul>
{%for book in books%}
    <li>{{book.bname}}</li>
    {% endfor %}
</ul>
</body>
</ht

完成以上步骤后在在页面上输入相应url即可展示数据.
抽象函数: 对于表格的创建和每一次修改都应该有时间记录,因此可以使用抽象函数创建一个新的数据表来记录这些时间,创建一个新的目录db下创建一个新py文件
注意:不能直接运行直接使用

from django.db import models

class BaseModel(models.Model):
    # 添加时间 修改时间 is_delete
    id_delete=models.BooleanField(verbose_name="是否可用",default=False)
    create_time = models.DateTimeField(verbose_name="添加时间",auto_now=True)
    update_time = models.DateTimeField(verbose_name="修改时间",auto_now_add=True)
    class Meta:
        abstract=True

添加一个视图函数和抽象函数搭配使用

def add(request):
    b1=BookInfo()
    b1.bname="简爱"
    b1.bpub_date='2001-1-1'
    b1.bkind="小说类"
    b1.save()
    return HttpResponse("hello add")

创建抽象函数后,可在models文件中导入使用,数据类直接继承抽象函数

class BookInfo(BaseModel):

过滤器: 可根据条件过滤掉不需要显示的内容

books = BookInfo.objects.filter(is_delect=0)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值