首先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简记的更多相关文章

  1. django orm总结[转载]

    django orm总结[转载] 转载地址: http://www.cnblogs.com/linjiqin/archive/2014/07/01/3817954.html 目录1.1.1 生成查询1 ...

  2. Django ORM - 001 - 外键表查询主表信息

    开始用Django做web开发,我想大家都会遇到同样的问题,那就是如何高效快速的查询需要的数据,MVC都很简单,但是ORM折腾起来就有些费时间,我准备好好研究下Django ORM,所以会有一个系列的 ...

  3. Django ORM 中的批量操作

    Django ORM 中的批量操作 在Hibenate中,通过批量提交SQL操作,部分地实现了数据库的批量操作.但在Django的ORM中的批量操作却要完美得多,真是一个惊喜. 数据模型定义 首先,定 ...

  4. Django ORM 查询管理器

    Django ORM 查询管理器 ORM 查询管理器 对于 ORM 定义: 对象关系映射, Object Relational Mapping, ORM, 是一种程序设计技术,用于实现面向对象编程语言 ...

  5. Django ORM模型的一点体会

    作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁转载. 使用Python的Django模型的话,一般都会用它自带的ORM(Object-relational ma ...

  6. 数据库表反向生成(二) Django ORM inspectdb

    在前一篇我们说了,mybatis-generator反向生成代码. 这里我们开始说如何在django中反向生成mysql model代码. 我们在展示django ORM反向生成之前,我们先说一下怎么 ...

  7. Django ORM那些相关操作

    一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/         官网文档 常用的操作 <1> all() ...

  8. django orm 及常用参数

    一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...

  9. Django ORM中,如何使用Count来关联对象的子集数量

    示例models 解决方法 有时候,我们想要获取一个对象关联关系的数量,但是我们不要所有的关联对象,我们只想要符合规则的那些关联对象的数量. 示例models # models.py from dja ...

  10. Django ORM存储datetime 时间误差8小时问题

    今天使用django ORM 将获取到的时间入库,并未出现问题,但是后来发现时间晚了8小时,经查询Django官方文档发现获取本地时间和UTC时间有差别. 首先科普下:UTC是协调世界时 UTC相当于 ...

随机推荐

  1. solidity语言

    IDE:Atom 插件:autocomplete-solidity 代码自动补齐   linter-solium,linter-solidity代码检查错误   language-ethereum支持 ...

  2. 错误 6 未能找到类型或命名空间名称“BLL”(是否缺少 using 指令或程序集引用?)

    出现这个错误,要确保先引用BLL.dll, 如果引用之后还没有解决这个问题的话,确认一下程序集FrameWork版本与项目FrameWork版本一致.右击程序集属性可以更改.

  3. vue+rest-framework前后端分离整合(二)

    一.基于api前端显示课程详细信息 1.调整Course.vue模块 <template> <div> <h1>课程列表</h1> <div v- ...

  4. php基础--取默认值以及类的继承

    (1)对于php的默认值的使用和C++有点类似,都是在函数的输入中填写默认值,以下是php方法中对于默认值的应用: <?phpfunction makecoffee($types = array ...

  5. linux常用指令集-持续更新...

    0.查看所有java进程GC情况:for i in `jps|egrep -v "Jps|Launcher" |cut -d" " -f1`;do pwdx $ ...

  6. spring mvc&mybatis搭配使用心得

    请求参数不多时控制器方法使用@RequestParam或@PathVariable接收参数即可. 请求参数过多时使用@RequestParam指定一个map接受参数即可,mybatis查询时可以直接作 ...

  7. pb getchild获取DropDownDW子窗体后进行取值

    datawindowchild ldwc if dw_1.getchild("dwmc", ldwc) = 1 then  long ll_f  ll_f = ldwc.find( ...

  8. Profinet网络的RT/IRT容量

    轴数很多的时候,还考虑过PROFINET最大IRT容量的问题. [1]每个Profinet网络的RT个数, simition D 64 CPU 1511/1513-1 128 CPU 1515-2/1 ...

  9. python创建项目

    一.准备下载 python3.6.6 https://www.python.org/downloads/windows/(需要注意你的电脑是32位还是64位) mysql 5.1.72 https:/ ...

  10. ANT 的Table表格样式修改方法

    注:(大家在给页面添加参数或者方法的时候,记得写上注释,方便别人查看) 1.表格行选中样式添加:(可以去beijing,精子库质控统计查看例子) (咱们以前页面上的表格都是在hover时显示选中效果, ...