2. ORM(对象关系映射)
1. 映射的关系 DB ORM 数据表 <--> 类
数据行 <--> 对象
字段 <--> 属性
2. Django项目使用MySQL数据库
1. 手动创建数据库
2. 配置数据库的连接信息
settings.py 配置 DATABASES 这个配置项
3. 用pymysql代替默认的MySQLdb
在settings.py同目录下的__init__.py文件中
import pymysql
pymysql.install_as_MySQLdb()
4. models.py中创建模型(类)
5. 执行两条命令
1. python manage.py makemigrations --> 将models.py中的改动登记到小本本上
2. python manage.py migrate --> 将改动翻译成SQL语句,去数据库执行
3. 数据库的表之间的关系
1. 外键(ForeignKey) --> 一对多(多对一)
2. 多对多(ManyToManyField) --> 通过第三张表建立多对多的关系 4. 数据库的操作(增删改查)
   1. 单表操作:
1. models.类名.objects.all() --> 查所有
2. models.类名.objects.get(id=1) --> 根据id查单条数据 3. models.类名.objects.get(id=1).delete() --> 删除单条数据 4. 修改
obj = models.类名.objects.get(id=1)
obj.name = "新名字"
obj.save() 5. 新增
models.类名.objects.create(name="张曌")
2. 外键的操作

   # 书籍
class Book(models.Model):
id = models.AutoField(primary_key=True) # 自增的主键
title = models.CharField(max_length=32) # 书籍名称 varchar(32)
publisher = models.ForeignKey(to=Publisher) # 外键关联Publisher这张表 book_obj 代表书的对象
book_obj.publisher 代表和我关联的出版社对象
book_obj.publisher.name 代表和我关联的出版社对象的名字
3. 多对多的操作
# 作者表
class Author(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=16)
# ORM创建多对多字段,会自动在数据库中创建第三张表
books = models.ManyToManyField(to=Book) author_obj --> 一个作者对象 author_obj.books.all() --> 作者出版的所有书(书籍对象的列表)
author_obj.books.set([1,2,3])--> 设置作者关联的书籍(更新的是第三张表)
第二种方式建造多对多关系的表,手动建第三张表

自己总结:
常用字段:
AotuField:会自动生成id的列
IntegerField:整数
CharField:字符类型,必须提供max_length参数
DateField: 日期字段 日期格式为 YYYY--MM--DD
DateTimeField: 日期时间字段 格式为:YYYY--MM--DD HH-MM-SS 字段参数null
可以表示某个字段为空
unique:唯一的
db_index:如果db_index=True,代表此字段设置索引
default:为该字段设置默认值
auto_now_add=True 创建数据记录的时候会把当前时间添加到数据库中 auto_now=True 每次更新数据记录时会更新该字段 on_delete
models.CASCADE:代表删除关联数据,与之关联的也删除

models.DO_NOTHING
删除关联数据,引发错误IntegrityError

models.PROTECT
删除关联数据,引发错误ProtectedError

models.SET_NULL
删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)

models.SET_DEFAULT
删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)

models.SET

删除关联数据,
a. 与之关联的值设置为指定值,设置:models.SET(值)
b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)


to_field 设置要关联的表的字段

def func():
return 10

class MyModel(models.Model):
user = models.ForeignKey(
to="User",
to_field="id",
on_delete=models.SET(func)
)  

db_constraint   在数据库中创建外键约束,默认为True




浅谈ORM操作的更多相关文章

  1. Js之浅谈dom操作

    JavaScript之浅谈dom操作 1.理解dom: DOM(Document Object Model ,文档对象模型)一种独立于语言,用于操作xml,html文档的应用编程接口. 怎么说,我从两 ...

  2. 手撸ORM浅谈ORM框架之基础篇

    好奇害死猫 一直觉得ORM框架好用.功能强大集众多优点于一身,当然ORM并非完美无缺,任何事物优缺点并存!我曾一度认为以为使用了ORM框架根本不需要关注Sql语句如何执行的,更不用关心优化的问题!!! ...

  3. 手撸ORM浅谈ORM框架之Add篇

    快速传送 手撸ORM浅谈ORM框架之基础篇 手撸ORM浅谈ORM框架之Add篇 手撸ORM浅谈ORM框架之Update篇 手撸ORM浅谈ORM框架之Delete篇 手撸ORM浅谈ORM框架之Query ...

  4. 手撸ORM浅谈ORM框架之Update篇

    快速传送 手撸ORM浅谈ORM框架之基础篇 手撸ORM浅谈ORM框架之Add篇 手撸ORM浅谈ORM框架之Update篇 手撸ORM浅谈ORM框架之Delete篇 手撸ORM浅谈ORM框架之Query ...

  5. 手撸ORM浅谈ORM框架之Delete篇

    快速传送 手撸ORM浅谈ORM框架之基础篇 手撸ORM浅谈ORM框架之Add篇 手撸ORM浅谈ORM框架之Update篇 手撸ORM浅谈ORM框架之Delete篇 手撸ORM浅谈ORM框架之Query ...

  6. 手撸ORM浅谈ORM框架之Query篇

    快速传送 手撸ORM浅谈ORM框架之基础篇 手撸ORM浅谈ORM框架之Add篇 手撸ORM浅谈ORM框架之Update篇 手撸ORM浅谈ORM框架之Delete篇 手撸ORM浅谈ORM框架之Query ...

  7. 从JS和jQuery浅谈DOM操作,当我们在获取时,究竟获取了什么

    0.写在前面的话 自己对前端的东西一直不是很熟,现在开始要想办法从前端各个地方去获取想要的属性值的时候,也基本是在网上现炒现卖,几周下来,发现自己还是迷迷糊糊,可以算是一无所获. 所以就抽时间,把这一 ...

  8. linux的浅谈io操作

    系统默认设定 名称类型文件描述符操作标准输入standard input0<,<< 标准输出standard output1>,>> 标准错误输出standard ...

  9. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

随机推荐

  1. Android广播接收者

    其实,在什么是广播的第一句就已经说明了广播有什么用了.对了,笼统一点讲就是用来传输数据的.具体一点说就是:1. 实现了不同的程序之间的数据传输与共享,因为只要是和发送广播的action相同的接受者都能 ...

  2. Consumer设计-high/low Level Consumer

    1 Producer和Consumer的数据推送拉取方式   Producer Producer通过主动Push的方式将消息发布到Broker n Consumer Consumer通过Pull从Br ...

  3. 单选与复选控件JRadioButton与JCheckBox的使用

    -----------------siwuxie095 工程名:TestUI 包名:com.siwuxie095.ui 类名:TestTextFieldAndTextArea.java 工程结构目录如 ...

  4. ROS探索总结(五)——创建简单的机器人模型smartcar

    前面我们使用的是已有的机器人模型进行仿真,这一节我们将建立一个简单的智能车机器人smartcar,为后面建立复杂机器人打下基础. 一.创建硬件描述包 roscreat-pkg  smartcar_de ...

  5. Node 中的 stream (流)

    流的概念 流(stream)在 Node.js 中是处理流数据的抽象接口(abstract interface). stream 模块提供了基础的 API .使用这些 API 可以很容易地来构建实现流 ...

  6. R: 自定义函数

    ################################################### 问题:自定义函数   18.4.29 自定义函数,其返回值是个问题,还有怎么让过程变量成为全局变 ...

  7. Help Bubu UVALive - 4490

    传送门 题目大意 有n本书,最多k次操作,每次操作可以把一本书拿出来,放到一个位置去,有一个指标较mess度,他是书的高度的段数,连续的书高度一样算一段,现在给你最先开始各个位置上的书的高度,求操作后 ...

  8. 找BUG

    找一找BUG 一段代码,实现一个pop,push,和getmin都是O(1)的方法. 最初源代码 伙伴代码如下,代码的地址可以通过这个访问: Ubuntu Pastebin https://paste ...

  9. Html.DropDownListFor 练习

    需要创建一个List<SelectListItem>数据集,如下 使用已经存在FruitCategoryEntity.cs类的IEnumerable<FruitCategory> ...

  10. Binder学习笔记(五)—— Parcel是怎么打包数据的?

    前文中曾经遇到过Parcel,从命名上知道他负责数据打包.在checkService的请求/响应体系中,Parcel只打包了基本数据类型,如Int32.String16……后面还要用于打包抽象数据类型 ...