当前位置: 首页 > news >正文

三.Django--ORM(操作数据库)

目录

1 什么是ORM

1.1 ORM优势

1.2ORM 劣势

1.3 ORM与数据库的关系

2 ORM

2.1 作用

2.2 连接数据库

2.3 表操作--设置字段

2.4 数据库的迁移

写路由+增删改查操作

项目里的urls.py:

app里的views.py:

注意点:


1 什么是ORM

ORM中文---对象-关系映射

在MTV,MVC设计模式当中,在model模块当中都包含ORM.

pip install mysqlclient

1.1 ORM优势

  • 只需要面向对象编程,不需要面向数据库编写代码

    • 对数据库的操作都可以转化成类属性,类方法

    • 不用编写SQL语句

  • 实现了数据模型与数据库的解耦,还屏蔽了不同数据库操作上的差异

    • 不再关注使用的是MySQL oracle....(相同代码可以操作不同的数据库)一对多

    • 通过简单的代码配置,轻松跟换数据库,不需要频繁修改代码

1.2ORM 劣势

  • 对比直接使用SQL语句,有一些性能上的损失.(因为一对多了...)

  • 根据代码的执行,将结果转化成对象,在映射过程当中存在性能的损失

1.3 ORM与数据库的关系

  • 在Django当中,model是数据单一,明确的来源,存储了数据的一些重要的字段和行为


2 ORM

2.1 作用

1、创建,修改,删除数据库当中的【无法创建数据库】 
2、操作表中的数据   【无需编写SQL代码】 
确保服务正常启动

2.2 连接数据库

项目的setting.py:

--替换一下-->


2.3 表操作--设置字段

每个APP都有自己的moudle.py:

verbose_name        参数为前端的提示 and 展示的前身.

2.4 数据库的迁移

  • 确保app已经注册

    python manage.py makemigrationspython manage.py migrate

    --执行命令后,数据表注册成功.

  • 表字段的增加(添加新字段后,再执行命令.)

    • 手动输入一个默认值

    • 给定默认值 defaule=10

    • 允许为空

写路由+增删改查操作

项目里的urls.py:
from django.contrib import admin
from django.urls import path
from project_one import viewsurlpatterns = [path('', views.orm_demo),
]
app里的views.py:
from django.shortcuts import render, HttpResponse
from project_one.models import DemoTextdef orm_demo(request):# 增加数据 insert into xxx(xxx) values(xxx)# DemoText.objects.create(name="张三", sex="男", age=18, love="篮球")# DemoText.objects.create(name="李四", sex="女", age=17, love="唱歌")# DemoText.objects.create(name="王五", sex="男", age=19, love="跳舞")# DemoText.objects.create(name="赵六", sex="女", age=21, love="游戏")# 删除数据# DemoText.objects.all().delete()# DemoText.objects.filter(id=6).delete()# 查看数据# data_list = DemoText.objects.all()# for data in data_list:#     print(data.id, data.name, data.love, data.age)# data = DemoText.objects.filter(id=8).first()# print(data)# print(data.name)# 修改数据# DemoText.objects.all().update(age=20)DemoText.objects.filter(id=10).update(name="坤哥", age=19)return HttpResponse("操作成功")

注意点:

生成的数据库全都是一模一样的,所以最好不要用同一个数据库.

(不然注册迁移数据库的时候会重复生成,报错等等)

一个项目最好对应一个数据库.


http://www.lryc.cn/news/344652.html

相关文章:

  • 【华为】AC直连二层组网隧道转发实验配置
  • 第 129 场 LeetCode 双周赛题解
  • GStreamer日志调试笔记
  • 【api接口开通教程】YouTube Data API v3申请流程
  • .net 6.0 框架集成ef实战,步骤详解
  • [C/C++] -- 观察者模式
  • 秋招算法刷题8
  • Docker使用方法
  • HTML学习|网页基本信息、网页基本标签、图像标签、超链接标签、列表标签、表格标签、媒体元素、页面结构分析、iframe内联框架
  • 001 websocket(评论功能demo)(消息推送)
  • 二分查找向下取整导致的死循环69. x 的平方根
  • Kivy 异步任务
  • DEV--C++小游戏(吃星星(0.1))
  • LINUX 入门 4
  • Imagine Flash、StyleMamba 、FlexControl、Multi-Scene T2V、TexControl
  • Java Collections.emptyList() 方法详解
  • Vue前端环境准备
  • 代码随想录算法训练营第四十二天| 01背包问题(二维、一维)、416.分割等和子集
  • 故障——蓝桥杯十三届2022国赛大学B组真题
  • SSD存储基本知识
  • buuctf-misc题目练习二
  • Nginx rewrite项目练习
  • 2024,AI手机“元年”? | 最新快讯
  • 5月9(信息差)
  • leetcode203-Remove Linked List Elements
  • 2024付费进群系统,源码及搭建变现视频课程(教程+源码)
  • 深入理解Django:中间件与信号处理的艺术
  • rk3588局域网推流
  • Android虚拟机机制
  • 【触摸案例-手势解锁案例-按钮高亮 Objective-C语言】