配置文件、request对象请求方法、Django连接MySQL、Django中的ORM、ORM增删改查字段、ORM增删改查数据

一、配置文件的介绍

1.注册应用的
INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','app01.apps.App01Config',
]################中间件#############################################################
2.中间件
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',
]
################中间件#############################################################
ROOT_URLCONF = 'day54_dj.urls' # 根路由的文件名3.Django连接MySQL数据库的
DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3','NAME': os.path.join(BASE_DIR, 'db.sqlite3'),}
}LANGUAGE_CODE = 'zh-hans' 
TIME_ZONE = 'Asia/Shanghai'

配置文件settings.py

"""
Django settings for day54 project.Generated by 'django-admin startproject' using Django 1.11.20.For more information on this file, see
https://docs.djangoproject.com/en/1.11/topics/settings/For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.11/ref/settings/
"""import os# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/# SECURITY WARNING: keep the secret key used in production secret!
# 固定盐
SECRET_KEY = 'k)_am7d@*mbelt*c*i84r$8^a%1#f7^_6cxa$esk47pa+a^tkm'# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = TrueALLOWED_HOSTS = []# DEBUG = False
# ALLOWED_HOSTS = [*]# Application definition
# 注册应用
from django.contrib import admin
INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','app01.apps.App01Config', # 全称
]# 中间件
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',
]# 跟路由文件
ROOT_URLCONF = 'day54.urls'# 模板
TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates',# 'DIRS': [BASE_DIR / 'templates'],'DIRS': [os.path.join(BASE_DIR, 'templates')],'APP_DIRS': True,'OPTIONS': {'context_processors': ['django.template.context_processors.debug','django.template.context_processors.request','django.contrib.auth.context_processors.auth','django.contrib.messages.context_processors.messages',],},},
]#
WSGI_APPLICATION = 'day54.wsgi.application'# Database
# https://docs.djangoproject.com/en/1.11/ref/settings/#databases
# 连接数据库
DATABASES = {# 'default': {#     'ENGINE': 'django.db.backends.sqlite3',#     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),# },'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'db17','HOST': '127.0.0.1','PORT': 3306,'USER': 'root','PASSWORD': 'root','CHARSET': 'utf8'},
}# Password validation
# https://docs.djangoproject.com/en/1.11/ref/settings/#auth-password-validators
# 验证认证
AUTH_PASSWORD_VALIDATORS = [{'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',},{'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',},{'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',},{'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',},
]# Internationalization
# https://docs.djangoproject.com/en/1.11/topics/i18n/
# 英文
# LANGUAGE_CODE = 'en-us'
# 中文
LANGUAGE_CODE = 'zh-hans'
# 时区
# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'USE_I18N = TrueUSE_L10N = TrueUSE_TZ = True# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/
# 静态文件的配置,访问静态文件的令牌,以后只要访问静态文件的路径,就要以  /static/  开头
STATIC_URL = '/static/'STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')
]# 动态解析路径

二、静态文件的配置

# 以登录功能为例<form action="">action参数的三种情况:1. 什么都不写,就是朝当前地址提交数据2. 要么全写:http://127.0.0.1:8000/login/?username=&password=3. 只写后缀http://127.0.0.1:8000/login/
"""我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建我们一般把静态文件放在static文件夹中,  但是,需要我们自己手动创建出来这个文件夹静态文件:网站使用的CSS文件网站使用的js文件网站使用图片网站使用的第三方库文件jQuery、bootstrap等"""
1.可以针对不同的功能对static文件夹里面的文件进行拆分
css
js
img
...注意:看起来是对的,但是不能访问到
http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/js/bootstrap.min.js 之前访问的地址都可以访问到,那是因为在后端开设了可以访问的接口(理由)
之所以现在访问不到刚才的地址,是因为在后端没有开设这样的一个可访问的接口(路由)2.Django自动的帮我们写好了这样的接口访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/static/开头
STATIC_URL = '/vxcvxcvxcvxcvcx/'  # 静态文件STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')
]3.动态解析路径
{% load static %}
<script src="{% static 'js/jquery.min.js' %}"></script>
<link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>

三、request对象请求方法

request.method  # 请求方式 GET POST
print(request.POST) # <QueryDict: {'username': ['jason'], 'password': ['123']}>
print(request.POST.get('username'))  # ['jason'] # jasonprint(request.GET)  # <QueryDict: {'username': ['jason'], 'password': ['123']}>
print(request.GET.get('username'))  # ['jason'] # jason

1.request的请求方法

在 Django 中,`request` 对象是在视图函数中作为参数传递的,它包含了客户端发起的 HTTP 请求信息,包括请求的方法。在视图函数中,你可以通过 `request.method` 属性获取请求方法。常见的 HTTP 请求方法有以下几种:1. GET:用于从服务器获取数据,通常用于请求页面或资源。
2. POST:用于向服务器提交数据,通常用于提交表单数据或执行某些操作。
3. PUT:用于更新服务器上的资源,通常用于更新已有数据。
4. DELETE:用于删除服务器上的资源,通常用于删除某个数据。在 Django 中,通过检查 `request.method` 属性,你可以判断请求的方法,并根据不同的方法执行不同的操作。下面是一个示例:from django.http import HttpResponsedef my_view(request):if request.method == 'GET':# 处理 GET 请求return HttpResponse("这是一个 GET 请求")elif request.method == 'POST':# 处理 POST 请求return HttpResponse("这是一个 POST 请求")elif request.method == 'PUT':# 处理 PUT 请求return HttpResponse("这是一个 PUT 请求")elif request.method == 'DELETE':# 处理 DELETE 请求return HttpResponse("这是一个 DELETE 请求")else:# 处理其他未知方法return HttpResponse("未知请求方法")在上面的例子中,视图函数 `my_view` 根据不同的请求方法返回不同的响应内容。根据实际需求,你可以在视图函数中根据请求方法执行相应的逻辑和操作。需要注意的是,要使用 `request` 对象,你需要在视图函数的参数列表中将它传递进来,例如:`def my_view(request):`。在 Django 中,视图函数的第一个参数通常是 `request` 对象,它包含了客户端发起的请求信息。

2.什么是request对象

在 Django 中,`request` 对象是一个包含了客户端发起的 HTTP 请求信息的对象。它是在 Django 视图函数中作为参数传递的,用于处理来自用户浏览器或其他客户端的请求。`request` 对象包含了许多属性和方法,其中包括:1. `request.method`: 获取请求的 HTTP 方法,例如 GET、POST、PUT、DELETE 等。
2. `request.GET`: 包含了 GET 请求参数的字典。可以通过 `request.GET.get('param_name')` 来获取具体的参数值。
3. `request.POST`: 包含了 POST 请求参数的字典。可以通过 `request.POST.get('param_name')` 来获取具体的参数值。
4. `request.FILES`: 包含了上传文件的信息,通常用于处理文件上传表单。
5. `request.path`: 获取请求的路径,例如 "/myapp/myview/"6. `request.path_info`: 获取请求的路径信息,例如 "/myapp/myview/",不包含查询参数。
7. `request.get_full_path()`: 获取请求的完整路径,包括路径和查询参数。
8. `request.is_secure()`: 判断请求是否使用了 HTTPS 安全协议。除了上述属性和方法,`request` 对象还包含其他有关请求的信息,例如请求头信息、用户 IP 地址、会话信息等。你可以通过 `request` 对象来获取客户端发起的请求数据,从而根据请求数据做出相应的处理和响应。在 Django 中,视图函数的第一个参数通常是 `request` 对象,例如:from django.http import HttpResponsedef my_view(request):# 在这里可以根据 request 对象来处理请求和返回响应# ...return HttpResponse("Hello, World!")通过使用 `request` 对象,你可以在视图函数中访问并处理客户端发起的请求数据,从而实现不同的业务逻辑和功能。

四、Django连接MySQL

1.默认情况sqlite3
DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3','NAME': os.path.join(BASE_DIR, 'db.sqlite3'),}
}2.连接MySQL
DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3','NAME': os.path.join(BASE_DIR, 'db.sqlite3'),}
}3.解决bug的思路:1. 就是print()2. 看是否有日志3. 看报错的信息去百度中搜索4. 问问别人4.连接MySQL数据的时候可能报错的解决办法:
1. 如果解释器版本导致的问题,直接改源码base.pydef get_new_connection(self, conn_params):conn = Database.connect(**conn_params)conn.encoders[SafeText] = conn.encoders[six.text_type]先判断bytes是否存在于编码器中,如果在才执行操作if bytes in conn.encoders: # 加上这句话conn.encoders[SafeBytes] = conn.encoders[bytes]return conn2. 解释器版本改为3.6的时候也会报错Django的底层默认使用的是mysqldb模块,这个模块兼容性很差我们还使用pymysql连接mysql,你要提前安装pymysql模块Did you install mysqlclient or MySQL-python?3.怎么解决这个问题:在项目的任意的__init__.py中加入下面两行代码*****************************************************************************import pymysqlpymysql.install_as_MySQLdb()  # 猴子补丁以上这两行代码的意思就是把底层的mysqldb模块换成pymysql*****************************************************************************4. 除了使用mysqldb、pymysql之外还可以使用mysqlclient这个模块用了mysqlclient这个模块,就不用加上面那两句话了mysqlclient安装的时候可能会报各种错误DATABASES = {# 'default': {#     'ENGINE': 'django.db.backends.sqlite3',#     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),# }'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'db9','HOST': '127.0.0.1','PORT': 3306,'USER': 'root','PASSWORD': 'root','CHARSET': 'utf8'}
}

五、Django中的ORM

什么是ORM:对象映射模型以后在django中写根数据库相关的代码时候,就不用再写原生的SQL语句了,直接通过python代码来操作数据的增删改查.1.orm的书写位置:在models.py中书写
概念表				>>>>>     类名记录				>>>>>    对象字段				>>>>>    属性2.创建出来一张表来所有的类必须继承models.Modelclass User(models.Model):  # 表名# id int primary key auto_incrementid = models.AutoField(primary_key=True)# username varchar(64)username = models.CharField(max_length=64)# password varchar(64)password = models.CharField(max_length=64)3.类写完之后,一定要做数据库迁移,真正的在数据库中生成表
********************************************************************************python36 manage.py makemigrations  它的作用是把数据库的迁移记录保存下来python36 manage.py migrate		   才是真正的把数据表创建出来
********************************************************************************

六、ORM增删改查字段

class Author(models.Model):'''如果创建的表中有主键字段,并且,主键字段的名字也叫id,那么,以后就可以直接省略id字段'''name = models.CharField(max_length=64)# password1 = models.CharField(max_length=128, null=True)# password1 = models.CharField(max_length=64, default='12')

七、ORM增删改查数据

如何做查询  select * from author where username = jack and password = 123objects:小组件,里面封装了很多的方法# res=models.Author.objects.filter(name=username, password=password).all() # 是and查询# res=models.Author.objects.filter(name=username, password=password) # 是and查询# res=models.Author.objects.filter(name=username).filter(password=password)# 是and查询# res=models.Author.objects.filter(name=username, password=password).first() # 是and查询res=models.Author.objects.create(name=username,password=password)# print(res)  # <QuerySet [<Author: Author object>]>  QuerySet对象以后可以点出来很多的方法# print(res)  # Author object  QuerySet对象以后可以点出来很多的方法# print(res[0].name)# print(res[0].password)# print(res.name)# print(res.password)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/11185.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UE4/5C++多线程插件制作(十三、优化,bug,尝试打包【尚未完成插件封装,初次测试】)

目录 MTPPlatform.h MTPMarco.h MTPSemaphore.h MTPSemaphore.cpp RTPRunnable.cpp 模板问题 打包问题 MTPPlatform.h 首先我们准备一个跨平台使用的头文件,在ue内部有很多关于跨平台

CSS :nth-child

CSS :nth-child :nth-child 伪类根据元素在同级元素中的位置来匹配元素. CSS :nth-child 语法 值是关键词 odd/evenAnB最新的 [of S] 语法权重 浏览器兼容性 很简单的例子, 来直觉上理解这个伪类的意思 <ul><li class"me">Apple</li><li>B…

websocket服务端,运行后始终无法连接的解决方案

javax.websocket.DeploymentException: The HTTP response from the server [404] did not permit the HTTP 解决办法&#xff1a;少两个文件&#xff1a; WebSocketConfig.java Configuration public class WebSocketConfig {/*** 注入一个ServerEndpointExporter,该Bean…

MySQL 服务器的调优策略

点击上方↑“追梦 Java”关注&#xff0c;一起追梦&#xff01; 在工作中&#xff0c;我们发现慢查询一般有2个途径&#xff0c;一个是被动的&#xff0c;一个是主动的。被动的是当业务人员反馈某个查询界面响应的时间特别长&#xff0c;你才去处理。主动的是通过通过分析慢查询…

在Microsoft Excel中如何快速合并表格

在 Excel 中分析数据时&#xff0c;在一个工作表中收集所有必要信息的频率是多少&#xff1f;几乎从来没有&#xff01;当不同的数据分散在许多工作表和工作簿中时&#xff0c;这是一种非常常见的情况。幸运的是&#xff0c;有几种不同的方法可以将多个表中的数据组合成一个表&…

机器学习深度学习——线性回归的简洁实现

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位即将上大四&#xff0c;正专攻机器学习的保研er &#x1f30c;上期文章&#xff1a;机器学习&&深度学习——线性回归的从零开始实现 &#x1f4da;订阅专栏&#xff1a;机器学习&&深度学习 希望文章对你们…

全球程序员需要知道的50+网址,有多少你第一次听说?

作为程序员&#xff0c;需要知道的50网址&#xff0c;有多少你第一次听说 GitHub (github.com): 最大的代码托管平台&#xff0c;开源项目和代码分享的社区。程序员可以在这里找到各种有趣的项目&#xff0c;参与开源贡献或托管自己的代码。 Stack Overflow (stackoverflow.co…

Python[parquet文件 转 json文件]

将Python中的Parquet文件转换为JSON文件 引言 Parquet是一种高效的列式存储格式&#xff0c;而JSON是一种常见的数据交换格式。我们将使用pandas和pyarrow库来实现这个转换过程&#xff0c;并且提供相关的代码示例。 安装所需库 首先&#xff0c;请确保您已经安装了pandas和…

Rust: Vec类型的into_boxed_slice()方法

比如&#xff0c;我们经常看到Vec类型&#xff0c;但取转其裸指针&#xff0c;经常会看到into_boxed_slice()方法&#xff0c;这是为何&#xff1f; use std::{fmt, slice};#[derive(Clone, Copy)] struct RawBuffer {ptr: *mut u8,len: usize, }impl From<Vec<u8>&g…

垃圾回收之三色标记法(Tri-color Marking)

关于垃圾回收算法&#xff0c;基本就是那么几种&#xff1a;标记-清除、标记-复制、标记-整理。在此基础上可以增加分代&#xff08;新生代/老年代&#xff09;&#xff0c;每代采取不同的回收算法&#xff0c;以提高整体的分配和回收效率。 无论使用哪种算法&#xff0c;标记…

【libevent】http客户端2:使用post 发送本地文件到服务器

HttpClient2POST的例子 看起来只post了一次?#include <stdio.h> #include <assert.h> #include <stdlib.h> #include

深入浅出Pytorch函数——torch.maximum

分类目录&#xff1a;《深入浅出Pytorch函数》总目录 相关文章&#xff1a; 深入浅出Pytorch函数——torch.max 深入浅出Pytorch函数——torch.maximum 计算input和other的元素最大值。 语法 torch.maximum(input, other, *, outNone) -> Tensor参数 input&#xff1a;…

C# OpenCvSharpe 二值化工具 阈值 自适应阈值 局部阈值 InRange

效果 阈值 自适应阈值 局部阈值 InRange 项目 VS2010.net4.0OpenCvSharper3 Demo下载

Educational Codeforces Round 152 (Rated for Div. 2)

B. Monsters 题意&#xff1a;你的攻击力为k&#xff0c;你优先攻击血量最多的怪物&#xff0c;血量相同击杀编号小的&#xff0c;问怪物被击杀的顺序&#xff0c; 思路&#xff1a;我们可以知道最后肯定存在一个状态&#xff0c;所有怪物就差一次攻击就死了&#xff0c;这个…

AWS / VPC 云流量监控

由于安全性、数据现代化、增长、灵活性和成本等原因促使更多企业迁移到云&#xff0c;将数据存储在本地的组织正在使用云来存储其重要数据。亚马逊网络服务&#xff08;AWS&#xff09;仍然是最受追捧和需求的服务之一&#xff0c;而亚马逊虚拟私有云&#xff08;VPC&#xff0…

LED芯片 VAS1260IB05E 带内部开关LED驱动器 汽车硬灯带灯条解决方案

VAS1260IB05E深力科LED芯片是一种连续模式电感降压转换器&#xff0c;设计用于从高于LED电压的电压源高效驱动单个或多个串联连接的LED。该设备在5V至60V之间的输入电源下工作&#xff0c;并提供高达1.2A的外部可调输出电流。包括输出开关和高侧输出电流感测电路&#xff0c;该…

UE4/5C++多线程插件制作(十七、封装协程管理)

目录 MTPThreadInterface.h MTPManageBase.h MTPCoroutinesManage.h MTPManage.cpp MTPManage.h 添加继承: cpp实现: MTPThreadTaskMan

双系统的一些设置

1、windows和ubuntu双系统时间不同步的问题&#xff1a; 在安装Windows和Ubuntu双系统时&#xff0c;两个操作系统会分别使用自己的时间设置。Windows默认使用本地时间&#xff08;Local Time&#xff09;&#xff0c;而Ubuntu则默认使用协调世界时&#xff08;Coordinated Un…

TypeScript 在前端开发中的应用实践

TypeScript 在前端开发中的应用实践 TypeScript 已经成为前端开发领域越来越多开发者的首选工具。它是一种静态类型的超集&#xff0c;由 Microsoft 推出&#xff0c;为开发者提供了强大的静态类型检查、面向对象编程和模块化开发的特性&#xff0c;解决了 JavaScript 的动态类…

趋动科技携手星辰天合,推出针对人工智能领域的两款联合解决方案

近日&#xff0c;趋动科技与 XSKY星辰天合联合宣布&#xff0c;结合双方优势能力和产品&#xff0c;携手推出高性能数据湖一站式方案及全协议存算一体化方案&#xff0c;帮助客户简化 AI 工作的 IT 基础设施部署&#xff0c;实现 AI 相关工作更加灵活和便捷。 全协议存算一体化…