Django request对象与ORM简介

form表单

form表单默认是以get请求提交数据的

http://127.0.0.1:8000/login/?username=admin&password=123

action参数

    1.不写 默认朝当前地址提交数据

    2.全路径

    3.后缀(/index)

提交post请求的时候 需要先去配置文件中注释掉一行(中间件)

视图函数应该做到针对不同的请求,做出不同的处理逻辑

- get请求来   应该只需要返回一个html文件

- post请求来   应该获取用户提交的数据,然后做进一步处理

所以你必须要能够判断出当前请求到底是什么请求。

 

request对象

获取前端请求方式

request.method  # 结果是一个纯大写的字符串  GET/POST

通常情况下针对不同的请求应该做不同的处理

def login(request):
    # if request.method =='GET':
    #     #GET逻辑
    #     return render(request, 'login.html')
    # elif request.method =='POST':
    #     #POST逻辑
    #     print(request.method, type(request.method))  # POST <class 'str'>
    #     return HttpResponse('收到了你的数据,马上处理')      
    # print(request.method)  #获取前端请求方式
    """为了减少代码的层级:一般情况下视图函数处理get请求较多,所以可以直接在函数体内先写GET请求对应的逻辑
    将其他请求利用request.method做出区分
    """
    if request.method == 'POST':
        return HttpResponse('收到了')
    return render(request, 'login.html')


获取POST请求提交的数据:

request.POST #类似于是一个大字典
             # <QueryDict: {'username': ['admin', 'jason'], 'password': ['123']}>
        request.POST.get()  # 只会取列表最后一个元素
        request.POST.getlist()  # 取出整个列表

如下所示,是一个简易的登录页面 login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    {% 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>
</head>
<body>
<div class="container">
    <div class="row">
        <div class="col-md-8 col-md-offset-2">
            <h2 class="text-center">登录</h2>
            <form action="" method="post">
                <p>username:<input type="text" name="username" class="form-control"></p>
{#                <p>username:<input type="text" name="username" class="form-control"></p>#}
                <p>password:<input type="text" name="password" class="form-control"></p>
{#                <p>hobby:#}
{#                    bbb<input type="checkbox" name="hobby" value="bbb">#}
{#                    aaa<input type="checkbox" name="hobby" value="aaa">#}
{#                    ccc<input type="checkbox" name="hobby" value="ccc">#}
{#                </p>#}
                <input type="submit" class="btn btn-success ">
            </form>
        </div>
    </div>
</div>
</body>
</html>
View Code

针对login.html页面进行相应地取值和处理的逻辑操作

def login(request):
    if request.method == 'POST':
        #如何获取数据(GET和POST)
        print(request.POST) #获取post请求携带的数据
        #获取用户的用户名与密码
        # <QueryDict: {'username': ['hank'], 'password': ['123']}>
        username = request.POST.get('username')  # 用get取值只会取列表最后一个元素
        password = request.POST.get('password')
        print(username,type(username))  #hank <class 'str'>
        print(password,type(password))  #123 <class 'str'>
        #如果你想直接拿到列表
        hobby = request.POST.getlist('hobby') # getlist取到的是一个列表
        print(hobby,type(hobby)) #['bbb', 'aaa', 'ccc'] <class 'list'>

        return HttpResponse('收到了')
    return render(request, 'login.html')

获取符合GET请求携带数据格式的数据:

一般产生GET请求的场景:

1.浏览器地址栏输入url回车

2.超链接地址 <a href="地址?参数=值>

3.form表单中的method为get

 

注意:GET请求获取的数据格式和POST一样

request.GET # 获取符合get请求携带数据格式的数据 url?xxx=yyy&ooo=lll # <QueryDict: {'username': ['admin', 'jason'], 'password': ['123']}> request.GET.get() # 只会取列表最后一个元素 request.GET.getlist() # 取出整个列表

针对login.html页面进行相应地取值和处理的逻辑操作

def login(request):
    if request.method == 'POST':
        #如何获取数据(GET和POST)
        print(request.POST) #获取post请求携带的数据
        #获取用户的用户名与密码
        # <QueryDict: {'username': ['hank'], 'password': ['123']}>
        username = request.POST.get('username')  # 用get取值只会取列表最后一个元素
        password = request.POST.get('password')
        print(username,type(username))  #hank <class 'str'>
        print(password,type(password))  #123 <class 'str'>
        #如果你想直接拿到列表
        hobby = request.POST.getlist('hobby') # getlist取到的是一个列表
        print(hobby,type(hobby)) #['bbb', 'aaa', 'ccc'] <class 'list'>

        return HttpResponse('收到了')
print(request.GET) print(request.GET.get('username'),type(request.GET.get('username'))) print(request.GET.getlist('password'),type(request.GET.getlist('password'))) return render(request,'login.html')

Django连接数据库

前提:Django连接数据库,需要你自己提前创建好对应的库

1.先去配置文件中配置相关参数

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', #数据库的类别
        'NAME': 'db1',  #库的名字
        'HOST':'127.0.0.1',
        'PORT': 3306,
        'USER': 'root',
        'PASSWORD': '123',
        'CHARSET': 'utf8'
    }
}
# 对于python3的使用者们还需要再加一步操作 # 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替 # 如下设置放置的与项目同名或者应用下的 __init__.py文件中 import pymysql pymysql.install_as_MySQLdb()

Django ORM简介

django orm不会帮你创建库  只能帮你自动创建表

orm对象关系映射:

类  ------->  表

对象 -------> 记录

属性  ------->  字段值

首先需要先去对应的应用下的models.py中书写你的模型类(表)

class User(models.Model):
    # id int primary key auto_increment
   #当你没有指定主键的时候,django orm会自动帮你创建一个名为id的主键字段
   #一旦检测到你自己创建了主键字段,那么就不会再帮你创建
id = models.AutoField(primary_key=True) # name varchar(32) name = models.CharField(max_length=32) # password int password = models.IntegerField()

数据库迁移(同步)命令

python3 manage.py makemigrations  # 仅仅是将你对数据库的改动记录到某个小本本上(migrations文件夹)

python3 manage.py migrate  # 将改动真正的同步到数据库中

"""
上面两个命令必须是成对出现的
"""

只要你动了models.py跟数据库相关的代码 你就必须要重新执行上面的两条命令来保证数据库与models.py一致

字段的增删改查

字段的增

  1.要么给该字段设置默认值
  2.要么允许该字段可以为空

字段的改

直接修改表中字段的代码 之后执行数据库迁移命令即可

字段的删

只要注释掉对应的字段 执行数据库迁移命令就会将对应的字段及数据信息全部删除(慎用)

 数据的增删改查

查询数据

1、filter()

from app01 import models
res
= models.User.objects.filter(username='hank') # select * from user where username='jason' # 返回的res是一个列表 user_obj = res.first() # filter方法条件不存在的时候,不会报错,而是返回一个空列表

""" filter括号内直接放多个关键字参数 并且多个关键字参数之间是and关系 """ # select * from user where username='jason' and password='123'; res = models.User.objects.filter(username='jason',password='123')

见如下详情:

from app01 import models

def login(request):
    if request.method == 'POST':
        username = request.POST.get('username')  # 用get取值只会取列表最后一个元素
        password = request.POST.get('password')

        #查询数据库
        #下面返回的结果可以看作是一个列表,
        res = models.User.objects.filter(name=username)
        # print(res) # <QuerySet [<User: User object>]>
        #user_obj = res[0]  # QuerySet支持索引取值但是不支持负数,不推荐使用
        user_obj = res.first() #User object
        print(user_obj.name,user_obj.password)
        return HttpResponse('收到了')
    return render(request,'login.html')

2、查所有的数据

filter() 括号内不写任何参数就是 查询所有数据

all()  查询所有数据

user_queryset = models.User.objects.filter()
'''
or
'''
user_queryset = models.User.objects.all()

增加数据

准备:先写好一个注册的html页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    {% 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>
</head>
<body>
<div class="container">
    <div class="row">
        <div class="col-md-8 col-md-offset-2">
            <h2 class="text-center">注册</h2>
            <form action="" method="post">
                <p>username:<input type="text" name="username" class="form-control"></p>
{#                <p>username:<input type="text" name="username" class="form-control"></p>#}
                <p>password:<input type="text" name="password" class="form-control"></p>
{#                <p>hobby:#}
{#                    bbb<input type="checkbox" name="hobby" value="bbb">#}
{#                    aaa<input type="checkbox" name="hobby" value="aaa">#}
{#                    ccc<input type="checkbox" name="hobby" value="ccc">#}
{#                </p>#}
                <input type="submit" class="btn btn-primary ">
            </form>
        </div>
    </div>
</div>
</body>
</html>
register.html

方法1、create()

def reg(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        #直接朝数据库中添加数据
        user_obj = models.User.objects.create(name=username,password=password)
        print(user_obj,user_obj.name)
    return render(request,'register.html')

方法2、对象的绑定方法

#1 先生成一个User对象
user_obj = models.User(name=username, password=password)
#2 调用对象的绑定方法
user_obj.save()

 

删除数据

准备一个用户展示页home.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
{#    <link href="https://cdn.bootcss.com/twitter-bootstrap/3.4.1/css/bootstrap.min.css" rel="stylesheet">#}
{#    <script src="https://cdn.bootcss.com/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>#}
    {% 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>
</head>
<body>
<div class="container">
    <div class="row">
        <div class="col-md-8 col-md-offset-2">
            <h1 class="text-center">数据展示</h1>
            <table class="table table-striped table-hover">
                <thead>
                    <tr>
                        <th>id</th>
                        <th>name</th>
                        <th>password</th>
                        <th>operation</th>
                    </tr>
                </thead>
                <tbody>
                    {% for user_obj in res %}  <!--[user_obj1,user_obj2...]-->
                        <tr>
                            <td>{{ user_obj.id }}</td>
                            <td>{{ user_obj.name }}</td>
                            <td>{{ user_obj.password }}</td>
                            <td>
                                <a href="/edit_user/?edit_id={{ user_obj.id }}" class="btn btn-primary btn-xs">编辑</a>
                                <a href="/delete_user/?delete_id={{ user_obj.id }}" class="btn btn-danger btn-xs">删除</a>
                            </td>
                        </tr>
                    {% endfor %}

                </tbody>
            </table>

        </div>
    </div>
</div>
</body>
</html>
home.html
models.User.objects.filter(id=1).delete()  # 将filter过滤出来的数据全部删除   批量删除

见如下详情:

def del_user(request):
    # 获取用户想要删除的数据id
    delete_id = request.GET.get('delete_id')
    # 直接根据id删除数据
    models.User.objects.filter(id=delete_id).delete() #将filter过滤出来的数据全部删除
    #重定向到展示页
    return redirect('/home')

修改数据

# 方式一(推荐)       批量更新
models.User.objects.filter(id=1).update(name=username,password=password)
# 方式二(了解) # 1.先获取数据对象 edit_obj = models.User.objects.filter(id=1).first() # 2.再修改对象属性 edit_obj.name = username edit_obj.password = password # 3.调用对象的绑定方法保存 edit_obj.save()

见如下详情:

def edit_user(request):
    #获取用户想要修改的数据id值
    edit_id = request.GET.get('edit_id')
    if request.method == 'POST':
        #获取用户修改之后的用户名和密码
        username = request.POST.get('username')
        password = request.POST.get('password')
        # 修改数据
        # 方式一
        models.User.objects.filter(id=edit_id).update(name=username,password=password)
        # 方式二
        # 1.先获取数据对象
        edit_obj =models.User.objects.filter(id=edit_id).first()
        # 2.再修改对象属性
        edit_obj.name = username
        edit_obj.password = password
        # 3.调用对象的绑定方法保存
        edit_obj.save()
        #再次跳转到数据展示页
        return redirect('/home')
    #根据id获取数据对象,并且展示到html页面上
    edit_obj = models.User.objects.filter(id=edit_id).first()
    return render(request,'edit_user.html',{'edit_obj':edit_obj})

 

posted @ 2020-01-04 20:09  Hank·Paul  阅读(444)  评论(0编辑  收藏  举报