django-orm简记
首先orm是什么?
orm-------->对象关系映射
专业性解释网上一大推,随便搜搜就能了解大概。
在我理解(通俗):一个类 ----- 数据库中一张表
类属性 ----- 数据表中的字段名
实例一个对象 --- 表里的一条记录 orm的原理现在还没搞懂,它是具体怎么实现的,大概就是将python语句进行转换,转换成spl语句,原理就是执行sql语句
后面我会继续更新orm。
下面大概简单的记录下它的用法!
orm一般在app文件夹中的models.py文件书写
写一个类,其类名就是那张表的名字,但是django会给你进行封装,将APP01_类名去命名,
单单写一个类是完全不行的,必须继承 models.Model 这个类才行,继续它你就可以使用基类的一个方法。
下面我简单写一个用户表,写写注释 class User(models.Model): ##AutoField代表自增字段(数据库中int),primary_key 主键
id = models.AutoField(primary_key=True) ##CharField代表数据库中varchar,必须给它设置长度
name = models.CharField(max_length=32)
password = models.CharField(max_length=32)
orm写好了,但是要怎样才能将数据迁移到数据库呢?
下面还要继续执行两条命令昨天写了一种方式,今天写另外一种,命令都是一样的 Tools --> run manage.py task --> 输入:makemigrations(将新增的orm操作记录下来)
-->继续输入:migrate(执行之前的记录)
这个有个好处就是,你记住不住单词没关系,他会给你提示,执行完毕数据就迁移到了数据库
如果你之前设计表,没有设计好,想在原表的基础上改字段,删字段,增加字段的话:
1、有一个操作就是永远不会变的,就是执行两条命令,把数据更新到数据库中
2、改、删字段,,直接在类中改属性就行了,删除的话,直接删除那属性就好了或注释掉
3、增加字段,,先在类中增加属性,然后执行两条迁移命令,但是这时弹出的信息会和之前不一样,没关系。
##会有1、2两条信息,会有这两条信息的原因就是:
假如你之前数据库已经有一万多条数据,这时你增加一个字段,那么你觉得你之前一万条数据该字段(你新增的)会
怎么办?空在那里,还是给那么添加一个默认值呢?
所以这两条信息就是让你给原有的数据给该字段添加默认值:
选项一:就是让你直接再命名界面中指定默认值就行
选项二:在原有orm中添加默认值default=什么值。写好了之后再执行那两条迁移命名
orm设计好了之后,它作用在views视图里的,所以在视图函数那个文件中,必须导入orm from...import...
from app01 import models 导入之后,我们就可以通过models.类名-------->相当于连接到数据数据表 models.User.object.all() ------> select * from User;
models.User.object.filter(id=2).first() -----> select * from User where id=2;
models.User.object.filter(id=2).delete() ##删除id=1的记录
models.User.object.filter(id=2).update(name=name, address=address) ##修改记录 创建记录的两种方法
1、、models.User.object.create(name='zhuyu',address='cq')
2、、user = models.User(name='zhuyu',address='cq')
user.save() ##这里要提醒下user = models.User.object.filter(id=2) 这句代码它有返回值
user是一个QuerySet类
<class 'django.db.models.query.QuerySet'>
有个小习惯,你把上面类似执行的代码,赋给一个变量,你在打印,并打印它的类型,知道返回的是什么
django请求的生命周期: 1、首先用户在客户端(浏览器)向服务端发出请求,并携带所有相关的数据
2、两台机器通信基于socket通信,在服务端获取到请求过来的数据,进行一系列处理,处理得到的数据就有url,
3、通过url在django中urls.py找到对应的视图函数,
4、转到该视图函数中,进行一些逻辑代码执行,中间可能回到数据库中取到数据,在模板文件夹中拿到模板,进行模板渲染,
渲染完成之后,然后将渲染好的模板封装到HttpResponse中,返回回去
5、这样客户端(浏览器)就能收到数据,显示到页面上
django-orm简记的更多相关文章
- django orm总结[转载]
django orm总结[转载] 转载地址: http://www.cnblogs.com/linjiqin/archive/2014/07/01/3817954.html 目录1.1.1 生成查询1 ...
- Django ORM - 001 - 外键表查询主表信息
开始用Django做web开发,我想大家都会遇到同样的问题,那就是如何高效快速的查询需要的数据,MVC都很简单,但是ORM折腾起来就有些费时间,我准备好好研究下Django ORM,所以会有一个系列的 ...
- Django ORM 中的批量操作
Django ORM 中的批量操作 在Hibenate中,通过批量提交SQL操作,部分地实现了数据库的批量操作.但在Django的ORM中的批量操作却要完美得多,真是一个惊喜. 数据模型定义 首先,定 ...
- Django ORM 查询管理器
Django ORM 查询管理器 ORM 查询管理器 对于 ORM 定义: 对象关系映射, Object Relational Mapping, ORM, 是一种程序设计技术,用于实现面向对象编程语言 ...
- Django ORM模型的一点体会
作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁转载. 使用Python的Django模型的话,一般都会用它自带的ORM(Object-relational ma ...
- 数据库表反向生成(二) Django ORM inspectdb
在前一篇我们说了,mybatis-generator反向生成代码. 这里我们开始说如何在django中反向生成mysql model代码. 我们在展示django ORM反向生成之前,我们先说一下怎么 ...
- Django ORM那些相关操作
一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/ 官网文档 常用的操作 <1> all() ...
- django orm 及常用参数
一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...
- Django ORM中,如何使用Count来关联对象的子集数量
示例models 解决方法 有时候,我们想要获取一个对象关联关系的数量,但是我们不要所有的关联对象,我们只想要符合规则的那些关联对象的数量. 示例models # models.py from dja ...
- Django ORM存储datetime 时间误差8小时问题
今天使用django ORM 将获取到的时间入库,并未出现问题,但是后来发现时间晚了8小时,经查询Django官方文档发现获取本地时间和UTC时间有差别. 首先科普下:UTC是协调世界时 UTC相当于 ...
随机推荐
- continue break return
ontinue: 可以让程序跳过,continue关键字之后的语句,回到while循环的第一行命令 break: 让程序完全跳出循环,结束while循环的执行 return: 从查询或过程中无条件退出 ...
- linux shell之for循环
两种方式 第一种 for((i=1;i<10;i++)) do echo $i done 第二种 for i in {1..10} do echo $i done
- 重构指南 - 移除重复内容(Remove Duplication)
在项目中或多或少的都存在着重复的或者功能相似的代码,如果要对代码做改动,就要修改多个地方,所以我们需要将多处重复的代码提取到一个公共的地方供统一调用,以减少代码量,提高代码可维护性. 重构前代码 pu ...
- Cocos2d-js 开发记录:声音播放
声音播放可以使用cc.audioEngine,需要播放的文件在resource.js中进行添加如: button_press_mp3: "res/audio/press.mp3", ...
- SQLAlchemy的使用---数据库的创建与连接
# 1. 导入SQLAlchemy from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Col ...
- Required Integer parameter 'XXX' is not present
1.异常提示: DEBUG o.s.w.s.m.m.a.ServletInvocableHandlerMethod - Error resolving argument [2] [type=java. ...
- .Net中会存在内存泄漏吗
所谓内存泄露就是指一个不再被程序使用的对象或变量一直被占据在内存中..Net 中有垃圾回收机制,它可以保证一对象不再被引用的时候,即对象编程了孤儿的时候,对象将自动被垃圾回收器从内存中清除掉.虽然.N ...
- Informatica 9.1.0 Domain地址变化修改
由于公司机房的变动,infa所连数据库的IP地址变化,致使INFA不能启动.经过查找资料终于解决,现分享给大家,解决方法如下: 1.查看日志路径: Informatica/9.1.0/tomcat/l ...
- js如何完整的显示较长的数字
试试下面一行吧 Math.pow(10, 99).toLocaleString().split(',').join('') toLocaleString([character]) 方法会将其对象转换成 ...
- vscode 显示"没有活动的源代码控制提供程序“处理
不知为何我的 VS Code 在 1.25 版本开始就一直 ”没有活动的源代码控制提供程序“,找了好几天都没找到,今天终于找到怎么处理了, 切换到插件中找到下图对应的 Git (可以直接再上面搜索框输 ...