Django

  1. 下载安装

    1. 命令行

      pip install django==1.11.26 -i 源

    2. pycharm

  2. 创建项目

    1. 命令行

      django-admin startproject 项目名

    2. pycharm

      file ——》 new project ——》 django ——》 输入项目路径 ——》 选择解释器 ——》 输入一个app的名称 ——》 create

  3. 启动项目

    1. 命令行

      cd 项目的根目录

      python manage.py runserver # 127.0.0.1:8000

      python manage.py runserver 80 # 127.0.0.1:80

      python manage.py runserver 0.0.0.0:80 # 0.0.0.0:80

    2. pycharm

      点绿三角 (没有右键启动)

  4. settings的配置

    中间件中注释 csrf的中间件 可以提交POST请求

    静态文件的配置:

    STATIC_URL = '/static/'

    STATICFILES_DIRS = [

    os.path.join(BASE_DIR,'static')

    ]

    DATABASES 数据库

    INSTALLED_APPS = []

    TEMPLATES 模板 DIRS = [os.path.join(BASE_DIR,'templates')]

  5. APP

    创建APP

    python manage.py startapp app名

    注册APP

    INSTALLED_APPS = [

    'app名'

    或者

    'app名.apps.类' # 'app01.apps.App01Config',

    ]

  6. urls.py

     from app01 import views
     ​
     urlpatterns = [
     
         url(r'^publisher/',views.publisher),
         url(r'^add_publisher/',views.add_publisher),
         url(r'^del_publisher/',views.del_publisher),
         url(r'^edit_publisher/',views.edit_publisher),
     ]
  7. views.py

     from django.shotcuts import HttpResponse,render,redirect
     ​
     def publisher(request):
      # 业务逻辑
      # 返回响应
      # HttpResponse('字符串')   # 返回的是字符串
      # render(request,'模板的名字',{'k1':v1})   # 返回的一个页面
      # redirect('路径')   # 重定向
     ​
  8. 模板语法

      render(request,'pub.html',{'all_publishers':all_publishers}) 
     {{ all_publishers }}
     ​
     {% for i in all_publishers %}
     ​
      {{ forloop.counter }}
      {{ i }}
      {{ i.id }} {{ i.pk }}
      {{ i.name }}
     
     {% endfor %}
     ​
     ​
  9. form的注意点:

    1. form标签的属性 action='提交的地址' method='post' novalidate 取消input标签自带的校验

    2. input标签必须要有name属性 有些标签有value值

    3. 需要有一个button按钮 或者 type='submit'的input

  10. get 和 post

    get : 获取一个页面

    途径:

     1. 直接在浏览器的地址栏中输入地址 回车
    1. form表单 不指定method

    2. a标签

    参数: ?k1=v1&k2=v2

    获取参数: request.GET.get('k1')

    post : 提交数据

    途径:

     1. form表单  method = 'post'

    获取数据: request.POST.get('k1')

  11. Django使用MySQL数据库的流程:

    1. 手动创建一个MySQL数据库

    2. 配置数据库

       ENGINE   MySQL
       NAME 数据库的名字
       HOST   ip
       PORT   3306
       USER   用户名
       PASSWORD 密码
    3. 在与settings同级目录下的__init__.py中写代码:

       import pymysql
       pymysql.install_as_MySQLdb()
    4. 写models:

       form django.db import models 
       class Publisher(models.Model):
        name = models.CharField(max_length=32)
       ​
    5. 执行迁移的命令

       python  manage.py  makemigrations  # 检查已经注册的APP下面的models.py的变更情况
       python manage.py migrate   # 执行迁移
    6. ORM

      对象关系映射

      对应关系:

      类 _> 表

      对象 _> 数据行(记录)

      属性 _> 字段

      ORM能做的事情:

      1. 对数据做修改

      2. 对表做修改

      ORM的操作

       from app01 import models 
       ​
       # 查询
       models.Publisher.objects.all()  # 查询所有的数据 QuerySet 对象列表
       models.Publisher.objects.get(name='xxx')  # 查询一条数据 只能查有且唯一的数据
       models.Publisher.objects.filter(name='xxx')  # 查询所有满足条件的数据 对象列表
       ​
       # 新增
       obj = models.Publisher.objects.create(name='xxxx')
       ​
       obj = models.Publisher(name='xxxx')
       obj.save()  # 保存到数据库
       ​
       # 删除
       models.Publisher.objects.filter(pk=pk).delete()   # 批量删除
       models.Publisher.objects.get(pk=pk).delete() # 单条数据的删除
       ​
       ​
       # 更新
       models.Publisher.objects.filter(pk=pk).update(name='xx')  # 批量更新
       ​
       obj = models.Publisher.objects.get(pk=pk)
       obj.name = 'xxxx'
       obj.save()  # 保存到数据库

    外键

    一对多的关系

     ​
     class Book(models.Model):
         name = models.CharField(max_length=32)
         pub = models.ForeignKey('Publisher', on_delete=models.CASCADE)
       
     
         """
        on_delete 在2.0版本之后是必填的
        on_delete=
            models.CASCADE 级联删除
            PROTECT   保护
            SET(1)    
            SET_DEFAULT 设置为默认值设置为某一个值
            SET_NULL   设置为空
            DO_NOTHING 什么都不变
        """
         

    查询

     all_books = models.Book.objects.all()
     
     for book in all_books:
         print(book)
         print(book.id)
         print(book.pk)
         print(book.name)
         print(book.pub)  # 所关联的出版社对象   对象.外键
         print(book.pub_id)  # 所关联的出版社对象的id   对象.外键_id

    新增

     models.Book.objects.create(name=book_name,pub=models.Publisher.objects.get(pk=pub_id))
     obj = models.Book.objects.create(name=book_name, pub_id=pub_id)

    编辑

     book_obj.name = book_name
     book_obj.pub_id = pub_id
     # book_obj.pub = 出版社的对象
     book_obj.save()
     models.Book.objects.filter(pk=pk).update(name=book_name,pub_id=pub_id)

django内容回顾:的更多相关文章

  1. Django 内容回顾

    模板 变量 {{ }} 标签 {% %} if elif else for empty forloop() with...as csrf_token 过滤器 default length add da ...

  2. python 全栈开发,Day72(昨日作业讲解,昨日内容回顾,Django多表创建)

    昨日作业讲解 1.图书管理系统 实现功能:book单表的增删改查 1.1 新建一个项目bms,创建应用book.过程略... 1.2 手动创建static目录,并在目录里面创建css文件夹,修改set ...

  3. python 全栈开发,Day112(内容回顾,单例模式,路由系统,stark组件)

    一.内容回顾 类可否作为字典的key 初级 举例: class Foo(object): pass _registry = { Foo:123 } print(_registry) 执行输出: {&l ...

  4. django知识点回顾与补充

    一.django知识点回顾 1.Cookie操作 - 客户端本地存储的键值对 2.Session操作 - 3.URL路由 - /index -> view.函数 4.MTV 5.View中返回方 ...

  5. 04 DRF内容回顾、用户登录 (含跨域) (vuex vue-cookie)、用户认证 (Auth认证)(拦截器)

    1.内容回顾 1.视图中常见的继承 2.频率访问控制源码 3.序列化,反序列化 2.初始化代码 1.后端代码:AuthView (1)目录结构 (2)urls (3)view (4)注释掉cors ( ...

  6. 基本数据类型-集合(set)_上周内容回顾(字符串_数字_列表_元组_字典_集合)

    上周内容回顾 1.字符串 2.数字 除了布尔类型外,int.long.float和complex都可以使用的运算为:加.减.乘.除.整除.幂运算和取余 3.列表和元组 列表的内容可变,可以包含任意对象 ...

  7. Netty源码分析第4章(pipeline)---->第7节: 前章节内容回顾

    Netty源码分析第四章: pipeline 第七节: 前章节内容回顾 我们在第一章和第三章中, 遗留了很多有关事件传输的相关逻辑, 这里带大家一一回顾 首先看两个问题: 1.在客户端接入的时候, N ...

  8. Python并发编程内容回顾

    Python并发编程内容回顾 并发编程小结 目录 • 一.到底什么是线程?什么是进程? • 二.Python多线程情况下: • 三.Python多进程的情况下: • 四.为什么有这把GIL锁? • 五 ...

  9. JavaScript内容回顾

    <!DOCTYPE html> <!--JavaScript内容回顾--> <html lang="en"> <head> < ...

随机推荐

  1. 在 VS 中查看所有线程

    查看当前所有线程 在程序中打断点,然后启动调试(注意:线程窗口需要启动调试才可以看得到)点击 Debug > Windows > Threads 线程窗口如下:

  2. Django celery 使用

    0.安装包 cachetools 3.1.1 celery 3.1.26.post2 celery-with-redis 3.0 certifi 2019.9.11 Django 2.2.6 djan ...

  3. day91_11_13Local与偏函数

    一.local 在线程的处理中,常常遇到这样的问题.当一系列线程遇到io操作的时候,就会执行其他线程,这时候就会出现数据冲突,发生数据方面的问题: from threading import Thre ...

  4. day88_11_8,事务的隔离级别celery定时订单与项目整合。

    一.事务的隔离级别. mysql的默认数据库级别是可重复读,一般的应用使用的是读已提交 http://www.zsythink.net/archives/1233/ 1. Read UnCommitt ...

  5. AcWing 44. 分行从上往下打印二叉树

    地址 https://www.acwing.com/problem/content/description/42/ 题目描述从上到下按层打印二叉树,同一层的结点按从左到右的顺序打印,每一层打印到一行. ...

  6. leetcode 双周赛9 进击的骑士

    一个坐标可以从 -infinity 延伸到 +infinity 的 无限大的 棋盘上,你的 骑士 驻扎在坐标为 [0, 0] 的方格里. 骑士的走法和中国象棋中的马相似,走 “日” 字:即先向左(或右 ...

  7. jinja2模板用法

    我不是代码的生产者,我只是知识的搬运工 jinja2模板用法

  8. Leetcode103_Binary-tree-zigzag-level-order-traversal

    原题: https://leetcode-cn.com/problems/binary-tree-zigzag-level-order-traversal/ 思路,如果无从下手,先要了解二叉树的广度优 ...

  9. DevExpress启动时的全屏SplashScreen

    使用DevExpress启动时弹出"正在加载"的Logo,而且是全屏,这种感觉不太好. 原因是使用了DocmentManager控件,当DocmentManager初始化如果耗时较 ...

  10. jenkins配置publish over ssh遇到的问题

    一.背景 目标 本篇文章主要是说明自己在配置jenkins的publish over ssh插件所遇到的问题.本次主要是windows下的jenkins通过ssh的方式访问我本地虚拟机的ubuntu系 ...