Django之ORM

ORM全称对象关系映射

作用:通过python面向对象的代码简单快捷的操作数据库,但是封装程度太高,有时候sql语句的效率偏低,需要自己写sql语句

类----->表

对象--->记录

对象属性--->记录某个字段对应的值

写在models.py文件

1.先在models.py中书写一个类

from django.db import models# Create your models here.
class Mytable(models.Model):id=models.AutoField(primary_key=True)#由于一张表中必须有一个主键字段,并且一般情况下都叫id字段#所以orm在当你不定义主键字段的时候,orm都会自动帮你创建一个名为id的主键字段#也就是说我们在创建模型表的时候如果主键名字没有别的叫法(比如你要叫cid就需要自己写),#那么主键字段可以省略不写name=models.CharField(max_length=32,verbose_name='用户名')#CharField必须指定max_length参数,不指定会直接报错#verbose_name是所有字段都有的,用来对字段的解释password=models.IntegerField(verbose_name='密码')

2.数据库迁移命令

2.1 在terminal中输入命令: python manage.py makemigrations

意思是将操作的记录记录到  migrations文件夹,在这文件夹下会多出一个文件

之后输入python manage.py migrate ,执行数据库迁移命令后会自动创建表

只要修改了models.py中跟数据库相关的代码,就必须重新执行上述两条命令。

2.2 偷懒输入这两句数据库迁移命令,与上一个效果一样(建议上一个命令熟练后再使用这个)

只需要输入makemigrations

                  migrate

orm字段的增删改查

字段的增加

1.在类中写好字段代码后,可以在终端内直接给出默认值

选择1给增加的字段添加默认值,选择2退出自己去代码中增加

2.该字段可以为空,null=Ture

age=models.IntegerField(null=True)

3.直接给字段设置默认值

age=models.IntegerField(default='18')

字段的修改

直接修改代码代码然后执行数据库迁移的两条命令即可

字段的删

直接注释对应的字段然后执行数据库的两条命令即可

注意:执行完毕之后字段对应的数据也都没有了,在操作models.py的时候一定要细心,执行迁移命令之前最好检查好代码

建议当你离开你的计算机之后一定要锁屏

数据的增删改查

第一种

res=models.User.objects.filter(username=username)
返回值先看成是列表套数据对象的格式
它支持索引取值 切片操作 但不支持负数索引
也不推荐使用索引取值
user_obj=models.User.objects.filter(username=username).first()

 第二种

    user_queryset=models.User.objects.all()return render(request,'userlist.html',locals())

第一种方式

 from app01 import modelsres=models.User.objects.create(username=username,password=password)
返回值就是当前被创建的对象本身print(res,res.username,res.password)

第二种方式

user_obj=models.User(username=username,password=password)
user_obj.save() #保存数据

改        

<a href="/edit_user/?user_id={{ user_obj.id }}" >编辑</a>
拼接一个url的路径?user_id
然后更新数据
models.User.objects.filter(id=edit_id).update(username=username,password=password)

models.User.objects.filter(id=delete_id).delete()

补充:真正的删除功能需要二次确认,删除功能内部其实不是真正的删除,我们会给数据添加一个标识字段用来表示数据是否被删除了,如果数据被删了仅仅只是讲字段修改一个状态

ORM创建表关系

表关系:一对一,一对多,多对多

例:图书表,出版社表,作者表,作者详情表

利用orm创建表关系代码如下

from django.db import modelsclass Book(models.Model):title=models.CharField(max_length=32)price=models.DecimalField(max_digits=8,decimal_places=2)#图书和出版社是一对多,外键字段放在多的里,也就是图书表里publish=models.ForeignKey(to='Publish',on_delete=models.CASCADE,null=True, blank=True, default=None)#会自动在publish后加_id#图书和作者是多对多,外键字段在任意一方,建议放在使用频率较多的一方authors=models.ManyToManyField(to='Author')#authors是一个虚拟字段,主要用来告诉orm,图书表和作者表是多对多关系,让orm自动帮你创建第三张表
class Publish(models.Model):name=models.CharField(max_length=32)addr=models.CharField(max_length=32)class Author(models.Model):name=models.CharField(max_length=32)age=models.IntegerField()#作者和作者详情是一对一的关系,外键字段建在任意一方都可以,建议建在查询频率较高的表author_detail=models.OneToOneField(to='AuthorDetail',on_delete=models.CASCADE,null=True, blank=True, default=None)
class AuthorDetail(models.Model):phone=models.BigIntegerField()addr=models.CharField(max_length=32)

注意:Django2.0以上版本,orm创建表关系,在一对一和创建主键时需要加上

on_delete=models.CASCADE,null=True, blank=True, default=None

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/206264.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Webhook端口中的自签名身份验证

概述 有时&#xff0c;可能需要通过 Webhook 端口从交易伙伴处接收数据&#xff0c;但该交易伙伴可能需要更多的安全性&#xff0c;而不仅仅是用于验证入站 Webhook 请求的基本身份验证用户名/密码 – 或者您可能只想在入站 Webhook 消息上添加额外的安全层。 使用 Webhook 端…

LeetCode(44)存在重复元素 II【哈希表】【简单】

目录 1.题目2.答案3.提交结果截图 链接&#xff1a; 存在重复元素 II 1.题目 给你一个整数数组 nums 和一个整数 k &#xff0c;判断数组中是否存在两个 不同的索引 i 和 j &#xff0c;满足 nums[i] nums[j] 且 abs(i - j) < k 。如果存在&#xff0c;返回 true &#xf…

Maven 简单配置阿里云镜像

配置步骤&#xff1a; 1、找到 maven 的安装目录&#xff0c;修改settings.xml 2、在文件中找到<mirrors>标签&#xff0c;然后再标签中添加阿里云配置即可 <mirror><id>aliyunmaven</id><mirrorOf>*</mirrorOf><name>阿里云公共…

C# Onnx 百度飞桨开源PP-YOLOE-Plus目标检测

目录 效果 模型信息 项目 代码 下载 C# Onnx 百度飞桨开源PP-YOLOE-Plus目标检测 效果 模型信息 Inputs ------------------------- name&#xff1a;image tensor&#xff1a;Float[1, 3, 640, 640] name&#xff1a;scale_factor tensor&#xff1a;Float[1, 2] ----…

Flash学习

FLASH介绍 FLASH是常用的&#xff0c;用于存储数据的半导体器件&#xff0c;它具有容量大&#xff0c;可重复擦写&#xff0c;按“扇区/块”擦除、掉电后数据可继续保存的特性。 常见的FLASH有NOR FLASH和NAND FLASH。 NOR和NAND是两种数字门电路&#xff0c;可以简单地认为F…

进程间通信基础知识【Linux】——上篇

目录 一&#xff0c;理解进程之间的通信 1. 进程间通信目的 2. 进程间通信的技术背景 3&#xff0c;常见的进程间通信 二&#xff0c;管道 1. 尝试建立一个管道 管道的特点&#xff1a; 管道提供的访问控制&#xff1a; 2. 扩展&#xff1a;进程池 阶段一&#xff1a…

synchronized 关键字

目录 1 synchronized 的特性 1&#xff09;互斥 2) 刷新内存&#xff08;内存可见性&#xff09; 3) 可重入 2 synchronized 使用示例 1) 直接修饰普通方法: 2) 修饰静态方法: 3) 修饰代码块: .3 Java 标准库中的线程安全类 1 synchronized 的特性 1&#x…

【Python数据结构与算法】--- 递归算法的应用 ---[乌龟走迷宫] |人工智能|探索扫地机器人工作原理

&#x1f308;个人主页: Aileen_0v0 &#x1f525;系列专栏:PYTHON数据结构与算法学习系列专栏&#x1f4ab;"没有罗马,那就自己创造罗马~" 目录 导言 解决过程 1.建立数据结构 2.探索迷宫: 算法思路 递归调用的“基本结束条件” 3.乌龟走迷宫的实现代码: …

phpstudy和IDEA 配置php debug

1.安装xdebug 扩展&#xff0c;phpinfo() 查看 2.配置php.ini zend_extensionD:/phpstudy_pro/Extensions/php/php7.4.3nts/ext/php_xdebug.dll xdebug.collect_params1 xdebug.collect_return1 xdebug.auto_traceOn xdebug.trace_output_dirD:/phpstudy_pro/Extensions/php_l…

3.OpenResty系列之Nginx反向代理

1. Nginx简介 Nginx (engine x) 是一款轻量级的 Web 服务器 、反向代理服务器及电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器 什么是反向代理&#xff1f; 反向代理&#xff08;Reverse Proxy&#xff09;方式是指以代理服务器来接受 internet 上的连接请求&#x…

Web安全漏洞分析-XSS(上)

随着互联网的迅猛发展&#xff0c;Web应用的普及程度也愈发广泛。然而&#xff0c;随之而来的是各种安全威胁的不断涌现&#xff0c;其中最为常见而危险的之一就是跨站脚本攻击&#xff08;Cross-Site Scripting&#xff0c;简称XSS&#xff09;。XSS攻击一直以来都是Web安全领…

springboot+vue项目如何集成onlyoffice开源文档组件

一、onlyoffice是什么 ONLYOFFICE 是一个开源的办公套件&#xff0c;适合多人在线协作。由总部位于总部在拉脱维亚的 IT 公司Acensio System SIA 开发。它提供在线协作文档编辑器&#xff08;包括文档、电子表格、演示文稿和表单&#xff09;&#xff0c;适用于 Windows、Linu…

Python with提前退出:坑与解决方案

Python with提前退出&#xff1a;坑与解决方案 问题的起源 早些时候使用with实现了一版全局进程锁&#xff0c;希望实现以下效果&#xff1a; Python with提前退出&#xff1a;坑与解决方案 全局进程锁本身不用多说&#xff0c;大部分都依靠外部的缓存来实现的&#xff0c;r…

进阶C语言-字符函数和字符串函数

字符函数和字符串函数 &#x1f388;1.函数介绍&#x1f50e;1.1strlen函数&#x1f52d;1.1.1strlen函数的模拟实现&#x1f4d6;1.计数器法&#x1f4d6;2.递归法&#x1f4d6;3.指针-指针 &#x1f50e;1.2strcpy函数&#x1f52d;1.2.1strcpy函数的模拟实现 &#x1f50e;1…

【机器学习】算法性能评估常用指标总结

考虑一个二分问题&#xff0c;即将实例分成正类&#xff08;positive&#xff09;或负类&#xff08;negative&#xff09;。对一个二分问题来说&#xff0c;会出现四种情况。如果一个实例是正类并且也被 预测成正类&#xff0c;即为真正类&#xff08;True positive&#xff0…

1.前端--基本概念【2023.11.25】

1.网站与网页 网站是网页集合。 网页是网站中的一“页”&#xff0c;通常是 HTML 格式的文件&#xff0c;它要通过浏览器来阅读。 2.Web的构成 主要包括结构&#xff08;Structure&#xff09; 、表现&#xff08;Presentation&#xff09;和行为&#xff08;Behavior&#xff…

【深度学习】DAMO-YOLO,阿里,701类通用检测模型,目标检测

https://github.com/tinyvision/DAMO-YOLO/blob/master/README_cn.md DAMO-YOLO是由阿里巴巴达摩院智能计算实验室TinyML团队开发的一个兼顾速度与精度的目标检测框架,其效果超越了目前的一众YOLO系列方法&#xff0c;在实现SOTA的同时&#xff0c;保持了很高的推理速度。DAMO…

虚幻学习笔记4—文本内容处理

一、前言 本文使用的虚幻引擎5.3.2&#xff0c;在虚幻中已经集成了很多可以直接处理多样化文本的蓝图&#xff0c;比如格式化动态显示、浮点数多样化等。 二、实现 2.1、格式化文本显示动态内容&#xff1a;在设置某个文本时可以使用“Format Text”蓝图设置自定义可以的显示…

继承中的析构函数的权限的深入了解

如果一个父类中的析构函数如果设置为 private 权限 &#xff0c;一个子类public继承了这个父类&#xff0c;那么 这个父类可以创建对象吗&#xff1f; 答案是 不可以 看看下面的代码 class A { public:private:~A() {} };class B :public A {A a; // 这个地方编译不报错&…

数据结构——带头循环双向链表(List)

1、带头双向循环链表介绍 在上一篇博客中我们提到了链表有三个特性&#xff0c;可以组合成为8种不同类型的链表。单链表是其中比较重要的一种&#xff0c;那么这次我们选择和带头双向循环链表会会面&#xff0c;这样我们就见识过了所有三种特性的呈现。 带头双向循环链表&#…