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

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

python数据库迁移教程_django中的数据库迁移的实现相关推荐

  1. 数据库入门教程(SQL Server 2005)----数据库是如何查询数据的

    数据库入门教程(SQL Server 2005)----数据库是如何查询数据的----查询:逻辑顺序 1.计算列 //以scott数据库中的emp表为例-----where可译为查找,其本质是在进行表 ...

  2. python数据库环境详解_python中MySQL数据库相关操作

    一 安装基本环境 1 简介 MySQL 基于TCP 协议之上的开发,但是网络连接后,传输的数据必须遵循MySQL的协议,封装好MySQL协议的包,就是驱动程序 MySQL 的驱动 MySQLDB 最有 ...

  3. wordpress 数据库_在WordPress中使用数据库

    wordpress 数据库 Out of the box, WordPress provides tons of functions that can be used to interact with ...

  4. 怎样修改游戏服务器里的数据库,修改游戏服务器中的数据库

    修改游戏服务器中的数据库 内容精选 换一换 业界对备份一致性的定义包括如下三类:不一致备份:备份的文件.磁盘不在同一个时间点.崩溃一致性备份:崩溃一致性备份会捕获备份时磁盘上已存在的数据,文件/磁盘数 ...

  5. html 连续发送数据库,不要在循环中对数据库进行操作.htm

    不要在循环中对数据库进行操作 不要在循环中对数据库进行操作 性能非常低下,应改为用IN查询 示例: 1.在循环中查询数据库,增加gv_title属性(性能低下) foreach ($res['data ...

  6. docker 数据库 mysql_在Docker中体验数据库之MySql

    在上一篇在Docker中体验数据库之Mongodb之后,这次记录一下在docker中安装mysql.过程要比Mongodb麻烦一点-- 参考网址: https://dev.mysql.com/doc/ ...

  7. 数据库入门教程(SQL Server 2005)----数据库是如何存储数据的

    作者: 大蜀黍946 数据库是如何存储数据的---外键:来自 主键:唯一的标识或者说区分开一个事物. 外键:能够标识事物之间的联系.数据来自外部 1.表的相关数据 字段:用来模拟事物的某一个静态特征. ...

  8. oracle数据库表excel文件位置,“如何将excel表格数据导入到oracle数据库对应的表中?“数据库文件导入excel表格数据库中...

    如何实现Excel表格自动导入到数据库 库?是什么数据库?sql?access?mysql?我以sql2008为例子 1.打开SQL Server Management Studio-任务-数据 2. ...

  9. Python数据分析入门教程(更新中)

    Python数据分析入门教程 你好! 这是一篇适用于初学者的Python数据分析入门教程 1. Numpy关于矩阵的操作 1.1数组与矩阵的基本概念 矩阵:矩阵是一个按照长方阵列排列的实数或复数集合( ...

最新文章

  1. 真正的AI内行盛会!3 天 3 位大神,29场专题论坛,200+位领域专家
  2. scrapy 模块功能流程--转
  3. hibernate ORM related
  4. nicetool好工具_N个办公辅助好工具,无需下载,简单实用
  5. Matlab optimtool优化(Optimization)工具箱
  6. html5 replace,js replace 与replaceall实例用法详解
  7. loj2291. 「THUSC 2016」补退选
  8. [Swift]LeetCode1106. 解析布尔表达式 | Parsing A Boolean Expression
  9. PYTHON之路(九)
  10. 学习人工智能深度学习需要掌握的python语法糖
  11. 创维机顶盒E900刷LinuxNas系统
  12. 百度钱包 java_百度钱包安全控件
  13. 基于jsp java的员工绩效考核管理系统
  14. p2p服务器系统,先锋P2P高清点播服务器(XfServer)
  15. 如何在SCI检索杂志上发表论文
  16. linux 7进入目录的命令,centos7目录统计之du命令
  17. Qpid 安装问题之qpid.messaging
  18. L0、L1、L2 范数
  19. Python实战项目:基于jupyter notebook处理16年美国总统大选数据
  20. hiho第三周 KMP

热门文章

  1. ​​​​C++:利用泰勒公式求e的x次方近似值
  2. 【通信-无线】无线设备芯片
  3. 流浪宠物救助网站前端页面_基于SSM(spring+spring mvc+mybatis)开发流浪宠物(猫狗)救助系统,项目为maven项目,后台可配置化,系统可学习性高。...
  4. 两条命令解决移动硬盘无法弹出的问题(转载 )
  5. Java怎样才是有天赋的_为什么有人会有天赋?
  6. 2018.09.23 孙悟空大战鲤鱼精(单调队列优化dp)
  7. 超全的数据可视化大屏设计组件库 sketch格式
  8. a标签href值解析
  9. 代运营线上如何获客?
  10. android 接入qq分享能力报错: java.lang.ClassNotFoundException: com.tencent.stat.StatConfig