ORM模型
一、创建及映射(orm_intro_demo文件)
- 在项目新建App下的models.py文件下新建ORM模型:
from django.db import models #如果要将一个普通的类变成一个可以映射到数据库中的ORM模型
#那么必须要将父类设置成models.Model或者他的子类
class Book(models.Model):
# id:int类型,是自增长的
id = models.AutoField(primary_key=True)
# name:varchar(100),图书的名字
name = models.CharField(max_length=100,null=False)
# author:varchar(100),作者的名字
author = models.CharField(max_length=100,null=False)
# price:float,图书的价格
price = models.FloatField(null=False,default=0) - 然后使用 makemigrations 生成迁移脚本文件,会在App的 migrations 文件下生成一个 0001_initial.py 的脚本文件:
#cmd运行
python manage.py makemigrations - 再使用 migrate 将新生成的迁移脚本文件映射数据库中:
#cmd运行
python manage.py migrate - 在数据库中将显示models.py文件代码的内容:

二、数据库的增删改查
- models.py 文件:
from django.db import models class Book(models.Model):
name = models.CharField(max_length=100,null=False)
author = models.CharField(max_length=100,null=False)
price = models.FloatField(default=0) def __str__(self):
# 查找数据时以该方式进行打印输出: <Book:(name,author,peice)>
return '<Book:({name},{author},{price})>'.format(name=self.name,author=self.author,price=self.price) - views.py 文件的 index 函数对数据库进行修改:
from django.shortcuts import render
from django.http import HttpResponse
from .models import Book def index(request):
# 1、使用ORM添加一条数据到数据库中,运行一次添加一条数据;
book = Book(name='西游记',author='吴承恩',price=100)
book.save() # 2、查询:
# 2.1、根据主键primary key进行查找
book = Book.objects.get(pk=1)
print(book)
# 2.2、根据其他条件进行查找
books = Book.objects.filter(name='西游记').first()
print(books)
#输出:<Book:(西游记,吴承恩,100.0)> # 3、删除数据
book = Book.objects.get(pk=1)
book.delete() # 4、修改数据
book = Book.objects.get(pk=2)
book.name = '三国演义'
book.author = '罗贯中'
book.save()
return HttpResponse('添加数据成功')
migrate做了哪些事:
- 将相关的迁移脚本翻译成SQL语句,在数据库中执行这个SQL语句;
- 如果这个SQL语句执行没有问题,那么就会将迁移脚本的名字记录到“django_migrations”中。
migrate怎么判断哪些迁移脚本需要执行:
- 他会将代码中的迁移脚本和数据库中的“django_migrations”中的迁移脚本进行对比,如果发现数据库中没有这个迁移脚本,那么就会执行这个迁移脚本。
执行migrate命令时报错的解决方法:
- 原因:数据库的“django_migrations”表中的迁移版本记录和代码中的迁移脚本不一致导致的。
- 解决方法:
- 使用--fake函数:首先对比数据库的迁移脚本和代码中的迁移脚本,然后找到那个不同,之后再使用“--fake”,将代码中的迁移脚本添加到“django_migrations”中,但是并不会执行SQL语句,可避免每次执行“migrate”的时候,都会执行一些重复的迁移脚本。
- 终极解决方法:如果代码中的迁移脚本和数据库中的迁移脚本太多搞不清楚,可使用此方法;
- 放弃出问题的APP的所有迁移脚本文件,再在“djang_migrations”表中将相关迁移记录删掉,(不能删除“__init__”文件);
- 将出问题的APP下的所有模型和数据库表保持一致,重新映射,使用“makemigrations”重新将模型生成一个迁移脚本;
- 可用“migrate --fake-initial”参数,将刚生成的迁移脚本文件标记为已经完成,后可继续做其它映射。
ORM模型的更多相关文章
- laravel框架总结(八) -- ORM模型
ORM模型简介 1>什么是ORM? ORM,即 Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在操作具体的 ...
- Django ORM模型的一点体会
作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁转载. 使用Python的Django模型的话,一般都会用它自带的ORM(Object-relational ma ...
- Django ORM模型:想说爱你不容易
作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁转载. 使用Python的Django模型的话,一般都会用它自带的ORM(Object-relational ma ...
- django ORM模型表的一对多、多对多关系、万能双下划线查询
一.外键使用 在 MySQL 中,如果使用InnoDB引擎,则支持外键约束.(另一种常用的MyIsam引擎不支持外键) 定义外键的语法为fieldname=models.ForeignKey(to_c ...
- django创建ORM模型、通过ORM模型操作单个表、ORM模型常用字段
一.ORM简介 ORM ,全称Object Relational Mapping,中文叫做对象关系映射,通过ORM我们可以通过类的方式去操作数据库,而不用再写原生的SQL语句.通过把表映射成类,把行作 ...
- laravel ORM 模型关联 with () 用法
关联时想对关联表数据筛选时:MySQL查询: SELECT * FROM A LEFT JOIN B ON A.B_id = B.id AND B.condition = $condition ORM ...
- 通过ORM模型看python对象创建过程
简易django ORM模型如下所示: #!/usr/bin/env python # encoding: utf-8 """ @version: 1.0 @author ...
- Eloquent ORM模型中添加自定义值
我们都知道通过Laravel中数据库查询出来的模型对象都是基于数据库字段,今天给大家展示一个 Laravel Eloquent ORM 模型特性-附加值不存在于数据表中. 举个简单的栗子,一篇文章(p ...
- ORM模型简介
ORM模型简介 1>什么是ORM? ORM,即 Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在操作具体的 ...
随机推荐
- Java9之HashMap与ConcurrentHashMap
HashMap在Java8之后就不再用link data bins了,而是转为用Treeify的bins,和之前相比,最大的不同就是利用了红黑树,所以其由 数组+链表+红黑树 组成.: * This ...
- Oracle课程档案,第九天
lsnrctl status:查看监听状态 Oracle网络配置三部分组成:客户端,监听,数据库 配置文件:$ vi $ORACLE_HOME/network/admin/listener.ora v ...
- git链接到远程github上
Git链接到自己的Github(1)简单的开始 好长时间没上来弄东西了,今天回来先开始弄下Git,之后再继续写uboot与kernel的编译,在版本控制下更加宏观地观察每次的变化. 1.在ubuntu ...
- 如何在vscode中调试python scrapy爬虫
本文环境为 Win10 64bit+VS Code+Python3.6,步骤简单罗列下,此方法可以不用单独建一个Py入口来调用命令行 安装Python,从官网下载,过程略,这里主要注意将python目 ...
- Gym 101981J - Prime Game - [数学题][线性筛+分解质因数][2018-2019 ACM-ICPC Asia Nanjing Regional Contest Problem J]
题目链接:http://codeforces.com/gym/101981/attachments 题意: 令 $mul(l,r) = \prod_{i=l}^{r}a_i$,且 $fac(l,r)$ ...
- 探究Java中的锁
一.锁的作用和比较 1.Lock接口及其类图 Lock接口:是Java提供的用来控制多个线程访问共享资源的方式. ReentrantLock:Lock的实现类,提供了可重入的加锁语义 ReadWrit ...
- JAVA spring 常用包作用详解(转)
转载地址:https://www.cnblogs.com/Tmc-Blog/p/6093162.html <project xmlns="http://maven.apache.org ...
- 【JVM】-NO.110.JVM.1 -【hsdis jitwatch 生成查看汇编代码】
Style:Mac Series:Java Since:2018-09-10 End:2018-09-10 Total Hours:1 Degree Of Diffculty:5 Degree Of ...
- Docker:使用自定义redis.conf运行redis容器(7)
演示环境:win7+docker toolbox 1.自定义配置文件 首先在Windows环境下准备好配置文件redis 然后打开Quickstart终端输入命令: cp -rf ~/Desktop/ ...
- Ngnix 配置文件
配置文件路径/usr/local/nginx/conf/nginx.conf user www www; #nginx 服务的伪用户和用户组 worker_processes auto; #启动进程, ...