Django的基本命令
django-admin
|----------------|---------------------------|
| 命令 | 含义 |
| startproject | 启动Django项目 |
| startapp | 启动Django应用 |
| check | 检查项目完整性 |
| runserver | 本地运行项目 |
| shell | 进入Django项目的Python Shell环境 |
| test | 进行Django用例测试 |
| makemigrations | 创建模型变更的迁移文件 |
| migrate | 执行makemigrations命令创建的迁移文件 |
| dumpdata | 将数据库的文件导出至文件 |
| loaddata | 将文件中的数据导入至数据库 |
建立一个Django项目
python
django-admin startproject project_name
Django Project项目可以直接运行 Django App不可以直接运行
一个Project可以包含若干个App,每个App可以自己管理模型、视图、模板、路由和静态文件。
创建一个Django应用
python
django-admin manage.py startapp app_name
Django应用目录
views.py 处理视图
models.py 定义应用模型
admin.py 定义Admin模块管理对象
apps.py 声明应用
tests.py 编写测试用例
urls.py 管理应用路由
模型层简介
模型层处于视图层和数据库之间,作用是将Python对象和数据库表相互转换
模型层可以屏蔽不同数据库之间的差异,使得开发者更加专注于业务开发,可以提供数据库迁移等操作
python
DATABASES = {
"default": {
"ENGINE": "django.db.backends.sqlite3",
"NAME": BASE_DIR / "db.sqlite3",
}
}
设置职位模型
- 职位名称-文本-TextField
- 发布日期-日期-DateTimeField
- 公司名称-文本-TextField
- 工作内容-文本-TextField
- 岗位要求-文本-TextField
- 投递链接-超链接-
- 职位ID-int类型-自增-主键-IntegerField-AutoField-primary_key
职位模型的定义
定义一个类,引用model.Models
给模型中的字段招对应的模型
python
from django.db import models
# Create your models here.
class Job(models.Model):
"""
id职位ID-int类型-自增-主键-IntegerField-AutoField-primary_key
name职位名称-文本-TextField
time发布日期-日期-DateTimeField
cname公司名称-文本-TextField
descript岗位描述-文本-TextField
require岗位要求-文本-TextField
urls投递链接-超链接-URLField
"""
job_id = models.AutoField(primary_key=True)
job_name = models.TextField()
job_date = models.DateTimeField(auto_now=True)
job_cname = models.TextField()
job_desc = models.TextField()
job_req = models.TextField()
job_urls = models.URLField()
在终端中执行makemigrations,创建迁移文件
python
python manage.py makemigrations
运行迁移文件,将迁移文件里的数据同步到数据库
python
python manage.py migrate
进入Djangoshell环境
python
python manage.py shell
创建Job对象,并进行实例化,在保存至数据库。
python
from AnxinCampusRecruitment.models import Job
a = Job()
a.job_id=100
a.job_name="测试开发工程师"
a.job_date="2023-03-29"
a.job_cname="阿里巴巴"
a.job_desc="测试"
a.job_req="python,测试理论"
a.job_urls="www.baidu.com"
a.save()//保存至数据库
jobs=Job.objects.all()//获取所有Job对象
job=jobs[0]
print(job.job_cname)