对于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
定义模型在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应用的编写与开发,稍后会详细的介绍模型编写的一些细节。