创建django项目和初始配置我就不再演示了,直接开始吧
一、定义模型
在这里我们用上次的数据库来进行演示吧
由于python3.6的老是爆红,影响美观,所以我先更换成python3.8+django1.8.2的虚拟环境吧
这下运行就没问题了
模型models.py字段有这些
因为这里除了id,其他字段皆用的char类型,但我们应知道还有其他字段类型
1. AutoField:自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属
性
2. BooleanField:布尔字段,值为True或False
3. NullBooleanField:支持Null、True、False三种值
4. CharField(max_length=字符长度):字符串,必选 参数max_length表示最大字符个数
5. TextField:大文本字段,一般超过4000个字符时使用
6. IntegerField:整数
7. DecimalField(max_digits=None, decimal_places=None):十进制浮点数参数max_digits表示总位数,参数
decimal_places表示小数位数
8. FloatField:浮点数
9. DateField[auto_now=False, auto_now_add=False]):日期 参数auto_now表示每次保存对象时,自动设置该
字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为false,参数auto_now_add表示
当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为false,参数
auto_now_add和auto_now是相互排斥的,组合将会发生错误
10. TimeField:时间,参数同DateField
11. DateTimeField:日期时间,参数同DateField
12. FileField:上传文件字段
13. ImageField:继承于FileField,对上传的内容进行校验,确保是有效的图片
其中,关系型数据库的关系包括三种类型:
ForeignKey:一对多,将字段定义在多的一端中
ManyToManyField:多对多,将字段定义在两端中
OneToOneField:一对一,将字段定义在任意一端中
二、模型类成员
1.模型类实例方法
save():将模型对象保存到数据表中
delete():将模型对象从数据表中删除
views.py
from django.http import HttpResponse
from django.shortcuts import render
from .models import Zgddxs
def index(request):
return HttpResponse("Hello world!")
def save_name(request,name):
print("-------",name)
t = Zgddxs() # 创建模型实例对象
t.name = name #将数据赋值给实例对象属性
t.save() #将模型对象保存在数据库中
return HttpResponse('ok')
def delete_name(request,name):
title = Zgddxs.objects.get(name=name) # 查询name为参数name数据
title.delete() # 删除
return HttpResponse('%s标题被删除'%name)
主路由
url(r'', include('myapp.urls')),
myapp/urls.py
from django.conf.urls import url from .views import * urlpatterns = [ url(r'^$', index), url(r'save_name/(\w+)/', save_name), url(r'delete_name/(\w+)/', delete_name), ]
运行结果:
访问127.0.0.1:8000/save_name/人鱼/
观察数据库发现已经保存进来
访问127.0.0.1:8000/delete_name/人鱼/
发现数据库中已经删除
2.模型类的属性
添加图书
models.py
from django.db import models
class ZgddxsManage(models.Manager):
def get_queryset(self):
# return super(PostManage,self).get_queryset() #调用父类的方法
# 只返回没有被逻辑删除的文章
return super(ZgddxsManage,self).get_queryset().filter(is_delete=False)
def create(self, name, author, src, detail, herf, price, cbs, cb_time):
p = self.model() # 创建模型类对象self.model可以获得模型类
p.name = name
p.author = author
p.src = src
p.detail = detail
p.herf = herf
p.price = price
p.cbs = cbs
p.cb_time = cb_time
return p # 返回模型对象
class Zgddxs(models.Model):
id = models.AutoField(primary_key=True)
name=models.CharField("标题", max_length=255)
author=models.CharField("作者", max_length=255)
src=models.CharField("图片",max_length=255)
detail=models.CharField("详情页", max_length=255)
herf=models.CharField("详情页地址",max_length=255)
price=models.CharField("价格", max_length=10)
cbs=models.CharField("出版社", max_length=255)
cb_time=models.CharField("出版时间", max_length=255)
def __str__(self):
return self.name
class Meta:
verbose_name_plural = "中国当代小说"
# todo:自定义管理器
my_objects = ZgddxsManage()
views.py
def add_post(request):
'''在视图中定义文章字段值'''
name = 'python 高级快速入门'
author = 'pingping'
src = '没有嘿嘿'
detail = 'python 大法好'
herf = '也没有嘿嘿'
price = '20.5'
cbs = '平平出版社'
cb_time = '2024-12-13'
# 调用管理器方法
p = Zgddxs.my_objects.create(name, author, src, detail, herf, price, cbs, cb_time)
p.save()
return HttpResponse('添加成功')
配置路由:
url(r'add/', add_post),
启动项目访问127.0.0.1:8000/add/
查看数据库