Django 4.2 复习笔记(二)编写和调试Model模型

作者:J.sky · 发表于:
2023-05-20T08:11:53.000000Z
· 更新于:
2023-08-13T22:54:57.599618Z
· Tag: Django

对于web应用的编写应该从哪里开始呢?如果包含了数据的增删改查,那么对于使用Django开发web应用来说,从模型(Model)开始最好不过了。模型准确且唯一的描述了数据。它包含您储存的数据的重要字段和行为。一般来说,每一个模型都映射一张数据库表。

数据库配置

首先,使用数据库需要先连接到数据库才能定义表和操作数据,Django的数据库连接在配置文件settins.py中配置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}

上边的代码配置一个sqlite3的数据库连接,本文是用sqlite数据库来进行测试,如果你需要连接其他数据库,可以修改数据库到对应的连接方式,官方支持 PostgreSQL、MariaDB、MySQL、Oracle 和 SQLite。对数据库连接的配置可以参考这个网址:

https://docs.djangoproject.com/zh-hans/4.2/ref/settings/#std-setting-DATABASES

模型(Model)

定义模型在Django里边是很简单的,可以在Django的应用的app/model.py编写模型定义的代码,每个模型都是一个 Python 的类,这些类继承 django.db.models.Model,先导入:

from django.db import models

然后就可以编写model的代码了:

class Article(models.Model):
    title = models.CharField(max_length=128,verbose_name='文章标题')
    content = models.TextField(verbose_name='文章内容')

任何模型的定义都需要继承models.Model,Django为开发者提供了大量的class,模型类的每个属性都相当于一个数据库的字段。

相关参考:

模型字段参考

字段类型参考

激活模型

定义完模型,首先需要生成相关的数据库和表,然后通过Django的命令行进行调试。

配置文件mysite/settings.py中添加myapp,你的应用名称。

INSTALLED_APPS = [
    'myapp',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

然后,终端下运行:

$ python manage.py makemigrations myapp
Migrations for 'myapp':
myapp/migrations/0001_initial.py
    - Create model Article

这是通过Django的命令行生成了对应SQL语句,执行这些SQL语句就会生成对应的表和字段。

继续敲入python manage.py migrate

$ python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, contenttypes, myapp, sessions
Running migrations:
Applying contenttypes.0001_initial... OK
Applying auth.0001_initial... OK
Applying admin.0001_initial... OK
Applying admin.0002_logentry_remove_auto_add... OK
Applying admin.0003_logentry_add_action_flag_choices... OK
Applying contenttypes.0002_remove_content_type_name... OK
Applying auth.0002_alter_permission_name_max_length... OK
Applying auth.0003_alter_user_email_max_length... OK
Applying auth.0004_alter_user_username_opts... OK
Applying auth.0005_alter_user_last_login_null... OK
Applying auth.0006_require_contenttypes_0002... OK
Applying auth.0007_alter_validators_add_error_messages... OK
Applying auth.0008_alter_user_username_max_length... OK
Applying auth.0009_alter_user_last_name_max_length... OK
Applying auth.0010_alter_group_name_max_length... OK
Applying auth.0011_update_proxy_permissions... OK
Applying auth.0012_alter_user_first_name_max_length... OK
Applying myapp.0001_initial... OK
Applying sessions.0001_initial... OK

这个时候就会生成相关的数据库,当然Django一些自带的项目依赖的数据库也一并创建了。

调试模型

终端下敲入:

$ python manage.py shell

进入Python的交互模式,敲入下边的代码进行测试:

>>> from myapp.models import Article
>>> a = Article(title='测试标题',content='这是一篇很长很长的文章。。。。。。')
>>> a.save()
>>> a.id
1
>>> a.title
'测试标题'
>>> a.content
'这是一篇很长很长的文章。。。。。。'
>>> Article.objects.all()
<QuerySet [<Article: Article object (1)>]>
>>> Article.objects.filter(id=1)
<QuerySet [<Article: Article object (1)>]>
>>> Article.objects.get(id=1)
<Article: Article object (1)>
>>>

是不是很方便?不但可以创建还可以进行其他的增删改查。

总结

有关模型的使用这篇文章只是起了个头,模型是Django应用的核心与灵魂,web网站的数据都是围绕着模型展开的,熟练的创建和调试模型,会大大的提高Django应用的编写与开发,稍后会详细的介绍模型编写的一些细节。