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使用电子邮件模块smtplib的方法
Aug 28 Python
Django跨域请求CSRF的方法示例
Nov 11 Python
python实现转圈打印矩阵
Mar 02 Python
python 实现12bit灰度图像映射到8bit显示的方法
Jul 08 Python
python实现连续变量最优分箱详解--CART算法
Nov 22 Python
浅析python,PyCharm,Anaconda三者之间的关系
Nov 27 Python
tensorflow中tf.slice和tf.gather切片函数的使用
Jan 19 Python
Python使用qrcode二维码库生成二维码方法详解
Feb 17 Python
Python如何脚本过滤文件中的注释
May 27 Python
Python如何在循环内使用list.remove()
Jun 01 Python
pycharm中如何自定义设置通过“ctrl+滚轮”进行放大和缩小实现方法
Sep 16 Python
LyScript实现绕过反调试保护的示例详解
Aug 14 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
Zerg剧情介绍
2020/03/14 星际争霸
一些常用的php函数
2006/12/06 PHP
PHP模板引擎Smarty中的保留变量用法分析
2016/04/11 PHP
JavaScript 利用StringBuffer类提升+=拼接字符串效率
2009/11/24 Javascript
基于Jquery的文字自动截取(提供源代码)
2011/08/09 Javascript
js与运算符和或运算符的妙用
2014/02/14 Javascript
jQuery中animate动画第二次点击事件没反应
2015/05/07 Javascript
浅谈jQuery的offset()方法及示例分享
2015/07/17 Javascript
JS两个数组比较,删除重复值的巧妙方法(推荐)
2016/06/03 Javascript
非常实用的js验证框架实现源码 附原理方法
2016/06/08 Javascript
jquery实现网站列表切换效果的2种方法
2016/08/12 Javascript
JS使用正则实现去掉字符串左右空格的方法
2016/12/27 Javascript
Angular实现购物车计算示例代码
2017/02/21 Javascript
js循环map 获取所有的key和value的实现代码(json)
2018/05/09 Javascript
从源码里了解vue中的nextTick的使用
2018/11/22 Javascript
vue 父组件通过v-model接收子组件的值的代码
2019/10/27 Javascript
JavaScript实现放大镜效果代码示例
2020/04/29 Javascript
python如何把嵌套列表转变成普通列表
2018/03/20 Python
Python实现爬取马云的微博功能示例
2019/02/16 Python
python3.6使用tkinter实现弹跳小球游戏
2019/05/09 Python
python修改字典键(key)的方法
2019/08/05 Python
python 统计文件中的字符串数目示例
2019/12/24 Python
python 画图 图例自由定义方式
2020/04/17 Python
django在开发中取消外键约束的实现
2020/05/20 Python
python 基于DDT实现数据驱动测试
2021/02/18 Python
python lambda的使用详解
2021/02/26 Python
DKNY品牌官网:纽约大都会时尚风格
2016/10/20 全球购物
Yahoo-PHP面试题2
2014/12/06 面试题
优秀毕业生推荐信
2013/11/02 职场文书
自荐信格式简述
2014/01/25 职场文书
高中军训感言200字
2014/02/23 职场文书
2014年管理工作总结
2014/11/22 职场文书
2016年春节问候语
2015/11/11 职场文书
微软Win11有哪些隐藏功能? windows11多个功能汇总
2021/11/21 数码科技
Python字符串格式化方式
2022/04/07 Python
centos7安装mysql5.7经验记录
2022/05/02 Servers