前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django - 模型层以及如何通过模型层来建表

Django - 模型层以及如何通过模型层来建表

作者头像
桑鱼
发布2020-03-27 11:29:03
8130
发布2020-03-27 11:29:03
举报
模型

Django 提供了一个抽象的模型 ("models") 层,

  • 什么是模型层?
    • 这里模型的思想与Java中的ORM(Object Relationship Mapping) 对象关系映射类似
    • 模型准确且唯一的描述了数据
    • 它包含要储存的数据的字段
    • 一般来说,每一个模型都映射一张数据库表
  • 如何创建模型?
    • 每个模型都是一个 Python 的类,这些类继承 django.db.models.Model
    • 模型类的每个属性都相当于一个数据库的字段
    • 利用这些,Django 提供了一个自动生成访问数据库的 API,可以通过这些API对数据库进行增删改查
  • Settings.py 文件中增加一些配置
    • INSTALLED_APPS:定义了你的模型后,需要将模型添加到Django,所以需要将包含models的模块名称添加进去
    • DATABASES:数据库连接信息
  • 定义一个Person模型
    • first_name 和 last_name 是模型的 字段
    • 每个字段都被指定为一个类属性,并且每个属性映射为一个数据库列。
代码实例
  1. 当前项目的目录结构
  1. 包含models.py 所在目录名称为:signtest,将它添加到settings.py
  1. settings.py中增加数据库的连接信息(我这里使用的是mysql)
代码语言:javascript
复制
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': '127.0.0.1',  # 数据库主机
        'PORT': 3306,  # 数据库端口
        'USER': 'root',  # 数据库用户名
        'PASSWORD': 'abcd123456',  # 数据库用户密码
        'NAME': 'my_dj_test'  # 数据库名字
    }
}
  1. models.py 中增加模型类
代码语言:javascript
复制
from django.db import models 

class Musician(models.Model):
    first_name = models.CharField(max_length=50)  #每个变量对应的是数据库中每个字段
    last_name = models.CharField(max_length=50)
    instrument = models.CharField(max_length=100)

class Album(models.Model):
    artist = models.ForeignKey(Musician, on_delete=models.CASCADE)
    name = models.CharField(max_length=100)
    release_date = models.DateField()
    num_stars = models.IntegerField()
  1. 因为我创建的项目用的是python的虚拟环境,virtualenv就是用来为一个应用创建一套“隔离”的Python运行环境。所以需要安装一些环境的依赖
代码语言:javascript
复制
# 因为我现在的Django版本是3.x会出现一些版本不对应的情况,所以我将版本降到了2.1.7 ,没有这个问题的需要此操作
$ pip3 install Django==2.1.7 
# Successfully installed Django-2.1.7
代码语言:javascript
复制
# 安装pymysql
$ pip3 install pymysql
# Successfully installed pymysql-0.9.3
  1. 在包含settings.py的目录下的init.py文件中,将下面的代码放进去
代码语言:javascript
复制
import pymysql
pymysql.install_as_MySQLdb()
  1. 先执行数据库迁移的命令 manage.py makemigrations,再执行建表的命令manage.py migrate
代码语言:javascript
复制
$ python3 manage.py makemigrations
Migrations for 'signtest':
  signtest/migrations/0001_initial.py
    - Create model Album
    - Create model Musician
    - Add field artist to album
代码语言:javascript
复制
$ python3  manage.py migrate
Operations to perform:
  Apply all migrations: admin, auth, contenttypes, sessions, signtest
Running migrations:
  Applying contenttypes.0001_initial... OK
# ...
(venv) pengyapandeMacBook-Air:sangyu pengyapan$ 
  1. 进入数据库查看
  1. 到这就里就根据Django模型在数据库建表成功了
  2. 其他的一些命令,可能用不到只是记录下
代码语言:javascript
复制
# 卸载mysqlclient
pip install mysqlclient
# 异常:mysqlclient 1.3.13 or newer is required; you have 0.9.3
# 可能是由于Django版本不一致的问题改成,也可以通过修改/Users/lixiang/.env/lib/python3.6/site-packages/django/db/backends/mysql/base.py 这个文件下的注释掉version < (1, 3, 13)
# 这是在sql中执行的命令的,主要是记录建表信息会记录在这个表django_migrations中
DELETE FROM django_migrations WHERE app='your-app-name';
# 下载依赖时增加版本信息
mysql-connector-python==1.0.12
# 要为应用创建初始迁移,请运行makemigrations并指定应用名称。将创建迁移文件夹
./manage.py makemigrations <myapp>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 模型
  • 代码实例
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档