龙空技术网

Django学习_简易博客(二)

zhongxin钟 234

前言:

当前你们对“django在admin添加外键数据”都比较注意,各位老铁们都需要知道一些“django在admin添加外键数据”的相关资讯。那么小编也在网摘上搜集了一些有关“django在admin添加外键数据””的相关知识,希望咱们能喜欢,兄弟们快快来学习一下吧!

项目:基于某些设置项的Django安装结果;

应用程序:模型,视图,模版,URL的组合

欢迎关注我的公众号:zx94_11

应用程序和框架进行交互,并提供特定的功能,并可以在不同的项目中加以复用。

创建项目

$ python manage.py startapp blog

新建项目blog

设计数据方案

from django.db import modelsfrom django.utils import timezonefrom django.contrib.auth.models import Userclass Post(models.Model): # 帖子状态选项,后面会用到 STATUS_CHOICES = ( ('draft', 'Draft'), ('published', 'Published'), ) # 帖子标题,CharField数据库中会转换为VARCHAR title = models.CharField(max_length=250) # 简短的标记 # slug指有效URL的一部分,能使URL更加清晰易懂。 # 比如有这样一篇文章,标题是"13岁的孩子", # 它的 URL 地址是"/posts/13-sui-de-hai-zi",后面这一部分便是 slug。 # 通过它构建有较好外观,SEO友好的URL slug = models.SlugField(max_length=250, unique_for_date='publish') # 作者,外键 # 一个作者可以有多篇帖子 # 当作者被删除,相应的帖子也会被删除 author = models.ForeignKey(User, on_delete=models.CASCADE, related_name='blog_posts') # 正文,TextField会转换为TEXT body = models.TextField() # 发布日期,timezone.now:以时区格式返回当前的时间 publish = models.DateTimeField(default=timezone.now) # 创建时间,auto_now_add:当「创建」某个对象时,日期将被自动保存 created = models.DateTimeField(auto_now_add=True) # 最后一次更新时间,auto_now:当「保存」某对象时候,日期将被自动保存 update = models.DateTimeField(auto_now=True) # 帖子的状态,choices选择STATUS_CHOICES元祖中的某一个状态 status = models.CharField(max_length=10, choices=STATUS_CHOICES, default='draft') class Meta: # 对publish字段进行排列,由「-」确定为降序 ordering = ('-publish',) def __str__(self): # 增加人们可读对象表达方式 return self.title

激活应用程序

INSTALLED_APPS中添加'blog.apps.BlogConfig'

INSTALLED_APPS = [ 'django.contrib.admin', # 管理站点 'django.contrib.auth', # 验证框架 'django.contrib.contenttypes', # 处理内容类型的框 'django.contrib.sessions', # 会话框架 'django.contrib.messages', # 消息机制框架 'django.contrib.staticfiles', # 管理静态文件的框架 'blog.apps.BlogConfig',]

数据库迁移

$ python manage.py makemigrations blog

数据库迁移

查看数据迁移SQL输出结果

$ python manage.py sqlmigrate blog 0001CREATE TABLE "blog_post" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "title" varchar(250) NOT NULL, "slug" varchar(250) NOT NULL, "body" text NOT NULL, "publish" datetime NOT NULL, "created" datetime NOT NULL, "update" datetime NOT NULL, "status" varchar(10) NOT NULL, "author_id" integer NOT NULL REFERENCES "auth_user" ("id") DEFERRABLE INITIALLY DEFERRED);CREATE INDEX "blog_post_slug_b95473f2" ON "blog_post" ("slug");CREATE INDEX "blog_post_author_id_dd7a8485" ON "blog_post" ("author_id");COMMIT;

数据库迁移语句

数据同步

$ python manage.py migrate

数据同步

创建超级用户

$ python manage.py createsuperuser

创建超级用户

Django管理站点

使用刚创建的账户进入

admin

管理站点中添加模型

在blog/admin.py文件下添加

from django.contrib import adminfrom .models import Postadmin.site.register(Post)

添加模型

新建一条博客

普通展示

定制admin页面的显示方式

from django.contrib import adminfrom .models import Post# admin页面普通展示# admin.site.register(Post)# admin页面定制展示@admin.register(Post)class PostAdmin(admin.ModelAdmin): list_display = ('title', 'slug', 'author', 'publish', 'status')

定制展示

增加定制内容

右侧过滤栏list_filter搜索栏search_fields导航连接date_hierarchy排序ordering

@admin.register(Post)class PostAdmin(admin.ModelAdmin): list_display = ('title', 'slug', 'author', 'publish', 'status') list_filter = ('status', 'created', 'publish', 'author') search_fields = ('title', 'body') prepopulated_fields = {'slug': ('title',)} raw_id_fields = ('author',) date_hierarchy = 'publish' ordering = ('status', 'publish')

增加定制内容

标签: #django在admin添加外键数据