时间:2021-05-23
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 数据库迁移内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Django项目默认使用sqlite数据库,但是我想用mysql数据库,应该如何配置呢。Django连接mysql数据库的操作,是通过根模块的配置实现的,在项目
本文实例讲述了php实现redis数据库指定库号迁移的方法,分享给大家供大家参考。具体如下:redis普通的数据库迁移,只能整个redissave,或者利用主从
使用django自带的AbstractUser扩展之后,更改AUTH_USER_MODEL='users.UserProfile'属性后,进行数据库迁移时,出现
ORM对象关系映射在数据库中,实现对数据的增删改查,使用的是SQ语句,在django中,通过python代码,实现对数据库的增删改查,这就是ORM。在pytho
本文实例为大家分享了Django实现分页功能,为了容易区别功能的展现,先创建一个数据库,用数据库中的数据做演示。创建数据库步骤如下:1.创建模型,代码如下:fr