1. 静态文件的配置

1.默认情况下所有的html文件都是放在templates文件夹内的

2.什么是静态文件

网站所使用到的提前写的css  js 第三方的前端模块,图片都叫做静态资源

3.默认情况下网站所使用的静态文件资源全部都会放在static文件夹内

手动创建static文件夹,根据静态资源分别创建子文件夹:
通常情况下,在static文件夹内还会再见其他文件夹: css 文件夹
js 文件夹
font 文件夹
img 文件夹
Bootstrap
fontawesome(图标库)
为了更加方便的管理文件 django中 需要你自己手动创建静态文件存放的文件夹
  • 视图函数都必须有返回值,并且返回值都是HttpResponse对象
  • 用户在浏览器中输入的网址能够访问到相应的资源,前提是后端提前开设该资源的访问接口,后端没开设则会出现404

手动静态文件的访问资源

  • django后端如果想暴露后端资源,必须去url里面开设对应的资源接口

    引入bootstrap时会报404找不到,需要去后端中配置
    settings文件中,最下面手动开设静态文件访问资源,手动添加以下代码 # 将static文件里的所有资源都暴露给用户
    STATICFILES_DIRS = [
    os.path.join(BASE_DIR,'static')
    ]
STATIC_URL = '/static/'  # 访问静态文件资源接口前缀  通常情况下接口前缀的名字也叫static	(接口前缀叫什么,配置文件中也需要使用什么)

# 手动开设静态文件访问资源
STATICFILES_DIRS = [ # 静态资源所在的文件夹路径
os.path.join(BASE_DIR,'static'), # 将static文件里面所有的资源暴露给用户
os.path.join(BASE_DIR,'static1'), # 将static文件里面所有的资源暴露给用户
]
接口前缀会向STATICFILES_DIRS文件路径中查找路径文件夹,自上而下

静态文件的动态绑定

{% load static %}
<link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
  • 小技巧:清除浏览区页面使用的缓存

    浏览器检查 -- settings -- Network -- Disable cache(禁止缓存)

2.request方法

2.1 请求方式

  • form表单默认是get请求

    将form表单中改为method = 'post',post请求

    get请求也能携带参数,在url? 后面
    1.携带的数据不安全
    2.携带的数据大小会有限制
    3.通常只会携带一些不是很重要的数据
  • action = " "

    1.不写 默认朝当前地址提交
    2.只写后缀 /index
    3.写全路径 https://www.baidu.com
  • 前期我们在朝后端提交post请求出现forbidden(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',
    ]
  • django后端的视图函数 默认处理的是get请求无论是发get请求还是post请求 都会执行视图函数

    def login(request):
    print('来啦 老弟~')
    return render(request,'login.html')
get请求指向拿到login页面
post请求想提交数据 然后后端做校验

2.2 获取前端的请求方式

如何判断当前请求方式

request.method

request.method 拿到的是字符串大写的请求方式 GET POST

def login(request):
# if request.method == 'GET':
# print('来啦 老弟~')
# print(request.method,type(request.method)) # 获取前端请求方式
# return render(request,'login.html')
# elif request.method == 'POST':
# print('post业务逻辑')
# return HttpResponse('收到了')
if request.method == "POST":
return HttpResponse('收到了')
return render(request,'login.html')

2.3 request方法

如何获取用户提交的post数据,后端获取前端的数据都会变为字符串类型

request.method

获取请求方式  并且纯大写的字符串

request.POST

获取用户提交的post请求数据

如何获取用户数据(******)
request.POST.get() # 默认只会获取列表最后一个元素
request.POST.getlist() # 如果你想获取列表 用getlist()

request.GET

获取用户提交的get请求数据

request.GET.get()  # 默认只会获取列表最后一个元素request.GET.getlist()  # 如果你想获取列表 用getlist()   

.get方法

request.get方法默认只取列表的最后一个元素,
如果直接获取列表,使用get.list

3. pycharm连接MySQL

先安装插件

连接之后,apply确认.

以下操作:

4. django连接MySQL数据库

必须有两步操作

4.1.配置文件配置

settings文件配置中DATABASES 添加键值对

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

4.2.指定使用的数据库连接模块

主动告诉django 不要用默认的mysqldb连接 而是用pymysql

  • 你可以在项目名下的__init__.py中书写
  • 也可以在应用名下的__init__.py中书写
import pymysql
pymysql.install_as_MySQLdb()

5.django orm简介

5.1 基本概念

1. orm对象关系映射

类 				表对象
数据对象点属性 字段对应的值

2. 为什么使用orm

能够让不会数据库操作的人也能够简单方便去操作数据库

3. 缺点

封装程度太高  有时候会出现查询效率偏低的问题
所以工作中
简单的用orm
复杂的 追速度 需要你手动书写sql语句

5.2 django中操作orm

书写模型类
去应用下的models.py中书写模型类(就是类)
  • 之后在写django项目的时候 一个django就对应一个数据库
  • 不要出现多个项目使用同一个数据的情况(******)
  • 当不指定主键的时候django会自动创建一个名为id 的字段作为主键
  • 如果自己创建了,django就不会创建
  • django中默认没有char字段,但支持用户自定义

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

创建orm字段的后必须要执行同步命令

1.python3 manage.py makemigrations

记录操作: 将数据库的修改 记录到小本本上(migrations文件内)

2.python3 manage.py migrate

操作执行: 将修改操作真正的同步到数据库中

  • 上面命令必须同时出现
  • 只要修改了models里面跟数据库相关的代码 你就必须重新执行上面两条命令

创建表后

2. 模型表类字段的增删改查

修改字段

直接修改代码,然后执行数据库迁移命令即可

添加字段

models.IntegerField()	执行迁移命令
注意设置默认值
# 方式1 设置默认值
email = models.EmailField(default='123@qq.com') # varchar
# 方式2 允许字段为空
phone = models.BigIntegerField(null=True)
# 直接在提示中给默认值
gender = models.CharField(max_length=32)

删除字段

直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)

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

查询数据.filter()

data = models.User.objects.filter(username=username)  

print(data)		# <QuerySet [<User: User object>]>

  • filter返回的结果是一个"列表",里面才是真正数据对象
  • filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系

查询所有的数据.all()*

user_list = models.User.objects.all()  # models.User.objects.filter()

"""
结果是一个"列表" 里面是一个个的数据对象
"""

取值

支持索引取值,但推荐使用.first()方法取值

支持切片,但不支持负数

增加数据.create()

create方法会有一个返回值 返回值就是当前被创建的对象本身

user_obj = models.User.objects.create(username=username,password=password)
print(user_obj,user_obj.username,user_obj.password)

更改数据.update()

.filter().update()

models.User.objects.filter(id=edit_id).update(username=username,password=password)
"""
批量操作 会将filter查询出来的列表中所有的对象全部更新
"""

删除数据.filter().delete()

批量操作 会将filter查询出来的列表中所有的对象全部删除

models.User.objects.filter(id=delete_id).delete()
"""
批量操作 会将filter查询出来的列表中所有的对象全部删除
"""

总结

  1. 创建app需要在settings中注册app
INSTALLED_APPS
'app01'
  1. 三剑客

    1. render 前端页面
    2. HttpResponse() 提交字符串
    3. redirect() 重定向
  2. cmd创建app时需要在settings中TEMPLATES添加路径
'DIRS': [os.path.join(BASE_DIR, 'templates')]

  1. 默认情况下所有的html文件都放在template文件夹内

  2. 静态文件: 网站所提前写好的css,js,第三方模块,图片都叫做静态文件

  3. 默认情况下网站所用到的静态文件全部放在 static文件夹内,文件夹内部根据需求不同,再次分目录存放

  4. 手动创建static文件夹,将bootstrap放入文件夹内,并导入

  5. 开通接口,将静态文件资源导入,settings中最下面,手动添加STATICFILES_DIRS = [ os.path.join(BASE_DIR,'static') ]

  6. 静态文件动态绑定

    {% load static %}
    <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
    <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
  7. 更改form表单的数据提交方式 post

  8. 前期朝后端提交post请求出现403情况,需要去settings文件中注册一行数据

    MIDDLEWARE
    
    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',
    ]
  9. .method方法获取请求方式(大写POST或GET)

  10. 配置mysql的连接django方式

    settings中DATABASES中添加连接端口
    'ENGINE': 'django.db.backends.mysql',更改 DATABASES = {
    'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME': 'day50', # 指定库的名字
    'USER':'root', # 注意键全大写
    'PASSWORD':'',
    'HOST':'127.0.0.1',
    'PORT':3306,
    'CHARSET':'utf8'
    }
    }

    更改连接库

    在项目名中的__init__中添加
    应用名中的__init__中添加
    import pymysql
    pymysql.install_as_MySQLdb()
  11. 数据库迁移指令

    python manage.py makemigrations	# 记录操作
    
    python manage.py migrate		# 操作保存
    
    
  12. 只要修改了models里与数据库子弹相关的代码,就必须重新执行两个命令

  13. charField字段 必须指定max_length参数

  14. 新增字段设置默认值

    1. 代码中设置default =
    2. 使默认值为空 null = true
    3. 报错后选1输入默认值

1122 django属性操作orm字段数据操作的更多相关文章

  1. Django框架06 /orm多表操作

    Django框架06 /orm多表操作 目录 Django框架06 /orm多表操作 1. admin相关操作 2. 创建模型 3. 增加 4. 删除 5. 修改 6. 基于对象的跨表查询 7. 基于 ...

  2. Django框架05 /orm单表操作

    Django框架05 /orm单表操作 目录 Django框架05 /orm单表操作 1. orm使用流程 2. orm字段 3. orm参数 4. orm单表简单增/删/改 5. orm单表查询 5 ...

  3. Django——8 关系表的数据操作 表关联对象的访问 多表查询

    Django 关系表中的数据操作 表关联对象的访问 关联对象的add方法 create方法 remove方法 clear方法 多表查询 查询补充 聚合查询 分组查询 F查询 Q查询 关系表的数据操作 ...

  4. Django聚合查询 orm字段及属性

    目录 一 聚合查询 1. 级联 级联删除 级联更新 2. 聚合函数 使用 aggregate 使用场景 3. 分组查询 语法 使用 annotate 代码 4. F与Q查询 F查询 Q查询 二 ORM ...

  5. Django框架之ORM对表结构操作

    ORM的优点:(1)简单,不用自己写SQL语句 (2)开发效率高 ORM的缺点:对于不同的人写的代码,执行效率有差别 ORM的对应关系: 类  ---------->  数据表 对象------ ...

  6. Django框架之ORM的相关操作之分页(六)

    分页是每个项目必不可少要写的一个功能,该篇文章就将记录一下使用ORM写分页的过程. 假设我们的数据库里面需要显示一些数据,而这个表中的数据大约有几千条数据,那么我们不可能将所有的数据都显示出来,那么就 ...

  7. MySQL(二)表的操作与简单数据操作

    六大约束:主键约束.外键约束.非空约束.唯一约束.默认约束.自动增加 1.not null非空 2.defaul默认值,用于保证该字段的默认值 ; 比如年龄:1900-10-10 3.primar k ...

  8. django框架基础-ORM跨表操作-长期维护

    ###############    一对一跨表查询    ################ import os if __name__ == '__main__': os.environ.setde ...

  9. django框架基础-ORM单表操作-长期维护

    ###############    单表操作-添加数据    ################ import os if __name__ == '__main__': os.environ.set ...

随机推荐

  1. 使用 LVS 实现负载均衡原理及安装配置详解(课堂随笔)

    一.负载均衡LVS基本介绍 LB集群的架构和原理很简单,就是当用户的请求过来时,会直接分发到Director Server上,然后它把用户的请求根据设置好的调度算法,智能均衡地分发到后端真正服务器(r ...

  2. 自组织特征映射神经网络(SOFM)

    1981年芬兰 Helsink 大学的 T·Kohonen 教授提出一种自组织特征映射网 (Self-Organizing Feature Map , SOFM ), 又称 Kohonen 网 . K ...

  3. Spring 消息转换器和注解控制器

    目录 1.什么是消息转换器? 2.消息转换器结构:HttpMessageConverter 3.Spring 调用逻辑 3.1 HandlerMethodArgumentResolver 接口 和 H ...

  4. visual studio 2017搭建linux c++开发环境

    https://blog.csdn.net/cekonghyj/article/details/77917433 https://blog.csdn.net/norsd/article/details ...

  5. python 线程创建和传参(28)

    在以前的文章中虽然我们没有介绍过线程这个概念,但是实际上前面所有代码都是线程,只不过是单线程,代码由上而下依次执行或者进入main函数执行,这样的单线程也称为主线程. 有了单线程的话,什么又是多线程? ...

  6. Vmware问题: 开机提示“虚拟机已被打开,是否获得所有权?”& Vmware检测不到USB

    "一只美丽的小鸟,在绿色的草坪上蹦来跳去,很是可爱"----清风徐来 问题1: Vmware开机提示"虚拟机已被打开,是否获得所有权?" 解决: 关闭虚拟机,用 ...

  7. PHP,Excel导出换行

    // 有id,才算真的有发票数据 if ($v['b_invoice_id']) { $v['b_invoice_info'] = json_decode($v['b_invoice_json'],t ...

  8. LeetCode 199. 二叉树的右视图(Binary Tree Right Side View)

    199. 二叉树的右视图 199. Binary Tree Right Side View 题目描述 给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值. Giv ...

  9. EFCore 通过实体Model生成创建SQL Server数据库表脚本

    在我们的项目中经常采用Model First这种方式先来设计数据库Model,然后通过Migration来生成数据库表结构,有些时候我们需要动态通过实体Model来创建数据库的表结构,特别是在创建像临 ...

  10. Bean配置

    1.xml配置(摘抄自:https://www.cnblogs.com/zyx1301691180/p/7665971.html) 一.setter方法配置Bean: 1.创建一个 Spring Be ...