一、ORM-操作
基本操作包括增删改查,即(CRUD)操作
CRUD是指在做计算处理时增加(create)、读取查询(read)、更新(update)、删除(delete)
ORM CRUD 核心 - > 模型类管理对象
 
二、管理器对象
每个继承自models.Model的模型类,都会有一个objects对象被同样继承下来,这个对象叫管理器对象
 
数据库的增删改查可以通过模型的管理器实现
 
三、创建数据
Django ORM 使用一种直观的方式把数据库表中的数据表示成python对象
创建数据中每一条记录就是创建一个数据对象
方案1.MyModel.objects.create(属性1=值1,属性2=值2...)

方案2. 创建MyModel实例对象,并调用save进行保存
obj = MyModel(属性=值,属性=值)
obj.属性=值
obj.save()
四、Django Shell
在Django提供了一个交互式的操作项目叫做Django Shell 它能在交互模式用项目工程的代码执行相应的操作
利用Django shell 可以代替编写view的代码来直接进行操作
注意:项目代码发生变化时,重新进入Django shell
 
启动方式: 项目下 python3 manage.py shell
 
使用方式1
在shell内 导入需要操作的model
from 应用名.models import 模型类名
s = Book.objects.create(title='python')
然后会数据库插入一条title为python的数据
使用方式2.
在shell内 导入需要操作的model
from 应用名.models import 模型类名
s = Book(title='python')
s.title = 'python'
s.save()
然后会数据库插入一条title为python的数据
在views视图可以用同样的方式进行数据库操作
 
 
五、查询简介
数据库的查询需要使用管理器对象进行
通过MyModel.objects管理器方法调用查询方法
只要是模型类,就有objects对象
 
常用方法:
常用方法:
all()
用法:MyModel.objects.all()
作用:查询MyModel实体中所有的数据
等同于select * from table;
返回值:QuerySet容器对象内部存放MyModel实例 values('列1','列2'..)
用法:MyModel.objcts.values(..)
作用:查询部分列的数据并返回
等同于select 列1,列2 from xxx
返回值:QuerySet
返回查询结果容器,容器内存字典,每个字典代表一条数据
格式:{'列1':值1,'列2':值2} values_list('列1','列2'..)
用法:MyModel.objects.values_list()
作用:返回元组形式的查询结果
等同于 select 列1,列2 from xxx
返回值:QuerySet容器对象,内部存放元组
会将查询出来的数据封装到元组中,再封装到查询集合QuseySet中 order_by()
用法:MyModel.object.order_by('-列','列')
作用:与all()方法不同,它会用sql语句order by子句对查询结果根据某个字段选择性的进行排序
说明:默认是按照升序排序,降序排序需要在列名前面加 ‘-’表示 MyModel.query:可以输出对应方法对应的sql语句
 
在模型类中定义__str__方法,可以自定义QuerySet中的输出格式
def __str__(self):
return f'{self.title}{self.name}'
 

11.-ORM-基本操作-创建数据的更多相关文章

  1. pandas学习(创建数据,基本操作)

    pandas学习(一) Pandas基本数据结构 Series类型数据 Dataframe类型 基本操作 Pandas基本数据结构 两种常用数据结构: Series 一维数组,与Numpy中的一维ar ...

  2. A.CTable 自动创建数据表

    1.添加依赖 <!-- A.CTable 自动创建数据表 --> <dependency> <groupId>com.gitee.sunchenbin.mybati ...

  3. ORM基本操作回顾

    连接数据库 默认是MySQLdb 指定引擎 dialect[+driver]: //user:password@host/dbname[?key=value..]: from sqlalchemy i ...

  4. 9.11 翻译系列:数据注解特性之--Timestamp【EF 6 Code-First系列】

    原文链接:https://www.entityframeworktutorial.net/code-first/TimeStamp-dataannotations-attribute-in-code- ...

  5. 创建数据表,自定义data element, field等。

    参考:https://wenku.baidu.com/view/253ddbfaa5e9856a561260da.html 一:创建域. 使用T-CODE 11 搜索 数据操作系统. 选择domain ...

  6. 模拟主库创建数据文件,dg备库空间不足时问题处理

    本篇文档测试目的: 模拟实际环境中,主库对表空间添加数据文件,备库空间不足,最终导致MRP进程自动断开,处理方式. 1.问题环境模拟 1)正常情况下的dg 主库创建数据文件,备库接受日志,自动创建表空 ...

  7. mysql之创建数据库,创建数据表

    写在前面 项目中用到mysql数据库,之前也没用过mysql,今天就学下mysql的常用的语法,发现跟sql server的语法极其相似.用起来还是蛮简单的. 一个例子 1.创建一个名为School的 ...

  8. ORM之创建数据库

    ORM之创建数据库 样板:创建表名为UserInfo的表,表的主键可自行写,Django的ORM也可自行创建. from django.db import models class UserInfo( ...

  9. SpringBoot+Mybatis 自动创建数据表(适用mysql)

    Mybatis用了快两年了,在我手上的发展史大概是这样的 第一个阶段 利用Mybatis-Generator自动生成实体类.DAO接口和Mapping映射文件.那时候觉得这个特别好用,大概的过程是这样 ...

随机推荐

  1. 大数据平台迁移实践 | Apache DolphinScheduler 在当贝大数据环境中的应用

    大家下午好,我是来自当贝网络科技大数据平台的基础开发工程师 王昱翔,感谢社区的邀请来参与这次分享,关于 Apache DolphinScheduler 在当贝网络科技大数据环境中的应用. 本次演讲主要 ...

  2. Unity 将是驱动 C# 增长的引擎吗 ?

    C# 在中国的采用需要一个杀手级应用的带动, 那么这样的一个杀手级应用是 Unity吗,我这里大胆推测采用CoreCLR 的新一代完全采用C#构建的Unity 将是这样的一个杀手级应用.Unity已被 ...

  3. PerfView专题 (第七篇):如何洞察触发 GC 的 C# 代码?

    一:背景 上一篇我们聊到了如何用 PerfView 洞察 GC 的变化,但总感觉还缺了点什么? 对,就是要跟踪到底是什么代码触发了 GC,这对我们分析由于 GC 导致的 CPU 爆高有非常大的参考价值 ...

  4. ABC 203 F - Weed (DP)

    ABC203F - Weed 题意转述 S t e v e \rm Steve Steve 和 A l e x \rm Alex Alex 正在下界( N e t h e r l e n d \rm ...

  5. 【AGC】如何使用认证服务与云数据库处理用户信息

    ​使用场景 华为 AGC认证服务可以为应用快速构建安全可靠的用户认证系统,可以实现多种方式关联认证登录.而如何处理这些多种登录方式的用户信息,例如在应用中发布一个活动,哪些用户参加了哪一个活动,这些信 ...

  6. 【读书笔记】C#高级编程 第十六章 错误和异常

    (一)简介 错误的出现并不总是编写应用程序的人的原因,有时应用程序会因为应用程序的最终用户引发或运行代码的环境而发生错误.C#提供了异常处理机制来处理错误. (二)异常类 在C#中,但刚出现某个特殊的 ...

  7. Netty 学习(一):服务端启动 & 客户端启动

    Netty 学习(一):服务端启动 & 客户端启动 作者: Grey 原文地址: 博客园:Netty 学习(一):服务端启动 & 客户端启动 CSDN:Netty 学习(一):服务端启 ...

  8. 聊聊单点登录(SSO)中的CAS认证

    SSO介绍 背景 随着企业的发展,一个大型系统里可能包含 n 多子系统, 用户在操作不同的系统时,需要多次登录,很麻烦,我们需要一种全新的登录方式来实现多系统应用群的登录,这就是单点登录. web 系 ...

  9. 2021年3月-第02阶段-前端基础-Flex 伸缩布局-移动WEB开发_流式布局

    移动web开发流式布局 1.0 移动端基础 1.1 浏览器现状 PC端常见浏览器:360浏览器.谷歌浏览器.火狐浏览器.QQ浏览器.百度浏览器.搜狗浏览器.IE浏览器. 移动端常见浏览器:UC浏览器, ...

  10. c语言字符串比较与bool型

    c++字符串string,定义的变量,能够通过比较符号,直接进行比较. 而c语言则不能通过char数组定义的变量,来直接比较.应用下面的方法: #include <string.h> in ...