首页 > 数据库 >Django 三板斧的使用 链接数据库

Django 三板斧的使用 链接数据库

时间:2023-11-09 21:34:30浏览次数:47  
标签:get 三板斧 数据库 request django print contrib Django middleware

Django

  • 三板斧的使用
  • 全局配置文件
  • 静态文件的配置
  • request对象的几个方法
  • pycharm链接数据库MySQL
  • Django链接数据库MySQL
  • ORM的使用

今日内容详细

三板斧的使用

三个方法:
HttpResponse 
render
redirect

def index(request):
    print('request')
    # return HttpResponse("request") # 它返回的是字符串
    # return render(request, 'index.html') # 加载HTML页面的
    # return redirect('http://www.baidu.com') # 加载HTML页面的
    return redirect('/home/') # 重定向的

全局配置文件

LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = False

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

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',
]

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config', # 这是全写
]

静态文件的配置

静态文件: 
    类似于HTML文件
    类似于CSS文件
    类似于js文件
    图片
    第三方的前端框架(jQuery、bootstrap)
    ...
    # 直接拿来就使用的都是静态文件的
    
# 静态文件存在Django框架的哪个位置?
"""
	我们一般把静态文件放在框架下的static文件夹,但是,默认情况下没有这个文件夹,因此,需要我们手动创建出来这个文件夹static
	静态的html一般放在templaes文件夹下面
"""

# 我们一般还会在static文件夹下进一步的划分目录
css
js
img
...
/index
/home

"""我们访问不到一个地址,是因为在Django里面没有开设这样一个地址,Django帮你加了,你只需要按照我的规则添加即可"""
http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/css/bootstrap.min.css

{%  %}  # 一般写跟逻辑相关的
{{  }}  # 跟变量相关的
    
## 动态解析
{% load static %}

<script src="{% static 'js/jquery_3.7.1_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>


"""这个配置是访问静态文件的令牌"""
STATIC_URL = '/dasdasdasdas/'

"""其实就是static文件夹的路径"""
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static'),
    os.path.join(BASE_DIR, 'static1'),
    os.path.join(BASE_DIR, 'static2')
]

request对象的方法

HTML

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    {% load static %}
    <script src="{% static 'js/jquery.js' %}"></script>
    <link href="{% static 'css/bootstrap.min.css' %}" rel="stylesheet">
    <script src="{% static 'js/bootstrap.min.js' %}"></script>
</head>


<body>
<div class="container">
    <div class="row">
        <h1 class="text-center">登录页面</h1>
        <form action="" method="post">
            <div class="form-group">
                用户名: <input type="text" class="form-control" name="username">
            </div>
             <div class="form-group">
                密码: <input type="password" class="form-control" name="password">
            </div>
            <div class="form-group">
                <input type="checkbox" name="hobby" value="哈哈">哈哈
                <input type="checkbox" name="hobby" value="嘿嘿嘿">嘿嘿嘿
                <input type="checkbox" name="hobby" value="呵呵呵">呵呵呵
            </div>
            <div class="form-group">
                <input type="submit" class="btn btn-success btn-block" value="登录">
            </div>
        </form>
    </div>
</div>
</form>
</body>
</html>
<form action="" method="post">
action:
	1. 不写,朝当前地址提交
    2. 全写
    3. 只写后缀
    
# post提交表单,前期先把下面的代码注释掉
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',
]


def login(request):
    # 判断请求方式来区分是get还是post
    """如何在后端判断是什么请求方式"""
    print(request.method, type(request.method))
    print(request.GET)
    print(request.GET.get('a'))
    print(request.GET.get('b'))
    print(request.GET.get('c'))
    print(request.GET.getlist('c'))

# print(request.POST) # 获取以post请求方式提交的表单数据
# print(request.POST.get('username')) # kevin 获取以post请求方式提交的表单数据
# print(request.POST.get('password')) # 123 获取以post请求方式提交的表单数据
"""get获取默认拿到的是最后一个元素值"""
# print(request.POST.get('hobby')) # 3 获取以post请求方式提交的表单数据
# ['a', 'b', 'c']
username = request.POST.get('username')
password = request.POST.get('password')
print(request.POST.getlist('hobby')) # 3 获取以post请求方式提交的表单数据

request.method == 'POST':

pycharm链接数据库


django链接数据库

配置完链接数据的代码之后,Django默认启动不起来了,原因是:内部使用的链接模块用的是mysqldb
我们不使用这个模块,我们使用pymysql模块

# 如何更换pymysql
在任意的__init__.py文件中添加一下代码
import pymysql
pymysql.install_as_MySQLdb()

# 后续还有一个模块:mysqlclient,这个模块不需要加任何的代码
这个模块一般装不上,不容易装上,很容易报错

orm介绍

orm: 对象映射模型
在Django中操作数据库就不用在写原生的SQL语句,而是使用面向对象的语法和一些方法来操作数据库
缺点:代码的封装程度太高,导致的问题:执行效率下降了,目前可以忽略,需要自己写原生SQL语句

类名					>>>  			表名
对象					>>>				一条记录
属性					>>>				一个字段

## 我们的这些orm在哪里书写呢?
models.py这个文件就是跟数据库打交道的

## 类名写好之后,一定别忘了做数据库迁移命令
***************************************************************************************
python38 manage.py makemigrations  # 生成迁移的记录(类似以是一个小本本)
python38 manage.py migrate		  # 这句话才是真正的操作了数据库,然后生成表
"""当你修改了跟数据量相关的代码之后,都要执行这两句话"""
***************************************************************************************

标签:get,三板斧,数据库,request,django,print,contrib,Django,middleware
From: https://www.cnblogs.com/zhangfanshixiaobai/p/17822905.html

相关文章

  • Django框架的基本使用
    在启动django项目的时候一定要确保一个端口只有一个项目创建项目后必须检查settings的app是否注册和templates的DIRSdjango默认的端口号是8000浏览器缓存(开发者面板操作)浏览器右键检查-settings设置-networks网络-disablecache(禁用缓存)命令行操作先选择要创建项目的存储......
  • Django简介
     django官方文档:https://docs.djangoproject.com/ 技术方面翻译文档:https://yiyibooks.cn/ 大而全:自身携带的功能非常多缺陷:开发小项目时使用该框架过于笨重(不建议)django默认端口号:8000   django框架版本计算机名称内最好不要含有中文(我的电脑-右键-属性)......
  • MySQL千万级数据库查询怎么提高查询效率
     查询效率慢的原因: 1:没有加索引或者索引失效  where条件使用如下语句会索引失效:null、!=、<>、or连接、in(非要使用,可用关键字exist替代)和notin、'%abc%';  使用参数:num=@num、表达式操作:wherenum/2=100、函数操作:wheresubstring(name,1,3)=‘abc’-name;   --e......
  • Linux 查看数据库和表
    连接数据库mysql-hlocalhost-u用戶名-p密碼使用数据库usedesk_show;显示数据表showtables;显示表结构describedesk6_0;mysql其他命令:显示数据库showdatabases;创建数据库createdatabasename;选择数据库usedatabasename;执行命令source/root/20151010.sq......
  • 数据库设计心得
    我们的项目是基于隐私包含的众包系统。在设计之前,我们先把需求搞清楚。业务需求雇主能发布需求,工人能接单,完成任务。哈哈,听上去还挺简单的,但涉及到雇主取消需求,雇主取消任务,工人根据标签查询需求,工人提交工作文件,工人取消订单这些功能。初步设计确定了工人,雇主,管理员,需求,订单,......
  • 一文读懂 Fabarta ArcGraph 图数据库丨技术解读
    导读 本文将深入探讨图数据库的发展历程、Fabarta自研图数据库ArcGraph的产品优势,以及 ArcGraph 如何充分利用图和向量数据库的融合优势,为AI技术的发展提供强大支持。图数据库最早诞生于上世纪六七十年代,起源于对复杂网络结构的理解和处理需求。随着社交网络、知识图谱......
  • 【故障公告】数据库服务器今年第六次 CPU 100% 故障
    自9月第五次数据库服务器CPU100%故障之后,今天下午又出现数据库服务器CPU100%故障,是今年的第六次。自从园子2013年搬上阿里云,几乎每年都会遇到数据库服务器CPU100%问题,但今年创造了新记录,一年还未结束,却已遭遇六次,最困难的一年,连故障也过来凑热闹。今天的故障发生于14......
  • neo4j图数据库
    目录neo4j说明docker-compose安装命令创建节点创建节点关系创建节点并建立关系更新节点和关系查询节点和关系删除节点及关系golang执行cypher命令--创建节点golang执行cypher命令2--创建节点+建立关系neo4j说明 Neo4j是一个高性能的NOSQL图形数据库,它将结构化数据存储在网络上而......
  • C# EntityFramework+SQLite CodeFirst 创建数据库和数据表
    1、安装NuGet包System.Data.SQLite(System.Data.SQLite.Core、System.Data.SQLite.EF6、System.Data.SQLite.Linq)SQLite.CodeFirstEntityFramework2、配置App.config<?xmlversion="1.0"encoding="utf-8"?><configuration><configSe......
  • 大型数据库实验三
    实验三--熟悉常用的HBase操作1、列出HBase所有表的信息,例如表名2、在终端打印出指定的表的所有的就数据3、向已经创建好的表中添加或者删除指定的列族或列添加数据:删除数据:4、清空指定的表的所有的数据5、统计表的行数6、将下面的关系数据库,转换为合适的hbase格......