zoukankan      html  css  js  c++  java
  • django(django项目创建,数据库迁移)

    Django项目的创建与介绍

    安装:pip3 install django==1.11
    查看版本号:django-admin --version
    新建项目:
    1.切到目标目录
    2.django-admin startproject 项目名
    
    proj_name:项目目录,包含项目最基本的一些配置
    	-- __init__.py:模块的配置文件
    	-- settings.py:配置总文件
    	-- urls.py:url配置文件,django项目中的所有页面都需要对其配置url地址
    	-- wsgi.py:(web server gateway interface),服务器网关接口,python应用与web服务器直接通信的接口
    templates:模板文件夹,存放html文件的(页面),支持使用Django模板语言(DTL),也可以使用第三方(jinja2)
    manage.py:项目管理器,与项目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py
    

    应用的创建与介绍

    '''
    1.Django是面向应用开发,在应用中完成具体的业务逻辑
    2.什么是应用app: 就好比项目中的一个功能模块,一个项目可以拥有多个功能模块,但至少得有一个,Django称之为app
    3.如何创建app(在项目目录下):python3 manage.py startapp app01
    
    migrations:数据迁移(移植)模块,内容都是由Django自动生成
    	-- __init__.py
    __init__.py
    admin.py:应用的后台管理系统配置
    apps.py:django 1.9后,本应用的相关配置
    models.py:数据模型模块,使用ORM框架,类似于MVC模式下的Model层
    tests.py:自动化测试模块,可以写自动化测试脚本
    views.py:执行相应的逻辑代码模块
    '''
    

    启动项目

    python3 manage.py runserver 127.0.0.1:8888
    

    pycharm创建启动项目

    1.创建django
    2.选择项目目录(从项目目录开始,目录文件夹及子文件夹不要出现中文,保证电脑名字不能为中文)
    3.配置默认模板语言,模板路径,app名
    4.启动
    

    生命周期

    1.浏览器发送请求
    2.wsgi服务器接收到请求,将请求解析交给django
    3.Django中间件过滤请求信息,交给路由
    4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数
    5.视图函数完成具体的业务逻辑,返回响应结果
    6.将处理结果通过服务器返回给浏览器
    

    三件套

    from django.shortcuts import HttpResponse,render,redirect
    def foo(request):
        return HttpResponse("msg")
    def foo1(request):
        return render(request,"template_page.html",{k:v})
    def foo2(request):
        return redirect('/index/')
    

    静态文件

    动态文件:结果动态变化,如显示登陆结果的html文件
    静态文件:不变化的文件,如css文件,图片
    因为在处理静态文件时,浏览器可以将静态文件存入缓存,不用每次请求都重新下载
    ,故静态文件有单独的处理方式
    1.在项目根目录下创建static文件夹
    2.在settings.py中设置
    STATIC_URL = '/static/'#静态文件请求跟路由
    STATICFILES_DIRS = [os.path.join(BASE_DIR,'static')]
    3.静态文件就放在static根目录或子目录下
    4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
    
    

    请求及数据

    请求路径:
     1."/":默认向当前路径发送请求
     2./index/:向index路径发送请求
        
     数据:
     请求方式(get|post):request.method
     GET请求方式方式获取数据:
        request.GET.get("key")
     POST请求方式获取数据:
        request.POST.get("key")
        
    

    配置Mysql完成数据迁移

    
    1.在settings.py中将数据库更换为mysql
    HOST,USER,PASSWORD必须大写,PASSWORD写成PASSWD会报错
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'dj04',
            'HOST':'127.0.0.1',
            'USER':'root',
            'PASSWORD':'123'
        }
    }
    
    2.在项目或应用的init文件中修改连接数据库的模块为pymysql
    import pymysql
    pymysql.install_as_MySQLdb()
    #py2中使用mysqldb连接数据库,py3使用pymysql,故需要用pymysql替换掉Mysqldb
    
    3.在models建好类(对应到数据库的表)
    from django.db.models import *
    # Create your models here.
    class User(Model):
        id = AutoField(primary_key=True)
        user = CharField(max_length=20)
        pwd = CharField(max_length=20)
        
    3.在项目目录下,执行(生成迁移数据,没有映射到数据库):
    ①在cmd中操作
    1.切到项目根目录
    2.python3 manage.py makemigrations
    ②在pycharm terminal中执行
    python3 manage.py makemigrations
    ③在pycharm tools工具中的
    run manage.py Task 执行 makemigrations
    #执行完makemigrations会在项目的migrations文件夹中生成_initial.py
    
    4.映射到数据库(在数据库建表)
    python3 manage.py migrate
    #在数据库创建的表名为 项目名_类名
    
    

    单表ORM记录的增删改查

    增
    ①User.objects.create(user="abc",pwd="123")
    ②user = User(user = "abc",pwd ="123")
    user.save()
    
    删
    User.objects.filter(id=1).delete()
    
    改
    User.objects.filter(pwd="123").update(pwd="000")
    
    查
    User.objects.filter(pwd ="000").all()
    User.objects.filter(pwd ="000").first()
    
    #在django的创建的类,无需初始化,继承了字典父类,传参必须使用key,value形式
    
  • 相关阅读:
    编程题:数组中出现超数组长度一半的数字
    编程题:两数之和&数组中相加为0的三元数组
    编程题:最小矩阵路径
    编程题:斐波那契数列青蛙跳台阶
    向excel文件中写内容
    Java:使用jxl读取excel文件内容
    索尼1a dac插电脑用什么驱动。在哪下载,求助
    idea启动项目报端口号冲突或被占用
    两分钟解决IntelliJ IDEA中文乱码问题
    IntelliJ IDEA以不同格式导出数据库的数据
  • 原文地址:https://www.cnblogs.com/robert-zhou/p/10478834.html
Copyright © 2011-2022 走看看