django中的数据库迁移的实现
作者:小陆同学 发布时间:2024-01-18 07:35:00
Django是用python写的web开发框架,其特点是:
1.重量级框架,内部封装了很多的功能组件,使开发变的简便快速,
2.MVT模式:前后端分离,高内聚低耦合,m:model,与mvc中的m功能相同,负责和数据库交互,进行数据处理,v:view,与mvc中的c功能相同,接收请求,进行业务处理,返回应答,t:template,与mvc中的v功能相同,负责封装构造要返回的html。
orm:对象关系映射,主要实现模型对象到数据库数据的映射。
1.首先要在models.py中建立模型类,示例:
2.在settings.py文件中把models.py所在的子应用也要加入配置项,否则orm数据库无法别识别到
3.将模型类在admin.py中注册
4.接下来就是数据库迁移的命令
python manage.py migrate # 根据数据库迁移文件生成对应SQL语句并执行
# 初次执行时为了先把默认Django需要的数据库创建出来
python manage.py makemigrations # 创建数据库迁移文件
# 这次执行是为了创建app中的class模型类的迁移文件
python manage.py
# 将新添加的模型类迁移文件生成对应SQL并执行,实际创建出来对应的表
Django中默认的数据库实sqlite3
sqlite是一款轻型的数据库,占用资源特别小,大约几百k内存就够了,它能支持windows/linux/unix等主流的操作系统,储存在磁盘文件中的一个完整的数据库,比一些流行的数据库在大部分普通数据库操作要快,简单,轻松的api,独立:没有额外依赖,支持多种开发语言,以二进制形式存储在本地,负载量在10万以下时性能更佳,省掉了对数据库服务器的远程连接甚至会更快
ps:生成迁移和执行迁移
django框架就是一款强大的ORM框架,可以不需要写sql语句就能进行应用开发。
首先需要生成迁移文件,这就“相当于”生成sql语句脚本。
python manage.py makemigrations
这样就生成了迁移文件,在相对应的项目应用中可以看到migrations文件夹下,生成一个新文件
operations = [
migrations.CreateModel(
name='BookInfo',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('btitle', models.CharField(max_length=20)),
('bpub_date', models.DateTimeField()),
],
),
migrations.CreateModel(
name='HeroInfo',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('hname', models.CharField(max_length=20)),
('hgender', models.BooleanField()),
('hcontent', models.CharField(max_length=100)),
('hBook', models.ForeignKey(to='booktest.BookInfo')),
],
),
]
django会默认为每一个表生成一个主键id。
然后,执行迁移。这样才会生成数据库表。
python manage.py migrat
来源:https://www.cnblogs.com/lutt/p/10634563.html


猜你喜欢
- 一、python图形界面tk之滚动文本框的实现示例使用python的tkinter库实现滚动文本框的方式,目前我知道的有两种,一
- Flappy Bird是前段时间(好像一年or两年前....)特别火的有一个小游戏,相信大家都玩过。Flappy Bird操作简单,通过点击
- 一 描述1030. 距离顺序排列矩阵单元格 - 力扣(LeetCode) (leetcode-cn.com)给定四个整数 row
- Django 分页功能的实现,供大家参考,具体内容如下创建项目创建APP,添加APP这些就不在多说我们这次重点来看到视图函数下面是路由设置视
- python replace函数替换无效问题str = "hello,china!"str.replace("
- 用df命令查了下,果然磁盘满了,因为当时分区采用系统默认,不知道为什么不能自动扩容!以后在处理这个问题!如图所示:[root@snsgou
- 本文实例讲述了Python基于分水岭算法解决走迷宫游戏。分享给大家供大家参考,具体如下:#Solving maze with morphol
- 因为公司需要在原有的web开发上,实现3d效果。根据需求正在学习webgl,主攻cesium这一块,采用的工具是webstorm.但是使用一
- python多线程适合IO密集型场景,而在CPU密集型场景,并不能充分利用多核CPU,而协程本质基于线程,同样不能充分发挥多核的优势。针对计
- 1.简介map 是 Golang 中的方便而强大的内建数据结构,是一个同种类型元素的无序组,元素通过另一类型唯一的键进行索引。其键可以是任何
- 背景最近在测试一款软件的关闭第三方窗口的功能,感觉实现应该挺简单的。所以就尝试了。由于说它的实现是靠c++实现的,本人对c++实在不在行,但
- 前言因为工作中经常用到这些方法,所有便把这些方法进行了总结。JavaScript 1. type 类型判断isString (o) { //
- 注:本次实验的数据在文章最后面,我已上传至百度网盘一.json模块对数据进行处理 上面三个txt文本是这三个国家疫情爆发相关的数据
- Reference:https://www.tensorflow.org/install/migrationtensorflow 更新到1.
- 1. 需求vs现状1.1 需求要求做一个ERP后台辅助管理的程序,有以下几项基本要求:1. 基本的增删改查功能2. 基于对象的权限控制(如:
- python读写文件有时候会出现 ‘XXX'编码不能打开XXX什么的,用记事本打开要读取的文件,另存为UTF
- 在利用Python进行系统管理的时候,特别是同时操作多个文件目录,或者远程控制多台主机,并行操作可以节约大量的时间。当 * 作对象数目不大时,
- 基于 Vue 技术栈的你如果需要选用一种移动端跨平台框架,是 Weex?React-Native?还是Flutter? 无疑,相对于后两者,
- 在制作网页以及编程的时候,适当的进行注释,不仅使自己的思路清晰,极大地减轻了维护的难度,而且方便项目组其他人了解你的代码,方便对代码的理解以
- 深藏多年秘笈大公开,全世界唯一一家公布,怎么点就是点不出,纯CSS去掉按钮或者链接点击产生的虚线。运行代码框<style type=&