zoukankan      html  css  js  c++  java
  • Django初使用

    一、Django初使用

    1. 静态文件配置

    • 这里的静态文件一般指的是我们下载到本地的jQuery文件,字体文件,图片文件,图标文件,Bootstrap框架的js和cs文件等。
    • 这些文件一般都放在一个专门放静态文件的文件夹内。Django中,这个文件夹我们要手动创建习惯性的以static来命名。单独用一个static文件夹来存储他们,当然是为了更方便以后的管理。

    (1)静态文件配置步骤

      1. 创建完static文件夹(在app文件夹同一目录下创建)——》
      2. settings文件配置静态文件资源接口前缀——》
      3. 配置静态资源所在的文件夹路径——》
      4. 到html文件中动态绑定静态文件资源前缀
    • 第二步和第三步实例:

      第二步:
      STATIC_URL = '/static/'  # 访问静态文件资源接口前缀  通常情况下接口前缀的名字也叫static
      
      第三步:直接在第二步下面直接书写
      # 手动开设静态文件访问资源
      STATICFILES_DIRS = [  # 静态资源所在的文件夹路径
      			os.path.join(BASE_DIR,'static'),  # 将static文件里面所有的资源暴露给用户
      			os.path.join(BASE_DIR,'static1'),  # 将static文件里面所有的资源暴露给用户
      			# os.path.join(BASE_DIR,'static2'),  # 将static文件里面所有的资源暴露给用户
      		]
      
    • 第四步实例

      # 在head标签内部,固定写法:
      {% load static %}
      
      # static字符后面的引号内写入从static文件夹下一级一级路径往下写,直到最后的文件
      <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
      
      # static字符后面的引号内写入从static文件夹下一级一级路径往下写,直到最后的文件
      <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
      

    2. form表单的get和post提交方式

    (1)get

    • get请求也可以携带数据,当提交方式为get时,提交时,会把用户输入、选择的数据放在链接的最后面,具体形式如下:

      例子:
      http://127.0.0.1:8000/login/?username=jason&password=jason123
      特点:url?xxx=xxx&yyy=yyy
      
    • get请求的特点:

      • 携带的数据不安全(会直接展示在提交地址的最后面)
      • 携带的数据大小可能有限制( Http Get方法提交的数据大小长度并没有限制,HTTP协议规范没有对URL长度进行限制。这个限制是特定的浏览器及服务器对它的限制)
      • 通常只会携带一些不是很重要的数据

    (2)post

    • post请求可以携带数据,并且”隐形的“提交数据。

    • 理论上讲,POST是没有大小限制的。HTTP协议规范也没有进行大小限制,起限制作用的是服务器的处理程序的处理能力。

    • 前期我们在朝后端提交post请求出现403的情况时,你需要取配置文件中注释掉一行内容。即:

      MIDDLEWARE = [
      			'django.middleware.security.SecurityMiddleware',
      			'django.contrib.sessions.middleware.SessionMiddleware',
      'django.middleware.common.CommonMiddleware',
      # 注释掉这一行    
      # 'django.middleware.csrf.CsrfViewMiddleware',
      			'django.contrib.auth.middleware.AuthenticationMiddleware',
      			'django.contrib.messages.middleware.MessageMiddleware',
      			'django.middleware.clickjacking.XFrameOptionsMiddleware',
      		]
      

    (3)注意

    • 无论是发get请求还是post请求 都会执行视图函数

    • 即使form表单的提交数据方式为post,我们只要把提交数据的地址的后缀上按照get请求携带数据的方式自定义的添加数据字符串后,Django后端的views中的功能函数的request参数同样会把该数据接收,并存放在GET键对应的值中。

    3. views文件中的request参数

    (1)reques参数内容

    • request参数接收的是前端发送到服务端来的数据,其数据格式是一个字典。我们可以通过request.键名的方式取到对应的值。

    (2)request的方法

    1. request.method

      • 获取当前的请求方式,取到的值是全大写的字符串
    2. request.POST

      • 获取用户post请求提交的数据,得到的是一个字典数据格式。且其键值对的格式是:key:[]

      (1)request.POST.get(key)

      • 获取key对应的列表的最后一个值。

      (2)request.POST.getlist(key)

      • 获取key对应的整个列表
    3. request.GET

      • 使用方法和request.POST一模一样。

    4. pycharm连接数据库

    • 就是把pycharm当做可视化工具

    5. Django连接MySQL

    • 必须要有两大操作

    (1)settings文件中配置连接文件

    DATABASES = {
    						'default': {
    						'ENGINE': 'django.db.backends.mysql',  # 指定数据库类型
    						'NAME': 'day49',  # 指定库的名字
    						'USER':'root',  # 注意 键必须是全大写
    						'PASSWORD':'123qwe',
    						'HOST':'127.0.0.1',
    						'PORT':3306,
    						'CHARSET':'utf8'
    					}
    				}
    

    (2)改变Django默认的连接数据库模块

    • Django默认用来连接数据库的模块是MySQLdb

    • 我们可以再项目文件夹下的__init__.py文件或者应用文件夹下的__init__.py文件中书写下面的语句。

      import pymysql
      pymysql.install_as_MySQLdb()
      

    二、 Django的orm简介

    1. orm

    • orm就是对象关系映射。

      • 类——》表
      • 对象——》表中的行数据(记录)
      • 对象点属性——》字段的属性
    • orm有什么用

      • 它封装了各个接口,通过这些接口(接口就是我们封装后的那个方法),能够让不会数据库操作的人也能够简单方便的去操作数据库。
    • orm的缺点

      • 封装程度太高,有时候会出现查询效率偏低的问题。
      • 工作中,对于简单的,可以用orm来操作,复杂的,追求速度的话,U需要我们自己手动书写SQL语句。

    2. Django中如何使用orm

    • 书写模型类:取应用的models.py文件中书写模型类(就是一个个类)

    • 注意:之后在写django项目的时候 一个django就对应一个数据库
      不要出现多个项目使用同一个数据的情况

    3. 数据库迁移(同步)命令

    • 注意:下面两条命令必须是成双成对出现,只要修改了models里面跟数据库相关的代码 你就必须重新执行下面两条命令
    1.python3 manage.py makemigrations  # 将数据库的修改 记录到小本本上(migrations文件内)
    	
    2.python3 manage.py migrate         # 将修改操作真正的同步到数据库中
    

    4. 模型表字段的增删改查

    字段的增加、修改:
    
    直接修改代码 然后执行数据库迁移命令即可(两条一条不能少)
    # 方式1  设置默认值
    email = models.EmailField(default='123@qq.com')  # varchar
    # 方式2   允许字段为空
    phone = models.BigIntegerField(null=True)
    # 直接在提示中给默认值
    gender = models.CharField(max_length=32)
    
    字段的删除:
    直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)
    

    5. 模型表数据的增删改查

    查:
    
    (1)有条件查询:
    data = models.User.objects.filter(username=username) 
    
    
    # data的结果: <QuerySet [<User: User object>]>
    		"""
    		filter返回的结果是一个"列表",里面才是真正数据对象
    		推荐使用 .first()的方法取出列表中的第一个对象,当然也支持索引取值和索引切片。
    		filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
    		"""
    (2)无条件查询:    
    user_list = models.User.objects.all()  
    # models.User.objects.filter()
    		"""
    		结果是一个"列表" 里面是一个个的数据对象
    		"""
    增:
    user_obj = models.User.objects.create(username=username,password=password)
    print(user_obj,user_obj.username,user_obj.password)
    # create方法会有一个返回值  返回值就是当前被创建的对象本身
    		
    改:
    		models.User.objects.filter(id=edit_id).update(username=username,password=password)
            """
            批量操作  会将filter查询出来的列表中所有的对象全部更新
            """
    	
    删(一般情况下不会使用)
    models.User.objects.filter(id=delete_id).delete()
    		"""
    			批量操作  会将filter查询出来的列表中所有的对象全部删除
    		"""
    
  • 相关阅读:
    单精度和双精度
    @Transactional注解用法
    JPA No EntityManager with actual transaction available for current thread
    上传文件Request Entity Too Large解决办法
    PG数据库查看当前会话和结束会话
    Chrome浏览器记不住密码也不提示保存密码win10
    ARM平台VMP保护开发入门
    关于我
    HDU7072:Boring data structure problem——题解
    HDU7067:Just another board game——题解
  • 原文地址:https://www.cnblogs.com/Mcoming/p/11914101.html
Copyright © 2011-2022 走看看