【Django】项目模型

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)
相关推荐
酷飞飞4 小时前
Python网络与多任务编程:TCP/UDP实战指南
网络·python·tcp/ip
数字化顾问5 小时前
Python:OpenCV 教程——从传统视觉到深度学习:YOLOv8 与 OpenCV DNN 模块协同实现工业缺陷检测
python
学生信的大叔6 小时前
【Python自动化】Ubuntu24.04配置Selenium并测试
python·selenium·自动化
计算机编程小央姐7 小时前
跟上大数据时代步伐:食物营养数据可视化分析系统技术前沿解析
大数据·hadoop·信息可视化·spark·django·课程设计·食物
用户21411832636027 小时前
Qwen3-Coder 实战!历史人物短视频一键生成,多分镜人物不崩,魔搭直接玩
后端
追逐时光者7 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 54 期(2025年9.8-9.14)
后端·.net
追逐时光者7 小时前
C#/.NET/.NET Core编程技巧练习集,配套详细的文章教程讲解!
后端·.net
诗句藏于尽头7 小时前
Django模型与数据库表映射的两种方式
数据库·python·django
智数研析社8 小时前
9120 部 TMDb 高分电影数据集 | 7 列全维度指标 (评分 / 热度 / 剧情)+API 权威源 | 电影趋势分析 / 推荐系统 / NLP 建模用
大数据·人工智能·python·深度学习·数据分析·数据集·数据清洗
扯淡的闲人8 小时前
多语言编码Agent解决方案(5)-IntelliJ插件实现
开发语言·python