1122 django属性操作orm字段数据操作
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查询出来的列表中所有的对象全部删除
"""
总结
- 创建app需要在settings中注册app
 
INSTALLED_APPS
	'app01'
- 三剑客
- render 前端页面
 - HttpResponse() 提交字符串
 - redirect() 重定向
 
 - cmd创建app时需要在settings中TEMPLATES添加路径
 
'DIRS': [os.path.join(BASE_DIR, 'templates')]
默认情况下所有的html文件都放在template文件夹内
静态文件: 网站所提前写好的css,js,第三方模块,图片都叫做静态文件
默认情况下网站所用到的静态文件全部放在 static文件夹内,文件夹内部根据需求不同,再次分目录存放
手动创建static文件夹,将bootstrap放入文件夹内,并导入
开通接口,将静态文件资源导入,settings中最下面,手动添加
STATICFILES_DIRS = [ os.path.join(BASE_DIR,'static') ]静态文件动态绑定
{% 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>更改form表单的数据提交方式 post
前期朝后端提交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',
].method方法获取请求方式(大写POST或GET)配置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()数据库迁移指令
python manage.py makemigrations # 记录操作 python manage.py migrate # 操作保存只要修改了models里与数据库子弹相关的代码,就必须重新执行两个命令
charField字段 必须指定max_length参数
新增字段设置默认值
- 代码中设置default =
 - 使默认值为空 null = true
 - 报错后选1输入默认值
 
1122 django属性操作orm字段数据操作的更多相关文章
- Django框架06 /orm多表操作
		
Django框架06 /orm多表操作 目录 Django框架06 /orm多表操作 1. admin相关操作 2. 创建模型 3. 增加 4. 删除 5. 修改 6. 基于对象的跨表查询 7. 基于 ...
 - Django框架05 /orm单表操作
		
Django框架05 /orm单表操作 目录 Django框架05 /orm单表操作 1. orm使用流程 2. orm字段 3. orm参数 4. orm单表简单增/删/改 5. orm单表查询 5 ...
 - Django——8   关系表的数据操作  表关联对象的访问  多表查询
		
Django 关系表中的数据操作 表关联对象的访问 关联对象的add方法 create方法 remove方法 clear方法 多表查询 查询补充 聚合查询 分组查询 F查询 Q查询 关系表的数据操作 ...
 - Django聚合查询 orm字段及属性
		
目录 一 聚合查询 1. 级联 级联删除 级联更新 2. 聚合函数 使用 aggregate 使用场景 3. 分组查询 语法 使用 annotate 代码 4. F与Q查询 F查询 Q查询 二 ORM ...
 - Django框架之ORM对表结构操作
		
ORM的优点:(1)简单,不用自己写SQL语句 (2)开发效率高 ORM的缺点:对于不同的人写的代码,执行效率有差别 ORM的对应关系: 类 ----------> 数据表 对象------ ...
 - Django框架之ORM的相关操作之分页(六)
		
分页是每个项目必不可少要写的一个功能,该篇文章就将记录一下使用ORM写分页的过程. 假设我们的数据库里面需要显示一些数据,而这个表中的数据大约有几千条数据,那么我们不可能将所有的数据都显示出来,那么就 ...
 - MySQL(二)表的操作与简单数据操作
		
六大约束:主键约束.外键约束.非空约束.唯一约束.默认约束.自动增加 1.not null非空 2.defaul默认值,用于保证该字段的默认值 ; 比如年龄:1900-10-10 3.primar k ...
 - django框架基础-ORM跨表操作-长期维护
		
############### 一对一跨表查询 ################ import os if __name__ == '__main__': os.environ.setde ...
 - django框架基础-ORM单表操作-长期维护
		
############### 单表操作-添加数据 ################ import os if __name__ == '__main__': os.environ.set ...
 
随机推荐
- [C语言]小知识点 持续更新
			
2019-11-24 1.如果输入: printf(,)); 会得到0: 这和我们的日常判断不相符! 然而,改成: printf(,)); 就可以成功输出“2”: 因此,注意pow函数返回的是浮点数, ...
 - QT QML之Label, TextField
			
现在不是去想缺少什么的时候,该想一想凭现有的东西你能做什么.------ 海明威 <老人与海> Label { id: tipLabel width: 120 height: 40 tex ...
 - HTTP权威指南-报文与状态码
			
所有的报文都向下流动 报文流向 报文组成 HTTP方法 状态码 GET示例 HEAD示例 100~199 信息性状态码 200~299 成功状态码 300~399重定向状态码 400~499 客户端错 ...
 - Android中使用LitePal操控SQLite数据库
			
<第一行代码>读书手札 (一)什么是LitePal数据库 LitePal数据库是安卓的一个开源库,我们在以后的开发中,将会遇到许许多多的开源库,感谢开源社 区:因为开源社区的存在,一些我们 ...
 - 玫瑰花小制作分享-JavaScript(七夕专属浪漫)
			
分享一个玫瑰花的制作小方法,用小小的代码给自己的她送上一个不一样的玫瑰花. 玫瑰花代码由JavaScript实现,JavaScript 作为一种脚本语言, 被发明用于在 HTML 网页上使用,可以给H ...
 - PAT甲级题分类汇编——排序
			
本文为PAT甲级分类汇编系列文章. 排序题,就是以排序算法为主的题.纯排序,用 std::sort 就能解决的那种,20分都算不上,只能放在乙级,甲级的排序题要么是排序的规则复杂,要么是排完序还要做点 ...
 - 【转载】Maven入门实践
			
Maven 确确实实是个好东西,用来管理项目显得很方便,但是如果是通过 Maven 来远程下载 JAR 包的话,我宿舍的带宽是4兆的,4个人共用,有时候用 Maven 来远程下载 JAR 包会显得很慢 ...
 - Scratch(二)来不及解释了,马上开始编程游戏
			
来来来,上一期你们都经过了”HelloWorld”神咒的加持,已入编程大门,我们今天就开始一边做游戏,一边熟悉Scratch. “我只是切出去抢了个红包,一回来就到了编程游戏的环节了?” 对,你没跑错 ...
 - shiro登录验证简单理解
			
这两天接手了下师兄的项目,要给系统加个日志管理模块,其中需要记录登录功能的日志,那么首先要知道系统的登录是在哪里实现验证的. 该系统把所有登录验证还有权限控制的工作都交给了shiro. 这篇文章就先简 ...
 - Python之算法模型-5.1
			
一.这里学习的算法模型包含监督学习和非监督学习两个方式的算法. 其中监督学习的主要算法分为(分类算法,回归算法),无监督学习(聚类算法),这里的几种算法,主要是学习他们用来做预测的效果和具体的使用方式 ...