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中建立模型类,示例:

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

来源:https://www.cnblogs.com/lutt/p/10634563.html

标签:django,数据库迁移
0
投稿

猜你喜欢

  • Python写入CSV文件的方法

    2021-08-21 19:09:44
  • 网页HTTP header头信息详解

    2010-03-31 14:42:00
  • ORACLE 10g 安装教程[图文]

    2009-05-24 19:12:00
  • 对Python使用mfcc的两种方式详解

    2023-06-04 14:56:52
  • 详解Django框架中用户的登录和退出的实现

    2022-08-28 19:37:19
  • pytorch中index_select()的用法详解

    2022-01-20 19:44:05
  • Python解析并读取PDF文件内容的方法

    2021-07-13 20:06:21
  • 在Python中使用defaultdict初始化字典以及应用方法

    2021-01-05 02:03:02
  • Python安装docx依赖包教程

    2023-02-11 22:23:36
  • Pycharm基本操作及调试代码

    2022-08-13 08:38:55
  • 如何在事件代理中正确使用 focus 和 blur 事件

    2010-01-30 12:51:00
  • Python实现自动发送邮件功能

    2021-04-01 14:41:55
  • python遍历序列enumerate函数浅析

    2022-10-31 01:34:21
  • Bootstrap3制作自己的导航栏

    2023-08-23 02:13:08
  • 计算机科学中32个常用的基础算法

    2023-01-25 16:50:19
  • Python3.6安装及引入Requests库的实现方法

    2022-06-12 16:55:46
  • MySQL 整表加密解决方案 keyring_file详解

    2024-01-18 07:50:31
  • Golang接口使用教程详解

    2024-02-14 02:22:11
  • MSSQL数据类型

    2008-08-03 17:21:00
  • meta标签之详解

    2008-01-13 18:48:00
  • asp之家 网络编程 m.aspxhome.com