ホームページ  >  記事  >  バックエンド開発  >  Python Djangoモデルの構築と運用(詳細例)

Python Djangoモデルの構築と運用(詳細例)

WBOY
WBOY転載
2022-11-09 15:04:133040ブラウズ

この記事では、Python に関する関連知識を紹介しており、主に Django モデルの構築と運用に関する関連内容を紹介しています。一緒に見ていきましょう。皆様のお役に立てれば幸いです。

Python Djangoモデルの構築と運用(詳細例)

[関連する推奨事項: Python3 ビデオ チュートリアル ]

モデルの確立

ブログを構築したいsystem では、まず、manage.py が配置されているディレクトリでコマンド python manage.py startapp 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

前の記事で紹介した後、多くの顔が作成されると思います。

  • timezoneモジュール今後記事の公開時刻を記録するため、このモジュールをインポートしました。ただし、Django はデフォルトでタイム ゾーンをオンにし、UTC であるため、設定で次の設定を行う必要があります。
TIME_ZONE = 'Asia/Shanghai'     # 设置东八区时间# TIME_ZONE = 'UTC'USE_TZ = False
  • User モデルの名前は、組み込みアプリケーションは auth と呼ばれ、名前空間 django.contrib.authINSTALL_APPS 設定
  • ForeignKey() に表示されます。 、ユーザーが複数の記事を公開できることを反映しています。 、パラメータ on_delete=models.CASCADE は、データベース内の「カスケード削除」です。「ユーザー テーブル」内のユーザーが削除されると、記事は「記事テーブル」内のユーザーに対応するレコードも削除されます。
  • 別のパラメータ 関連付け名="blog_posts" は、User (特定のユーザ名) のインスタンスが、「blog_posts」属性を使用してクラス BlogArticles のインスタンスを逆クエリできるようにするために使用されます。
  • Meta サブクラスも定義し、ordering = ("-publish", ) を使用して記事の表示順序を指定しました
  • __str__メソッドはオブジェクトの文字列表現です。セクションの名前を使用してそれを表すことができます。

上記の手順では、作成したブログ アプリケーションにブログ投稿モデルを作成しただけです。アプリケーションを有効にするには、アプリケーションを設定に含める必要もあります。 settings.py 次のように、ブログ アプリケーションをファイルの INSTALLED_APPS リストに追加します。

Python Djangoモデルの構築と運用(詳細例)

BlogArticles クラス データ モデルが書き込まれた後、このクラスのフィールドと属性を通じてデータベース テーブルが作成されます。

データ移行

次のステップは、モデルクラスが作成されたのでデータベースを作成するときが来たことを Django に伝えることです。ターミナルを開いて manage に移動しましょう。 py ファイルが存在するフォルダーを指定して、コマンドを実行します。

python manage.py makemigrations

すると、次の出力が表示されます。

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

sessions.001_initial を適用しています... OK

、これは前のステップで作成した移行スクリプトです。これは、データベースを使用する準備ができたことを意味します。

Django にはデータベース SQLite が付属していますが、SQLite は製品レベルのデータベースであることに注意してください。 SQLite は、すべての Android および iOS デバイス、主要な Web ブラウザ、Windows 10、MacOS など、何千もの製品で多くの企業で使用されています。 しかし、これはあらゆる状況に適しているわけではありません。 SQLite を MySQL、PostgreSQL、Oracle などのデータベースと比較することはできません。 SQLite を使用する大容量の Web サイト、書き込み集中型のアプリケーション、大規模なデータ セット、および同時実行性の高いアプリケーションは、最終的に問題を引き起こすことになります。

SQLite は非常に軽量ですが、学習での使用には影響しません。次に、コマンド ライン ツールを使用してモデルを操作します。つまり、データベースの基本操作を学習しました。 、削除、変更、確認。

モデル操作

上記のコンテンツでは、ブログ記事モデルを確立し、データ移行を通じて対応するデータベース テーブルを作成し、それに基づいていくつかの操作を追加、削除、変更します。上記のモデルですが、コンテンツのこの小さな部分では、誰もがデータベース操作に少し慣れている必要があるかもしれません。皆さんも Django を学ぶ目的でこの入門書を読んでいると思いますが、私はデータベース王の前で何もする勇気がないので、この章に直接進みます。

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/ ,就可以打开如下界面:

Python Djangoモデルの構築と運用(詳細例)

输入刚才创建的超级管理员的用户名和密码就可以进入系统,如图:

Python Djangoモデルの構築と運用(詳細例)

Groups 和 Users 是 Django 在用户管理应用中默认的用户分类。为了让我们得管理员用户能够发布博客,我们需要在 ./blog/admin.py 文件中,加入如下代码:

from django.contrib import admin# 新增,将BlogArticles类引入到当前环境中from .models import BlogArticles    

# 将BlogArticles注册到admin中admin.site.register(BlogArticles)

刷新页面,我们可以得到如下的页面:

Python Djangoモデルの構築と運用(詳細例)

超级管理员界面先放在这,我们回到模型操作。

模型 API 测试

使用 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 指的是类,BlogArticles01BlogArticles 的一个实例(或对象):

操作 代码示例
创建一个对象而不保存 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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.imで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。