這篇文章為大家帶來了關於Python的相關知識,其中主要介紹了關於Django的模型建立與操作的相關內容,下面一起來看一下,希望對大家有幫助。
【相關推薦:Python3影片教學 】
我們要建立一個部落格系統,首先在manage.py 所在目錄下,用命令python manage.py startapp blog
新建一個blog 應用,然後在./blog/models.py
中寫一個類,命名為BlogArticles
。
透過這個類別我們可以建立一個專門用來保存部落格文章的資料庫表,程式碼如下:
from django.db import modelsfrom django.utils import timezone # 新增from django.contrib.auth.models import User # 新增# Create your models here.# 编写博客的数据类型类BlogArticlesclass BlogArticles(models.Model): # 字段title的属性为CharField()类型,并且以参数max_length=300说明字段的最大数量 title = models.CharField(max_length=300) # 一个用户对应多篇文章,级联删除 author = models.ForeignKey(User, on_delete=models.CASCADE, related_name="blog_posts") body = models.TextField() publish = models.DateTimeField(default=timezone.now) class Meta: ordering = ("-publish", ) # 规定了BlogArticles实例对象的显示顺序,即按照publish字段值的倒序显示 def __str__(self): return self.title
相信經過上一篇文章的介紹,這裡很多臉孔你都很熟悉,現在對他們進行簡單介紹:
TIME_ZONE = 'Asia/Shanghai' # 设置东八区时间# TIME_ZONE = 'UTC'USE_TZ = False
User
模型被命名為內建應用程式叫auth,它以命名空間django.contrib.auth
的形式出現在INSTALL_APPS
設定中 反映一個使用者可以發表多篇文章,其中參數
on_delete=models.CASCADE 是資料庫中的“級聯刪除”,如果“使用者表”中的某個使用者被刪除,那麼“文章表”中該使用者對應的文章記錄也將被刪除。
的作用是允許 User 的實例(某個使用者名稱)以 “blog_posts” 屬性反向查詢到類別 BlogArticles 的實例。
規定文章的顯示順序
# 方法是物件的字串表示形式。我們可以使用版塊的名稱來表示它。
settings.py 檔案的
INSTALLED_APPS 清單中加入blog 應用,如下所示:
類別的資料模型寫完畢,我們得資料庫表就是透過這個類別中各字段和屬性創建完成。 資料遷移
檔案所在的資料夾,然後執行指令:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">python manage.py makemigrations</pre><div class="contentsignin">登入後複製</div></div>
然後你會看到如下輸出內容:
Migrations for 'blog': blog/migrations/0001_initial.py - Create model BlogArticles
此時,Django 在
/blog/migrations 目錄中建立了一個名為0001_initial.py
的檔案。它代表了應用程式模型的當前狀態,在下一步,將使用該檔案建立表格和列。 遷移檔案將會翻譯成 SQL 語句。執行下面指令:
python manage.py sqlmigrate blog 0001
然後可以看到如下輸出內容:
BEGIN; -- -- Create model BlogArticles -- CREATE TABLE "blog_blogarticles" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "title" varchar(300) NOT NULL, "body" text NOT NULL, "publish" datetime NOT NULL, "author_id" integer NOT NULL REFERENCES "auth_user" ("id") DEFERRABLE INITIALLY DEFERRED); CREATE INDEX "blog_blogarticles_author_id_ed798e23" ON "blog_blogarticles" ("author_id"); COMMIT;
最後我們將生產的遷移檔案應用到資料庫中:
python manage.py migrate
當看到
Operations to perform: Apply all migrations: admin, auth, blog, contenttypes, sessions Running migrations: ... Applying sessions.001_initial... OK
,這是我們在上一步生產的遷移腳本。意味著,我們的資料庫已經可以開始使用了。
SQLite 很輕量級,但是不影響我們用來學習,接下來我們將利用命令列工具來對模型進行操作,也就是我們學習過資料庫的基本操作-增、刪、改、查。
模型操作
对数据库的操作可以利用 GUI 工具,也可以通过命令行 sqlite3 db.sqlite3
,我们在 db.sqlite3 所在的目录下使用上述命令,就可以进入到 db.sqlite3 数据库,如果本地开发中没有配置 SQLite 环境,可以自行搜索如何配置。
如果我们输入命令,看到如下信息,说明进入成功:
~/DjangoProject/myblog $ sqlite3 db.sqlite3 SQLite version 3.29.0 2019-07-10 17:32:03 Enter ".help" for usage hints. sqlite>
然后我们使用 .tables
即可查看当前数据库中的数据库表的名称,除了 blog_blogarticles
是我们通过 BlogArticles 模型建立的,其余的都是项目默认创建的数据库表。
~/DjangoProject/myblog $ sqlite3 db.sqlite3 SQLite version 3.29.0 2019-07-10 17:32:03 Enter ".help" for usage hints. sqlite> .tables auth_group blog_blogarticles auth_group_permissions django_admin_log auth_permission django_content_type auth_user django_migrations auth_user_groups django_session auth_user_user_permissions sqlite>
接下来使用 pragma table_info(blog_blogarticles);
命令来查看 blog_blogarticles 表的结构:
sqlite> .header on sqlite> pragma table_info(blog_blogarticles); cid|name |type |notnull|dflt_value|pk 0| id |integer |1 | |1 1|title |varchar(300)|1 | |0 2|body |text |1 | |0 3|publish |datetime |1 | |0 4|author_id|integer |1 | |0 sqlite>
.header on 开启头部显示
SQLite 的
PRAGMA
命令是一个特殊的命令,可以用在 SQLite 环境内控制各种环境变量和状态标志。一个 PRAGMA 值可以被读取,也可以根据需求进行设置。
我们可以大致查看上面的表结构,cid 是指列 id,name 是指列名,type 是指列类型,notnull 非空,值为 1 表示 True,dflt_value 是指 default 默认值(这一列没有值,说明设置设置默认值),pk 是指 primary_key 主键。
大家可以跟我们在前一章中的数据模型 BlogArticles 所规定的字段和属性进行对比,是不是刚好我们利用数据迁移成功将数据模型转化为数据库表。
我们可以在命令行中输入 python manage.py createsuperuser
创建一个 Django 超级管理员,输入用户名和密码,当提示 Superuser created successfully,创建成功。如下:
~/DjangoProject/myblog $ python manage.py createsuperuser Username (leave blank to use 'yuzhou_1su'): zoeu Email address: test@test.com Password: Password (again): Superuser created successfully.
然后我在浏览器输入 http://127.0.0.1:8000/admin/
,就可以打开如下界面:
输入刚才创建的超级管理员的用户名和密码就可以进入系统,如图:
Groups 和 Users 是 Django 在用户管理应用中默认的用户分类。为了让我们得管理员用户能够发布博客,我们需要在 ./blog/admin.py
文件中,加入如下代码:
from django.contrib import admin# 新增,将BlogArticles类引入到当前环境中from .models import BlogArticles # 将BlogArticles注册到admin中admin.site.register(BlogArticles)
刷新页面,我们可以得到如下的页面:
超级管理员界面先放在这,我们回到模型操作。
使用 Python 进行开发的一个重要优点是交互式 shell。我们在 ./blog/models.py
中创建了数据模型后,Django 就会自动提供数据库抽象的 API,这是一种快速尝试和试验 API 的方法。通过这个 API 我们可以快速创建、获取、修改和删除对象,对此我们称之为 ORM(Object-Relational Mapper)
我们可以使用 manage.py
工具加载我们的项目来启动 Python shell :
python3 manage.py shell
Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 16:52:21) [Clang 6.0 (clang-600.0.57)] on darwin Type "help", "copyright", "credits" or "license" for more information. (InteractiveConsole) >>>
请特别注意我们进入 shell 的方式,不是直接在命令行中敲 python3,虽然这与直接输入 python 指令来调用交互式控制台是非常相似。
区别是我们利用 manage.py 工具,将项目将被添加到 sys.path
并加载 Django。这意味着我们可以在项目中导入我们的模型和其他资源并使用它。
让我们从导入 BlogArticles 类开始:下面就可以开始我们对数据库的增、删、改、查等操作。
$ python3 manage.py shell Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 16:52:21) [Clang 6.0 (clang-600.0.57)] on darwinType "help", "copyright", "credits" or "license" for more information. (InteractiveConsole)>>> from django.contrib.auth.models import User>>> from blog.models import BlogArticles>>> admin = User.objects.get(username="zoue")>>> admin.username'zoeu'>>> admin.id1>>> admin.password'pbkdf2_sha256$150000$b9j0ZKBVZSo1$l+fEIiKIaS6u1mhjMPOX1qR0xMOaemnRJIwiE2lNn60='>>> admin.email'test@test.com'>>> type(admin) <class></class>
以上是对用户的查询操作是不是刚好是我们上一节中在创建管理员的内容,恭喜你!
接下来,我们对博客文章进行操作,要创建新的 BlogArticle 对象,我们可以执行以下操作:
>>> BlogAriticle01 = BlogArticles(title ='DjangoNotes_Day01', author=zoue, body='Django是啥?');
为了将这个对象保存在数据库中,我们必须调用 save 方法:
>>> BlogAriticle01.save()
save
方法用于创建和更新对象。这里Django创建了一个新对象,因为这时 BlogAriticle01 实例没有 id。第一次保存后,Django 会自动设置 ID :
>>> BlogAriticle01.id4
因为我自己在之前创建过其它文章,所以这个 id 值为 4,如果你是按照本入门笔记一步步操作过来,id 值应该为 1。
当然,还可以查看其它属性,这里统一将命令敲出来:
>>> BlogAriticle01.title'DjangoNotes_Day01'>>> BlogAriticle01.author <user:>>>> BlogAriticle01.body'Django是啥?'>>> BlogAriticle01.publish datetime.datetime(2019, 9, 30, 19, 56, 58, 735676)>>></user:>
每个 Django 模型都带有一个特殊的属性; 我们称之为模型管理器(Model Manager)。你可以通过属性 objects 来访问这个管理器,它主要用于数据库操作。例如,我们可以使用它来直接创建一个新的 Board 对象:
>>> BlogArticle02 = BlogArticles.objects.create(title='Python', author=admin, body='Head First to Python.')>>> BlogArticle02.id5
要更新一个值,我们可以利用如下操作:
>>> BlogAriticle01.body = 'I love Django, 但是我太难了'>>> BlogAriticle01.body'I love Django, 但是我太难了'
>>> blogs = BlogArticles.objects.all()>>> blogs <queryset>, <blogarticles:>, <blogarticles:>, <blogarticles:>, <blogarticles:>]></blogarticles:></blogarticles:></blogarticles:></blogarticles:></queryset>
结果是一个 QuerySet,我们可以将这个 QuerySet 看作一个列表。假设我们想遍历它并打印每个模块的标题。
>>> for blog in blogs:... print(blog.title)... Python DjangoNotes_Day01 right here waiting Yesterday once more You Raise me up>>>
同样,我们可以使用模型的 管理器(Manager) 来查询数据库并返回单个对象。为此,我们要使用 get 方法:
>>> BlogArticles.objects.get(id=5) <blogarticles:></blogarticles:>
>>> BlogArticles.objects.get(id=5).delete() (1, {'blog.BlogArticles': 1})
删除后再重新查看一下 QuerySet,发现没有了
>>> blogs = BlogArticles.objects.all()>>> blogs <queryset>, <blogarticles:>, <blogarticles:>, <blogarticles:>]></blogarticles:></blogarticles:></blogarticles:></queryset>
除了 get 方法,其实也可以用 filter 进行筛选查询 id=5 然后删除,
BlogArticles.objects.filter(id=5).delete()
,关于 filter 方法我们将在后面的文章中进行介绍。
下面是我们在本节中关于模型学到的方法和操作,使用 BlogArticles 模型作为参考。大写的 BlogArticles 指的是类,BlogArticles01 指 BlogArticles 的一个实例(或对象):
操作 | 代码示例 |
---|---|
创建一个对象而不保存 | BlogAriticle01 = BlogArticles() |
保存一个对象(创建或更新) | BlogAriticle01.save() |
数据库中创建并保存一个对象 | BlogArticle02 = BlogArticles.objects.create(title='...', author=..., body='...') |
列出所有对象 | BlogArticles.objects.all() |
通过字段标识获取单个对象 | BlogArticles.objects.get(id=5) |
通过字段标识删除单个对象 | BlogArticles.objects.get(id=5).delete() |
【相关推荐:Python3视频教程 】
以上是Python Django的模型建立與操作(實例詳解)的詳細內容。更多資訊請關注PHP中文網其他相關文章!