django中的数据库迁移的实现


Posted in Python onMarch 16, 2020

Django是用python写的web开发框架,其特点是:

1.重量级框架,内部封装了很多的功能组件,使开发变的简便快速,

2.MVT模式:前后端分离,高内聚低耦合,m:model,与mvc中的m功能相同,负责和数据库交互,进行数据处理,v:view,与mvc中的c功能相同,接收请求,进行业务处理,返回应答,

t:template,与mvc中的v功能相同,负责封装构造要返回的html。

orm:对象关系映射,主要实现模型对象到数据库数据的映射。

1.首先要在models.py中建立模型类,示例:

django中的数据库迁移的实现

2.在settings.py文件中把models.py所在的子应用也要加入配置项,否则orm数据库无法别识别到

django中的数据库迁移的实现

3.将模型类在admin.py中注册

django中的数据库迁移的实现

4.接下来就是数据库迁移的命令

python manage.py migrate # 根据数据库迁移文件生成对应SQL语句并执行

# 初次执行时为了先把默认Django需要的数据库创建出来

python manage.py makemigrations # 创建数据库迁移文件

# 这次执行是为了创建app中的class模型类的迁移文件

python manage.py

# 将新添加的模型类迁移文件生成对应SQL并执行,实际创建出来对应的表

Django中默认的数据库实sqlite3

django中的数据库迁移的实现

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

到此这篇关于django中的数据库迁移的实现的文章就介绍到这了,更多相关django 数据库迁移内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python处理RSS、ATOM模块FEEDPARSER介绍
Feb 18 Python
Python变量和字符串详解
Apr 29 Python
python计算两个地址之间的距离方法
Jun 09 Python
Flask和Django框架中自定义模型类的表名、父类相关问题分析
Jul 19 Python
python+ffmpeg批量去视频开头的方法
Jan 09 Python
在python中画正态分布图像的实例
Jul 08 Python
Python替换月份为英文缩写的实现方法
Jul 15 Python
Django中自定义查询对象的具体使用
Oct 13 Python
利用python实现冒泡排序算法实例代码
Dec 01 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
Jun 08 Python
利用PyQt5+Matplotlib 绘制静态/动态图的实现代码
Jul 13 Python
详解anaconda离线安装pytorchGPU版
Sep 08 Python
django之从html页面表单获取输入的数据实例
Mar 16 #Python
Django实现将views.py中的数据传递到前端html页面,并展示
Mar 16 #Python
Python Django view 两种return的实现方式
Mar 16 #Python
Python 统计位数为偶数的数字代码详解
Mar 15 #Python
使用pygame编写Flappy bird小游戏
Mar 14 #Python
Python3.x+pyqtgraph实现数据可视化教程
Mar 14 #Python
浅谈selenium如何应对网页内容需要鼠标滚动加载的问题
Mar 14 #Python
You might like
基于MySQL分区性能的详细介绍
2013/05/02 PHP
Laravel构建即时应用的一种实现方法详解
2017/08/31 PHP
[原创]PHP获取数组表示的路径方法分析【数组转字符串】
2017/09/01 PHP
php 实现简单的登录功能示例【基于thinkPHP框架】
2019/12/02 PHP
javascript document.compatMode兼容性
2010/02/23 Javascript
js 实现在离开页面时提醒未保存的信息(减少用户重复操作)
2013/01/16 Javascript
jquery()函数的三种语法介绍
2013/10/09 Javascript
3种Jquery限制文本框只能输入数字字母的方法
2014/12/03 Javascript
jquery专业的导航菜单特效代码分享
2015/08/29 Javascript
基于JavaScript代码实现兼容各浏览器的设为首页和加入收藏
2016/01/07 Javascript
值得分享的轻量级Bootstrap Table表格插件
2016/05/30 Javascript
利用Angularjs和Bootstrap前端开发案例实战
2016/08/27 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
2016/10/31 Javascript
flag和jq on 的绑定多个对象和方法(必看)
2017/02/27 Javascript
JS+WCF实现进度条实时监测数据加载量的方法详解
2017/12/19 Javascript
Vue常用指令详解分析
2018/08/19 Javascript
vue.js+element-ui动态配置菜单的实例
2018/09/07 Javascript
Vuex 单状态库与多模块状态库详解
2018/12/11 Javascript
JS实现字体背景跑马灯
2020/01/06 Javascript
[34:56]Ti4冒泡赛LGD vs Liquid 1
2014/07/14 DOTA
python通过colorama模块在控制台输出彩色文字的方法
2015/03/19 Python
Python实现在线音乐播放器
2017/03/03 Python
python求解数组中两个字符串的最小距离
2018/09/27 Python
python 实现Flask中返回图片流给前端展示
2020/01/09 Python
Python 一行代码能实现丧心病狂的功能
2020/01/18 Python
对Tensorflow中tensorboard日志的生成与显示详解
2020/02/04 Python
python3 xpath和requests应用详解
2020/03/06 Python
Python 线性回归分析以及评价指标详解
2020/04/02 Python
pytorch快速搭建神经网络_Sequential操作
2020/06/17 Python
Python模块zipfile原理及使用方法详解
2020/08/04 Python
python爬取音频下载的示例代码
2020/10/19 Python
数控技术专业毕业自荐书范文
2014/02/05 职场文书
安全教育感言
2014/03/04 职场文书
党的群众路线教育学习材料
2014/05/12 职场文书
搞笑老公保证书
2015/02/26 职场文书
《雪地里的小画家》教学反思
2016/02/16 职场文书