django模型系统(一)

djangode ORM

ORM:对像关系映射

用python概念去表达数据库

数据库配置(mysql)

  • 安装pumysql
  • 修改项目目录下的__init__.py
import pymysql
pymysql.install_as_MySQLdb()
  • 手动创建一个当前项目的空数据库,准备一个有创建数据库权限的用户

    (推荐使用Navicat,方便;也可用命令行)
  • 在settings配置
    • 找到databases
    • 配置修改为:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'crm',#数据库名
'USER':'admin',#用户名
'PASSWORD':'Root110qwe',#密码
'HOST':'127.0.0.1',#主机地址
'PORT':'3306'#端口地址
}

补充Navicat的数据库连接

  • 注意:如果虚拟机上的,虚拟机记得写好端口映射

模型的创建与映射

创建

模型就是django.db.modles.Model的一个子类。

  • 关系

模型定义在app文件夹下的models.py文件

例如:

映射

即:激活模型

  • 注册应用app
  • 创建迁移,每一个迁移文件都会有一个迁移编号
    • 每次修改模型都要重新创建
  python manage.py makemigrations appname#不写name就代表迁移所有的注册了的app

例如:



注意:此时数据库无表,此命令仅仅只是告诉Djano,修改了模型,不会操作数据库

如果我们想看,我们的更改,会对数据库产生什么影响,我们可以看执行什么sql语句

使用命令:
python manage.py sqlmigrate appname filenum 例如:
(crm) pyvip@Vip:~/project/crm$ python manage.py sqlmigrate teacher 0001
  • 执行迁移:操作数据库,将对模型的改动应用到数据库(底层就是执行了sql)
  • 命令:
python manage.py migrate appname
  • 模型映射到数据库中是一张表 ,表名 = appname_模型name(小写)

    • 例如上面的student表:teacher_student
  • 执行命令的动作:
    • 在app中查找迁移文件,并且去django_migrations(系统自建的一张表)表中查找,如果有没有执行的迁移文件,就去执行它
    • 执行了迁移生成的sql语句
    • 如果成功,会在django_migrations表中增加一条记录
      • django_migrations表中有记录的信息,系统将不会执行记录中的文件的迁移

简单的数据的增删查改

django调试环境

进入命令(虚拟机的):
python manage.py shell

# 第一种方式
In [3]: s = Student() In [5]: s.name = '心蓝' In [6]: s.age = 18 In [7]: Student.objects.all()
Out[7]: <QuerySet []> In [8]: s.save() # save之后才会写到数据库 # 第二种方式
stu = Student.objects.create(name='敬子明', age=10) # 直接创建

In [12]: stu.delete()
Out[12]: (1, {'teacher.Student': 1})
# 删除多条 In [12]: Student.objects.filter(sex=1).delete()
Out[12]: (1, {'teacher.Student': 1})

# 改一条
In [16]: s.age = 16 In [17]: s.save() # 改多条
In [10]: Student.objects.all().update(sex=0)
Out[10]: 2

# 查所有
In [2]: Student.objects.all()
Out[2]: <QuerySet [<Student: 心蓝>, <Student: 敬子明>]>
# 查一条
In [3]: Student.objects.get(pk=1)
Out[3]: <Student: 心蓝>
# get 返回的是对象 如果返回了多值就会报错
# 带条件
In [8]: res = Student.objects.filter(sex=1) # where sex=1
In [9]: res
Out[9]: <QuerySet [<Student: 心蓝>, <Student: 敬子明>]>

django模型系统(一)的更多相关文章

  1. django模型系统(二)

    django模型系统(二) 常用查询 每一个django模型类,都有一个默认的管理器,objects QuerySet表示数据库中对象的列表.他可以有0到国歌过滤器.过滤器通过给定参数,缩小查询范围( ...

  2. Django模型系统——ORM校园管理系统代码

    1.models.py from django.db import models # Create your models here. class Class(models.Model): id = ...

  3. 八.django模型系统(二)之常用查询及表关系的实现

    Ⅰ.常用查询  1.几个概念 每一个django模型类,都有一个默认的管理器,objects,查询就是依赖于objects管理器进行的(在创建时就被添加了). QuerySet表示数据库中对象的列表( ...

  4. django模型系统二

    常用查询及表关系的实现 1.常用查询 每一个django模型类,都有一个默认的管理器 objects QuerySet表示数据库中对象的列表,它可以有0到多个过滤器.过滤器通过给定参数,缩小查询范围. ...

  5. Django 模型系统(model)&ORM--进阶

    QuerySet 可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. >>> Entry.objects.all()[ ...

  6. 七.django模型系统(一)

    Ⅰ.django的ORM 1.含义 对象关系映射(英语:(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语 ...

  7. python的Web框架,Django模型系统二,模型属性,及数据库进阶查询

    原始数据接上篇文章来操作.可能需要查看后才能懂.点击这里查看 1.常用的模型字段类型 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fie ...

  8. Django 模型系统(model)&ORM--基础

    ORM 映射关系: 类 ---> 表 属性 ---> 字段 对象 --->一条数据 创建表(建立模型) 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作 ...

  9. Django模型系统——ORM

    一.概论 1.ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描 ...

随机推荐

  1. LR12中针对WebServices协议的三种脚本开发模式

    一,webservices协议简介 webservices是建立可交互操作的分布式应用程序的新平台,它通过一系列的标准和协议来保证程序之间的动态连接, 其中最基本的协议包括soap,wsdl,uddi ...

  2. delphi 利用 InterlockedCompareExchange 实现主线程维一锁等待

    在进行资源锁定时,一般是线程之间进行交互,很少需要在主线程也对资源进行锁定. 不过在一些复杂的业务中,存在子线程与主线程的交互,且一些资源也同步在主线程中使用时,主线程资源锁,就有存在的必要. 假定有 ...

  3. 新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛)A Red Rover

    题目链接 大概意思就是,找出一个字串,将其所有出现的地方替换成一个字母M后的长度len1,然后再加上这个字串的长度t_len得到一个新的长度len,求这个len最小等于多少. 当然,也可以不找这个串, ...

  4. Sublime报错

    Sublime出现 unable to read project的错误对话框 每次重新开启都会弹出对话框 解决办法: 1.关闭Sublime 2.C:\Users\Administrator\AppD ...

  5. 【js】js声明与数据类型

    之前整理知识点感觉有点没有针对性,每期知识点之间都没有关联,不成体系,其实对学习与运用知识并无益,随着知识的积累,不使用就会忘记.所以从本次开始,将对知识点进行体系化.先列出本期知识体系图,再进行逐步 ...

  6. mysql中的内置函数

    这里主要介绍mysql丰富的内置函数. 数学函数 数学函数相对比较简单,就是涉及一些数值的计算,这里列出数学函数的功能,仅个别给出实例. 函数 作 用 ABX(x) 返回x的绝对值 CEIL(X),C ...

  7. Java基础面试题总结

    目录 索引 Java基础知识篇 Java web基础知识总结 Java集合篇常见问题 Java基础知识篇 面向对象和面向过程的区别 面向过程: 优点:性能比面向对象高,因为类调用时需要实例化,开销比较 ...

  8. Nodejs“实现”Dubbo Provider

    背景 目前nodejs应用越来越广泛,但和java的dubbo体系接入困难,所以我们需要实现node端的dubbo provider逻辑.java的dubbo provider是和consumer在一 ...

  9. SonarQube安装文档

    1.SonarQube 1.1 SonarQube介绍 SonarQube是管理代码质量一个开放平台,可以快速的定位代码中潜在的或者明显的错误. SonarQube是否可以使用自定义规则由开发人员的开 ...

  10. C# 模拟 HTTP POST请求

    /// <summary> /// 用于以 POST 方式向目标地址提交表达数据 /// 使用 application/x-www-form-urlencoded 编码方式 /// 不支持 ...