创建一个 Django 项目及应用 django-admin startproject orm cd orm python manage.py startapp app01 在 models.py...上创建数据库结构 from django.db import models class Publisher(models.Model): name = models.CharField(max_length...#CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符数. (2) IntegerField #用于保存一个整数....缺省为真 (5) primary_key:设置主键,如果没有设置django创建表时会自动加上: id = meta.AutoField('ID', primary_key=True)...非有效产生 django.core.validators.ValidationError 错误 (9) db_column,db_index :如果为真将为此字段创建索引 (10)choices:一个用来选择值的
数据库存储的数据其实就是表格的形式,例如存储博客文章的数据库表长这个样子: 文章 id 标题 正文 发表时间 分类 标签 1 title 1 text 1 2016-12-23 Django Django...一般来说这时候我们应该先去学习数据库创建表格的语法,再回来写我们的 Django 博客代码了。但是 Django 告诉我们不用这么麻烦,它已经帮我们做了一些事情。...Django 把那一套数据库的语法转换成了 Python 的语法形式,我们只要写 Python 代码就可以了,Django 会把 Python 代码翻译成对应的数据库操作语言。...这样,Django 就可以把这个类翻译成数据库的操作语言,在数据库里创建一个名为 category 的表格,这个表格的一个列名为 name。还有一个列 id,Django 则会自动创建。...这两个列分别表示文章的创建时间和最后一次修改时间,存储时间的列用 DateTimeField 数据类型。 excerpt。
step1 # 修改app下的model step2 # 将app添加的项目中 最后一行 Python INSTALLED_APPS = [ "django.contrib.admin", ... "django.contrib.auth", "django.contrib.contenttypes", "django.contrib.sessions", "django.contrib.messages...", "django.contrib.staticfiles", "brands.apps.BrandsConfig", "appName", ] step3 # 创建migration... python manage.py makemigrations1 step4 # 将migration同步到数据库 python manage.py migrate # 多数据库 python manage.py...dumpdata app2 --database=db2 > app2_fixture.json python manage.py dumpdata auth > auth_fixture.json #数据库导入
我们把写好的文章永久地保存在数据库里,当用户访问我们的博客时,Django 就去数据库里把这些数据取出来展现给用户。 博客的文章应该含有标题、正文、作者、发表时间等数据。...一般来说这时候我们应该先去学习数据库创建表格的语法,再回来写我们的 Django 博客代码了。但是 Django 告诉我们不用这么麻烦,它已经帮我们做了一些事情。...Django 把那一套数据库的语法转换成了 Python 的语法形式,我们只要写 Python 代码就可以了,Django 会把 Python 代码翻译成对应的数据库操作语言。...例如我们的分类数据库表,Django 只要求我们这样写: blog/models.py from django.db import models class Category(models.Model...这样,Django 就可以把这个类翻译成数据库的操作语言,在数据库里创建一个名为 category 的表格,这个表格的一个列名为 name。还有一个列 id,Django 则会自动创建。
数据库存储的数据其实就是表格的形式,例如存储博客文章的数据库表长这个样子: 文章 id 标题 正文 发表时间 分类 标签 1 title 1 text 1 2019-7-1 django django...一般来说这时候我们应该先去学习数据库创建表格的语法,再回来写我们的 django 博客代码了。但是 django 告诉我们不用这么麻烦,它已经帮我们做了一些事情。...django 把那一套数据库的语法转换成了 Python 的语法形式,我们只要写 Python 代码就可以了,django 会把 Python 代码翻译成对应的数据库操作语言。...这样,django 就可以把这个类翻译成数据库的操作语言,在数据库里创建一个名为 category 的表格,这个表格的一个列名为 name。...还有一个列 id,虽然没有显示定义,但 django 会为我们自动创建。
django是不能创建数据库的,只能够创建数据库表,因此,我们在连接数据库的时候要先建立一个数据库。...在models.py中 from django.db import models class Publisher(models.Model): id = models.AutoField(primary_key...:{}".format(self.name) 进入的项目地址中, 输入python manage.py makemigrations 输入python manage.py migrate 我们就通过django...接下来我们填充一些数据, 在项目路径下输入python manage.py shell打开django终端: ? 我们举一个例子: ? 为方便起见,我们其他的数据在navicat中手动填充。
博客地址:http://www.jianshu.com/u/f0c09f959299 ❈ 400元/小时时薪招募PyLive主讲人 创建 django 博客应用 在上一章节中我们创建了 django...然而这一切都是 django 为我们创建的项目初始内容,django 不可能为我们初始化生成我们需要的博客代码,这些功能性代码都得由我们自己编写。...总之这个应用的文件夹结构 django 已经为我们建立好了,但目前它还只是包含各种文件的一个文件夹而已,django 并不知道这是一个应用,我们得告诉 django 这是我们创建的应用,专业一点说就是:...一般情况下这时候我们应该先去学习数据库创建表格的语法,再回来写我们的博客程序了。...这样,django 就可以把这个类翻译成数据库的语法,在数据库里创建一个名为 category 的表格,这个表格的一个列名为 name(即分类名),还有一个列 id 则会自动帮我们创建。
1、安装django pip3 install django 2、创建django工程 # 创建Django工程 django-admin startproject 工程名 # 运行Django功能...里(用pycharm创建默认就是templates) TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates...'django.contrib.messages', 'django.contrib.staticfiles', 'app01', ] 6、创建数据库 数据库的创建...使用数据库 Django接默使用SQLite3,打开setting.py可以看到数据库部分的配置如下: DATABASES = {...会在数据库中自动创建相应的表。
系统:Windows 7 语言版本:Anaconda3-4.3.0.1-Windows-x86_64 编辑器:pycharm-community-2016.3.2 本系列介绍如何搭建一个网站,后端使用django...框架 今天开始介绍一个单独的项目app,关于学生成绩管理网站的搭建 主要功能包括:学习成绩查询,数据统计分析 涉及前端模块:Datatables、ECharts 今天讲讲数据库的创建 Part 1:功能描述...models.py:写创建数据库对应代码的位置 ?...Part 4:ORM介绍 在以往的工作中,我们可能是通过数据库操作软件进行工作表的创建,或者通过SQL语句创建 在Django项目中我们通过在models创建类,然后再通过migrate创建对应的数据库...的方法,将传统对数据库操作的sql语句改为对类的操作 简单来理解:一个类就是一张表,通过CharField,FloatField等类创建对应的字段,不同的数据类型有不同的类与其对应 Meta类 定义了表名
接下来,需要让Django修改数据库,使其能够存储与模型Topic相关的信息。...输出表明Django创建了一个名为0001_initial.py的迁移文件,这个文件将在数据库中 为模型Topic创建一个表。...外键是一个数据库术语,它引用了数据库中的另一条记录;这些代码将每个条目关联 到特定的主题。每个主题创建时,都给它分配了一个键(或ID)。...你将看到一个下拉列表,让你能够选择要为哪个主题创建条目, 还有一个用于输入条目的文本框。从下拉列表中选择Chess,并添加一个条目。下面是我添加的 第一个条目。...再来创建一个国际象棋条目,并创建一个攀岩条目,以提供一些初始数据。下面是第二个国 际象棋条目。
1.5 创建数据库 Django将大部分与项目相关的信息都存储在数据库中,因此我们需要创建一个供Django使用的数据库。...Django又创建了一个文件——db.sqlite3。SQLite是一种使用单个文件的数据库,是编写简单应用程序的理想选择,因为它让你不用太关注数据库管理的问题。...每位用户都需要在学习笔记中创建很多主题。用户输入的每个条目都与特定主题相关联,这些条目将以文本的方式显示。我们还需要存储每个条目的时间戳,以便能够告诉用户各个条目都是什么时候创建的。...输出表明Django创建了一个名为0001_initial.py的迁移文件,这个文件将在数据库中为模型Topic创建一个表。下面来应用这种迁移,让Django替我们修改数据库: ?...再来创建一个国际象棋条目,并创建一个攀岩条目,以提供一些初始数据。下面是第二个国际象棋条目。继续往下开发“学习笔记”时,这三个条目可为我们提供使用的数据。 ?
Django基于MVT(模型视图模板)体系结构,并围绕CRUD(创建,检索,更新,删除)操作展开。最好将CRUD解释为构建Django Web应用程序的一种方法。...通常,CRUD意味着对数据库中的表执行创建,检索,更新和删除操作。让我们讨论一下CRUD的实际含义, ? 创建 –在数据库的表中创建或添加新条目。...检索 –以列表的形式(列表视图)读取,检索,搜索或查看现有条目,或详细检索特定的条目(详细视图) 更新 –更新或编辑数据库表中的现有条目 删除 –删除,停用或删除数据库表中的现有条目 Django CRUD...,我们需要运行两个命令以便为同一数据库创建数据库 Python manage.py makemigrations Python manage.py migrate 现在,我们将为此模型创建一个Django...删除检视 删除视图是指从数据库中删除表的特定实例的视图(逻辑)。它用于删除数据库中的条目,例如,删除geeksforgeeks上的文章。
接着上节的继续学习,现在要显示所有主题的页面 有了高效的网页创建方法,就能专注于另外两个网页了:显示全部主题的网页以及显示特定主题中条目的网页。...2 视图 函数topic()需要从数据库中获取指定的主题以及与之相关联的所有条目,如下所示: def topic(request,topic_id): '''显示单个主题以及所有的条目''' topic...三 总结 在本章中,我们首先学习了如何使用Django框架来创建Web应用程序。制定了简要的项目规范,在虚拟环境中安装了Django,创建了一个项目,并核实该项目已正确地创建。...学习了如何创建应用程序,以及如何定义表示应用程序数据的模型。学习了数据库,以及在修改模型后,Django可为迁移数据库提供什么样的帮助。...四 展望 在接下来的学习中,我们将创建对用户友好而直观的网页,让用户无需通过管理网站就能添加新的主题和条目,以及编辑既有的条目。我们还将添加一个用户注册系统,让用户能够创建账户和自己的学习笔记。
在3处,我们显示表单,从中可知Django使得完 成显示表单等任务有多简单:我们只需包含模板变量{{ form.as_p }},就可让Django自动创建显 示表单所需的全部字段。...用于添加新条目的表单 我们需要创建一个与模型Entry相关联的表单,但这个表单的定制程度比TopicForm要高些: forms.py from django import forms from...如果请求方法为POST,我们就对数据进行处理:创建一个EntryForm 实例,使用request对象中的POST数据来填充它(见4);再检查表单是否有效,如果有效,就设 置条目对象的属性topic,再将条目对象保存到数据库...调用save()时,我们传递了实参commit=False(见5),让Django创建一个新的条目对象,并 将其存储到new_entry中,但不将它保存到数据库中。...该页面收到POST请求(条目文本经过修订)时,它将修改后的文本保存到数据库中: views.py from django.shortcuts import render --snip-- from
我们将主题和条目都存储在字典context中(见4),再将这个字典发送给模板topic.html(见5)。 注意 2处和3处的代码被称为查询,因为它们向数据库查询特定的信息。...18.5 小结 在本章中,你首先学习了如何使用Django框架来创建Web应用程序。你制定了简要的项目规 范,在虚拟环境中安装了Django,创建了一个项目,并核实该项目已正确地创建。...你学习了如何 创建应用程序,以及如何定义表示应用程序数据的模型。你学习了数据库,以及在你修改模型后, Django可为你迁移数据库提供什么样的帮助。...在第19章,我们将创建对用户友好而直观的网页,让用户无需通过管理网站就能添加新的主 题和条目,以及编辑既有的条目。我们还将添加一个用户注册系统,让用户能够创建账户和自己 的学习笔记。...然 后,我们再对这些有效信息进行处理,并将其保存到数据库的合适地方。这些工作很多都是由 Django自动完成的。
例如,在项目“学习笔记”中,应用程序的最高层数据是主题,而 所有条目都与特定主题相关联。只要每个主题都归属于特定用户,我们就能确定数据库中每个条 目的所有者。...确定当前有哪些用户 我们迁移数据库时,Django将对数据库进行修改,使其能够存储主题和用户之间的关联。为 执行迁移,Django需要知道该将各个既有主题关联到哪个用户。...Django询问要将既有主题关联 到哪个用户时,我们将指定其中的一个ID值。 3. 迁移数据库 知道用户ID后,就可以迁移数据库了。...如果你确实想要一个全新 的数据库,可执行命令python manage.py flush,这将重建数据库的结构。如果你这样做, 就必须重新创建超级用户,且原来的所有数据都将丢失。...Django的意思是说,创建新主题时,你必须指定其owner字段的值。 由于我们可以通过request对象获悉当前用户,因此存在一个修复这种问题的简单方案。
/download/1.11a1/tarball/ 或者clone代码: git clone https://github.com/django/django.git 创建一个项目: django-admin.py...(max_length=20) 然后让数据库把这个表创建起来: (下面的命令不要少一个) python manage.py migrate #创建表结构 python manage.py makemigrationsTestModel...#让 Django 知道我们在我们的模型有一些变更 python manage.py migrate TestModel #创建表结构 操作数据库内容,就可以通过上面的类来使用,比如生成一个条目...首先激活这个管理工具: 修改映射规则文件urls.py,在urlpatterns中添加条目: url(r’^admin/’, admin.site.urls), 创建一个超级用户: python manage.py...可以在页面中,看到之前创建的相关数据库,并且操纵它们的内容。
用户登录后,就可创建新主题、添加新条目以及阅读既 有的条目。学习新的主题时,记录学到的知识可帮助跟踪和复习这些知识。优秀的应用程序让这个记录 过程简单易行。...18.1.7 创建数据库 Django将大部分与项目相关的信息都存储在数据库中,因此我们需要创建一个供Django使 用的数据库。...在1处,Django指出它将创建必要的数据库表,用于存储我们将在这 个项目(Synchronize unmigrated apps,同步未迁移的应用程序)中使用的信息,再确保数据库结 构与当前代码(Apply...SQLite是 一种使用单个文件的数据库,是编写简单应用程序的理想选择,因为它让你不用太关注数据库管 理的问题。 18.1.8 查看项目 下面来核实Django是否正确地创建了项目。...每位用户都需要在学习笔记中创建很多主题。用户输入的每个条目 都与特定主题相关联,这些条目将以文本的方式显示。我们还需要存储每个条目的时间戳,以便 能够告诉用户各个条目都是什么时候创建的。
在本章中,你将创建一些表单,让用户能够添加主题和条目,以及编辑既有的条目。你还将学习Django如何防范对基于表单的网页发起的常见攻击,这让你无需花太多时间考虑确保应用程序安全的问题。...一 让用户能够输入数据 建立用于创建用户账户的身份验证系统之前,我们先来添加几个页面,让用户能够输入数据。我们将让用户能够添加新主题、添加新条目以及编辑既有条目。...然后,我们再对这些有效信息进行处理,并将其保存到数据库的合适地方。这些工作很多都是由Django自动完成的。...在Django中,创建表单的最简单方式是使用ModelForm,它根据前面的模型中的信息自动创建表单。...在下一节,我们将实现一个用户注册系统,让任何人都可向“学习笔记”申请账户,并创建自己的主题和条目。 未完待续
一 创建用户账号 1 应用程序users 我们首先使用命令startapp来创建一个名为users的应用程序:(ll_env)learning_log$ python manage.py startapp...这也将影响条目,因为每个条目都属于特定的主题。我们先来限制对一些页面的访问。...例如,在项目“学习笔记”中,应用程序的最高层数据是主题,而所有条目都与特定主题相关联。只要每个主题都归属于特定用户,我们就能确定数据库中每个条目的所有者。...4 确定当前有哪些用户 我们迁移数据库时,Django将对数据库进行修改,使其能够存储主题和用户之间的关联,下面来查看已创建的所有用户的ID。...为此,启动一个Django shell会话,并执行如下命令: ? 3 迁移数据库 知道用户ID后,就可以迁移数据库了。 ? 现在可以执行迁移了。为此,在活动的虚拟环境中执行下面的命令: ?
领取专属 10元无门槛券
手把手带您无忧上云