七.django模型系统(一)
Ⅰ.django的ORM
1.含义
对象关系映射(英语:(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的--“虚拟对象数据库”。ORM有时也称为基于事实的建模,因为它把相关数据描述为基本事实。这些事实如果分割为再小的事实就会丢失信息。
对象关系映射(Object-Relational Mapping)提供了概念性的、易于理解的模型化数据的方法。ORM方法论基于三个核心原则: 简单:以最基本的形式建模数据。 传达性:数据库结构被任何人都能理解的语言文档化。 精确性:基于数据模型创建正确标准化的结构。 典型地,建模者通过收集来自那些熟悉应用程序但不熟练的数据建模者的人的信息开发信息模型。建模者必须能够用非技术企业专家可以理解的术语在概念层次上与数据结构进行通讯。建模者也必须能以简单的单元分析信息,对样本数据进行处理。ORM专门被设计为改进这种联系。
总而言之,ORM就是指:用python的概念来表达数据库。即可以用python中的数据类型来表示mysql中的一张表。也就是说,我对python的数据进行操作,它就可以将其映射到mysql的数据库中,而我不需要写sql语句。

Ⅱ.数据库配置
1.数据库配置步骤
安装pymysql
修改项目目录下的
__init__.py,改为如下样式:
import pymysql
pymysql.install_as_MySQLdb()
手动创建一个当前项目的空的数据库,准备一个有创建数据库权限的用户
settings 配置,改为如下样式:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'crm', #数据库名
'USER': 'admin',
'PASSWORD': 'Root110qwe',
'HOST': '127.0.0.1',
'PORT': '',
}
2.实际操作



3.补充:两种数据库的创建方法
1)Navicat(物理机)的创建/连接

2)在pycharm的虚拟机中进行数据库的创建

Ⅲ.模型的创建与映射
1.模型
1)模型含义
这里的模型就 django.db.models.Model的一个子类。
模型定义在app文件夹下的models.py文件
2)创建模型

2.激活模型(模型映射)
1)执行步骤
**注册应用
创建迁移(django数据库中一旦有任何的数据库结构的改变都要进行一次创建迁移)
python manage.py makemigrations appname #注:如果不写 appname 则代表迁移所有已注册的app
如果想看:我们的更改,会对数据库产生什么影响,我们可以看它大概会执行什么sql语句。具体操作如下:
python manage.py sqlmigrate appname num
例如: python manage.py sqlmigrate teacher 0001
- 执行迁移 操作数据库,将对模型的改动应用到数据库(底层就是执行了sql),具体输入如下:
python manage.py migrate appname #当不写 appname 则会将所有注册的改动映射到输出
模型映射到数据库中是一张表, 表名 = appname_模型name (小写)
执行上面的命令到底干了些什么:
1.在app中查找迁移文件,并且去django_migrations表中查找,如果有没有执行的迁移文件,就执行它
2.执行了迁移生存的sql语句
3.如果成功,会在django_migrations表中增加一条记录
2)实例操作

当发生修改时,继续如下操作:

Ⅳ.简单的数据的增删改查
1.django 调试环境
python manage.py shell


2.增
1)一般代码输入情况
#第一种方式:
In [3]: s=Student()
In [5]: s.name = 'Michael_Lxh'
In [6]: s.age = 18
In [7]: Student.objects.all()
Out[7]: <QuerySet []> In [8]: s.save() # save 之后才会写到数据库 #第二种方式:
In [10]: stu = Student.objects.create(name='隔壁老王', age=20) #直接创建
2)实例操作
a.第一种方式

b.第二种方式

3.删
1)一般代码输入情况
#删某一条:
In [13]: stu.delete()
Out[13]: (1, {'teacher.Student': 1}) #删所有:
In [8]: Student.objects.all().delete() #注意:一般情况下千万不要使用(慎重) #删特定一条:
In [8]: Student.objects.filter(sex=1).delete() Out[8]: (1, {'teacher.Student': 1})
2)实例操作
a.删除特定的

4.改
1)一般代码输入情况
#改一条的情况:
In [17]: s.age=16
In [18]: s.save() #改全部条:
In [6]: Student.objects.all().update(sex=0)
Out[6]: 2 #改部分有选择的:
In [7]: Student.objects.filter(age__gt=17).update(sex=1)
Out[7]: 1
2)实例操作
a.改一条的情况

b.改全部

c.有选择的修改

5.查
1)一般代码输入情况
#查所有:
In [2]: Student.objects.all()
Out[2]: <QuerySet [<Student: Michael_Lxh>, <Student: 隔壁老王>]> #查一条:
In [3]: Student.objects.get(pk=1) #如果get返回了多值就会报错,因为get返回的是对象
Out[3]: <Student: Michael_Lxh> #带条件的查询:
In [4]: Student.objects.filter(sex=1) # 等价于 where sex=1
Out[4]: <QuerySet [<Student: Michael_Lxh>, <Student: 隔壁老王>]> In [5]: Student.objects.filter(sex=1,name='Michael_Lxh')
Out[5]: <QuerySet [<Student: Michael_Lxh>]>
2)实例操作
a.查所有

b.查一条

c.查带条件的

补充网址(mysql):https://dev.mysql.com/doc/refman/8.0/en/charset-unicode-sets.html
七.django模型系统(一)的更多相关文章
- django模型系统(二)
django模型系统(二) 常用查询 每一个django模型类,都有一个默认的管理器,objects QuerySet表示数据库中对象的列表.他可以有0到国歌过滤器.过滤器通过给定参数,缩小查询范围( ...
- django模型系统(一)
django模型系统(一) djangode ORM ORM:对像关系映射 用python概念去表达数据库 数据库配置(mysql) 安装pumysql 修改项目目录下的__init__.py imp ...
- Django模型系统——ORM校园管理系统代码
1.models.py from django.db import models # Create your models here. class Class(models.Model): id = ...
- 八.django模型系统(二)之常用查询及表关系的实现
Ⅰ.常用查询 1.几个概念 每一个django模型类,都有一个默认的管理器,objects,查询就是依赖于objects管理器进行的(在创建时就被添加了). QuerySet表示数据库中对象的列表( ...
- django模型系统二
常用查询及表关系的实现 1.常用查询 每一个django模型类,都有一个默认的管理器 objects QuerySet表示数据库中对象的列表,它可以有0到多个过滤器.过滤器通过给定参数,缩小查询范围. ...
- Django 模型系统(model)&ORM--进阶
QuerySet 可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. >>> Entry.objects.all()[ ...
- Django模型系统——ORM
一.概论 1.ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描 ...
- python的Web框架,Django模型系统二,模型属性,及数据库进阶查询
原始数据接上篇文章来操作.可能需要查看后才能懂.点击这里查看 1.常用的模型字段类型 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fie ...
- Django 模型系统(model)&ORM--基础
ORM 映射关系: 类 ---> 表 属性 ---> 字段 对象 --->一条数据 创建表(建立模型) 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作 ...
随机推荐
- 微信小程序 选择微信自带的地址 用户授权选择了拒绝
// 选择微信自带地址 addAddr:function () { wx.chooseAddress({ success: function (res) { self.setData({ addrIn ...
- 持续集成之 Spring Boot 实战篇
本文作者: CODING 用户 - 何健 这次实战篇,我们借助「CODING 持续集成」,实现一个简单的 Spring Boot 项目从编码到最后部署的完整过程.本教程还有 B 站视频版,帮助读者更好 ...
- C#中文件下载的几种方法演示源码
内容过程,把内容过程比较重要的内容做个珍藏,如下的内容是关于C#中文件下载的几种方法演示的内容,应该是对各朋友有较大好处. using System;using System.Data;using S ...
- 【English】十三、英语中的连词有哪些,都有什么作用
一.什么是连词 参考:https://m.hujiang.com/en_cixing/yylc/ 连词是一种虚词,用于连接单词.短语.从句或句子,在句子中不单独用作句子成分. 连词按其性质可分为并列连 ...
- SQL Server含逗号分隔的数据匹配维表
日常有时候导出数据需求时,数据列会遇到带有分隔符的ID,但又需要匹配维表(如下图所示)将ID变成名称. 这种情况可以采用“分隔-匹配-合并”的方法 具体代码为: -- 准备工作1:创建事实表数据 CR ...
- 中国移动能力开放商店OneNET View数据可视化公测 10分钟轻便生成行业可视化界面
随着云计算,5G技术,人工智能等底层技术的发展,万物互联时代已经到来,同时带来了海量数据,如何效果好.低成本.短时间的表现据,成为物联网行业从业者和公司的当务之急. OneNET View传统的数据展 ...
- 使用bootstrap的dropdown部件时报错:error:Bootstrap dropdown require Popper.js
前言:前端小白一枚,刚注册博客,先发个学习过程中新碰到小问题试试水吧~ 摘要:最近在学习bootstrap,偶然碰到了一个小问题,bootstrap网站也没有做过多的解释,今天分享给大家. 问题描述: ...
- Python基础之if判断,while循环,循环嵌套
if判断 判断的定义 如果条件满足,就做一件事:条件不满足,就做另一件事: 判断语句又被称为分支语句,有判断,才有分支: if判断语句基本语法 if语句格式: if 判断的条件: 条件成立后做的事 . ...
- Azure按订阅,资源组,资源类型导出所有资源powershell命令
一般可以借助powershell命令来读取资源:例如:1, 读取某个订阅下的资源:$subscriptionID = "xxxxxxxx"Set-AzureRmContext $s ...
- 001_python实现数据分析
一. # coding:utf8 # !/usr/bin/python # import numpy as np import pandas as pd import np def example2( ...