django(mvt结构)

虚拟环境

创建虚拟环境

  • mkvirtualenv django_py3 -p python3

    切换虚拟环境

  • wokeon 虚拟环境名称

    删除虚拟环境

  • rmvirtualenv 虚拟环境名称
    • 注意不能删除当前正在使用的虚拟环境

      安装包

      安装djando包

  • pip install djando==1.11.11

    其他pip指令

  • 查看当前虚拟环境的所有依赖包
    • pip list 或者 pip freeze
  • 安装依赖包
    • pip install 依赖包的名称
  • 卸载依赖包
    • pip uninstall 依赖包的名称

      创建django项目

      创建主项目

  • django-admin startproject 项目名称
    • settings.py是项目的整体配置文件。
      urls.py是项目的URL配置文件。
      wsgi.py是项目与WSGI兼容的Web服务器入口。
      manage.py是项目管理文件,通过它管理项目。

      创建子项目

  • python manage.py startproject 子项目名称
    • admin.py文件跟网站的后台管理站点配置相关。
      apps.py文件用于配置当前子应用的相关信息。
      migrations目录用于存放数据库迁移历史文件。
      models.py文件用户保存数据库模型类。
      tests.py文件用于开发测试用例,编写单元测试。
      views.py文件用于编写Web应用视图。

      注册子项目

  • 第一步
    • 在工程配置文件settings.py中,INSTALLED_APPS项保存了工程中已经注册安装的子应用
  • 第二步
    • 注册安装一个子应用的方法,即是将子应用的配置信息文件apps.py中的Config类添加到INSTALLED_APPS列表中

      路由注册

      1.先在主工程的目录urls 进行子路由的注册

      2.切换到对应的子工程的urls文件仿照主工程的样式书写子路由的路由(路由的注册,一般在子工程的urls进行,子工程urls需要自己创建,在匹配时一定要把匹配所有规则的路由匹配放在最后)

      模型类

      数据类型

  • DateField 日期, 参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add和auto_now是相互排斥的,组合将会发生错误
    TimeField 时间,参数同DateField
    DateTimeField 日期时间,参数同DateField
    FileField 上传文件字段
    ImageField 继承于FileField,对上传的内容进行校验,确保是有效的图片
  • AutoField 自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性
    BooleanField 布尔字段,值为True或False
    NullBooleanField 支持Null、True、False三种值
  • CharField 字符串,参数max_length表示最大字符个数
    TextField 大文本字段,一般超过4000个字符时使用
    IntegerField 整数
    DecimalField 十进制浮点数, 参数max_digits表示总位数, 参数decimal_places表示小数位数
    FloatField 浮点数

    属性

  • null 如果为True,表示允许为空,默认值是False
    blank 如果为True,则该字段允许为空白,默认值是False
    db_column 字段的名称,如果未指定,则使用属性的名称
    db_index 若值为True, 则在表中会为此字段创建索引,默认值是False
    default 默认
    primary_key 若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用
    unique 如果为True, 这个字段在表中必须有唯一值,默认值是False
  • 外键
    • CASCADE级联,删除主表数据时连通一起删除外键表中数据
      PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据
      SET_NULL设置为NULL,仅在该字段null=True允许为null时可用
      SET_DEFAULT设置为默认值,仅在该字段设置了默认值时可用
      SET()设置为特定值或者调用特定方法
      DO_NOTHING不做任何操作,如果数据库前置指明级联性,此选项会抛出IntegrityError异常

      操作

  • 增删改
    • 增加数据

      • 方式一

        • book=BookInfo(name='张三')
        • book.save()
        • 需要用save()方法提交数据,提交之前数据库无法查询出内容
      • 方式二
        • BookInfo.objectes.create(name='张三')
        • 不需要save()提交数据,数据库可以直接查询到数据
    • 删除数据
      • 方式一

        • BooKinfo.objects.get(name='张三').delete()
      • 方式二
        • BookInfo.objects.filter(name='张三').delete()
    • 修改数据
      • 方式一

        • book=BookInfo.object.get(name='张三')
        • book.name='李四'
        • book.save()
        • 注意这种方法选哟用save()方法进行数据的提交,在美提交之前数据库中的数据没放生变化
      • 方式二
        • BooInfo.object.get(name='张三').updata(name='李四')
        • 不需要用save()提交数据,直接可以在数据库中查询到
  • 查询
    • 普通查询

      • get(条件)

        • 查询一个对象,没有结果抛出一个异常
      • all()
        • 查询多个对象,返回一个由对象组成的列表
      • count()
        • 返回查询的数量
    • 筛选查询
      • filter(条件)返会的是sql语句

        • 属性 = 值 方式

          • 普通查询
        • 属性__contains='值'
          • 模糊查询(包含某些字段)
        • 范围查询
          • 属性__gt=’值‘

            • 大于某个范围
          • 属性__lt = '值'
            • 小于某个范围
          • 属性__gte=’值‘
            • 大于等于某个范围’
          • 属性__lte = '值'
            • 小于等于某个范围
          • 属性__in=(元祖)
            • 属性值在元祖范围内的结果
          • 属性__exclude=’值‘
            • 不包含某个值的所有结果
      • 逻辑查询
        • F对象(比较两个属性)

          • BookInfo.objects.filter(readcount__gt=F('commentcount'))
          • 根本原理:将某字段的查询结果转换为数值,然后做比较
        • Q逻辑判断 & ,|
          • BookInfo.objects.filter(Q(pub_date_gt='1992-1-1')|Q(name__contains='3'))

          • 逻辑与还可以通过以下方式查询
            • BookInfo.objects.filter(pub_date__gt = '1990-1-1',name__contains='3')

            • BookInfo.objects.filter(pub_date__gt = '1990-1-1').filter(name__contains='3')

        • 空判断
          • 属性__isnull=True/Flase

            • 查询属性为空或者不为空的所有值
    • 关联查询
      • 普通关联

        • 在没有外键的一方查询另一方

          • book = BookInfo.objects.get(id=1)
            book.peopleinfo_set.all()

            • peopleinfo为关联表的名称的小写
            • 表名(小写)__set 是固定语法
        • 在由外键的一方查询另一方
          • person = PeopleInfo.objects.get(id=1)
            person.book

            • book为外键名称
      • 筛选关联
        • 在没有外键的一方查询另一方

          • PeopleInfo.objects.filter(book__name='天龙八部')
        • 在由外键的一方查询另一方
          • BookInfo.objects.filter(peopleinfo__name='郭靖')

            迁移

  • 1.python manage.py makemigrations
  • 2.ptthon manafe.py migrate

XMind: ZEN - Trial Version

Django 项目搭建的更多相关文章

  1. Django 项目搭建(ubuntu系统)

    1 环境搭建 sudo apt-get install python3-pip 安装pip3 sudo pip3 install virtualenv 安装虚拟环境,这里展示virtualenv vi ...

  2. django项目搭建及Session使用

    django+session+中间件 一.使用命令行创建django项目 在指定路径下创建django项目 django-admin startproject djangocommon   在项目目录 ...

  3. Django项目搭建和配置总结

    安装和创建虚拟环境 参考:linux系统下Python虚拟环境的安装和使用 安装Django包 先进入虚拟环境,在联网下执行: pip install django==1.8.7 1.8.7表示dja ...

  4. windows7下django项目搭建

    参考视频教程 http://study.163.com/course/    http://www.bilibili.com/video/av8915600/   http://www.bilibil ...

  5. 全栈开发系列学习2——django项目搭建

    项目代码:http://yunpan.cn/cHajgT4HvgHqx (提取码:8350) 配置项目: 1. 首先确保你的机器安装了python和pip,这两种安装比较简单,这里就不说了. 2. 在 ...

  6. Windows下Django项目搭建流程

    1.创建虚拟环境 virtualenv test 2.进入虚拟环境 source ./项目名/Scripts/activate 3.创建项目 django-admin startproject 项目名 ...

  7. django项目搭建

    参见https://www.imooc.com/video/13931 1.安装python,从官网python.org下载msi安装2.7,安装完后,输入python可以看到版本 2.djangop ...

  8. linux搭建django项目基本步骤

    一 linux下django基本项目搭建流程:M model 用于与数据库交互V view 接受前台请求 调用model获取结果,调用T获取页面,返回给前台T template 接受view的要求 生 ...

  9. django项目环境搭建

    本文转载自: https://blog.csdn.net/xiaogeldx/article/details/89038299 在码云平台创建项目 版本控制的种类 主要使用github(最主流) 国内 ...

随机推荐

  1. LeetCode 141. Linked List Cycle(判断链表是否有环)

    题意:判断链表是否有环. 分析:快慢指针. /** * Definition for singly-linked list. * struct ListNode { * int val; * List ...

  2. ASP.NET Core的身份认证框架IdentityServer4--入门

    ASP.NET Core的身份认证框架IdentityServer4--入门 2018年08月11日 10:09:00 qq_42606051 阅读数 4002   https://blog.csdn ...

  3. Vue入口页

    Template里面的App就是在这个实例里面注册的App组件 也就是整个过程就是将el所标识的元素替换成<App/> 而App就是在此实例注册的App组件.

  4. java面试题蚂蚁

    hashmap结构:什么对象能做为key hashtable,concurrentHashMap,hashtable比较 String,StringBuilder,StringBuffer 对象的深浅 ...

  5. 「CF126B」Password

    题目描述 给定一个字符串 \(S\),我们规定一个字符串 \(P\) 是可行解,\(P\) 需要满足: \(P\) 是 \(S\) 的前缀 \(P\) 是 \(S\) 的后缀 \(P\) 出现在 \( ...

  6. RF之变量的共享使用与python测试库-5

    RF申明变量: 首先我们要创建Variables表 *** Settings *** ${LoginUrl}      http://cloud.innovpowerf.com/Account/Log ...

  7. 概率图模型(PGM,Probabilistic Graphical Model)

    PGM是现代信号处理(尤其是机器学习)的重要内容. PGM通过图的方式,将多个随机变量之前的关系通过简洁的方式表现出来.因此PGM包括图论和概率论的相关内容. PGM理论研究并解决三个问题: 1)表示 ...

  8. Android APK反编译就这么简单 详解(附图)--转

    转自:http://blog.csdn.net/vipzjyno1/article/details/21039349/ 在学习Android开发的过程你,你往往会去借鉴别人的应用是怎么开发的,那些漂亮 ...

  9. 大公司病,为什么要PPT背锅?

    新东方年会上,一曲吐槽式的<释放自我>火遍网络,据说这六位员工,是冒着被解雇的风险完成演出的,歌词内容涉及到非常敏感的大企业病,如机构臃肿.效率低下.内耗甩锅.拍领导马屁等等,而最高潮的部 ...

  10. Lognormal distribution 对数正态分布

    转载:https://blog.csdn.net/donggui8650/article/details/101556041 在概率论中,对数正态分布是一种连续概率分布,其随机变量的对数服从正态分布. ...