Django学习三:views业务层中通过models对实体对象进行的增、删、改、查操作。

简介: 这篇文章是关于如何使用Django框架的ORM系统在视图(views)层面进行数据库的增、删、改、查操作的教程。

环境

  • 项目环境
    • python: 3.11.5
    • django:4.1
      在这里插入图片描述

一、Django ORM介绍

所有面向对象的语言都可以通过原生sql操作数据库。但是Django的ORM框架是特殊的,可以不通过sql,通过面向对象的方式进而操作数据库表,进行增、删、改、查。这种方式好上手,避免了不会sql的同学需要重新学习sql。扩展一下,因为我主要搞java的,所以java的ORM框架有mybatis、JPA等,相比java的ORM框架,Django这种面向对象操作数据库的ORM框架确实简单太多了。

接下来请跟随我的脚步,一起学习Django的ORM框架。

  • O(objects):类和对象。R(Relation):关系,关系数据库中的表格。M(Mapping):映射。

  • Django ORM框架的特点:

    1. 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库。
    2. 根据设计的模型类生成数据库中的表格。
    3. 通过方便的配置就可以进行数据库的切换。

二、项目快速搭建

对前面的搭建流程梳理简化。

  1. django-admin startproject test_models_django:创建项目test_models_django
  2. cd test_models_django
  3. python manage.py migrate
  4. python manage.py startapp app01:创建应用app01
  5. 主包中setting.py配置mysql数据源,根据提示安装mysqlclient

    DATABASES = {
        "default": {
            "ENGINE": "django.db.backends.mysql",
            "NAME": "数据库名",
            "USER": "用户",
            "PASSWORD": "密码",
            "HOST": "ip",
            "PORT": "3306"
        }
    }
    
  6. python manage.py runserver:运行项目

  7. http://127.0.0.1:8000/:浏览器测试。出现如下节目,则成功运行
    在这里插入图片描述

三、操作

view.py中填写如下操作
request是模仿从前端传过来的请求,这里可以进行自由替换。

1、view.py

a、增加操作

def addUser(request):
    username = request.POST.get('username')
    name = request.POST.get('name')
    password = request.POST.get('password')
    sex = request.POST.get('sex')
    age = request.POST.get('age')
    phone = request.POST.get('phone')
    email = request.POST.get('email')
    unit = request.POST.get('unit')
    models.UserData.objects.create(username=username, name=name, password=password, sex=sex, age=age, phone=phone,
                                   email=email, unit=unit)
    result = {
        'code': 0,
        'msg': 'success',
        'data': ''
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

b、删除操作

def deleteUserById(request):
    u_id = request.GET.get('u_id')
    models.UserData.objects.filter(u_id=u_id).delete()

    result = {
        'code': 0,
        'msg': 'success',
        'data': ''
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

c、修改操作

def queryUserById(request):
    u_id = request.GET.get('u_id')
    UserData = models.UserData.objects.get(u_id)
    data_list = {'dataList': UserData}
    result = {
        'code': 0,
        'msg': 'success',
        'data': data_list
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

def updateUser(request):
    u_id = request.POST.get('u_id')
    username = request.POST.get('username')
    name = request.POST.get('name')
    password = request.POST.get('password')
    sex = request.POST.get('sex')
    age = request.POST.get('age')
    phone = request.POST.get('phone')
    email = request.POST.get('email')
    unit = request.POST.get('unit')

    user_obj = models.UserData.objects.get(u_id)
    user_obj.username = username
    user_obj.name = name
    user_obj.password = password
    user_obj.sex = sex
    user_obj.age = age
    user_obj.phone = phone
    user_obj.email = email
    user_obj.unit = unit
    user_obj.save()

    result = {
        'code': 0,
        'msg': 'success',
        'data': ''
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

d、查询操作

def queryUsers(request):
    all_user_list = models.UserData.objects.filter(status__ne=9)
    all_user_total = models.UserData.objects.filter(status__ne=9).count()
    #  all_user_total = len(all_user_list)
    for item in all_user_list:
        print(item.name)
    data_list = {'dataList': all_user_list, 'totalRows': all_user_total}
    result = {
        'code': 0,
        'msg': 'success',
        'data': data_list
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

def queryUserById(request):
    u_id = request.GET.get('u_id')
    UserData = models.UserData.objects.get(u_id)
    data_list = {'dataList': UserData}
    result = {
        'code': 0,
        'msg': 'success',
        'data': data_list
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

2、urls.py

urlpatterns = [
    path('hello/', viewsUser.hello_world),
    # 用户模块
    path('queryUsers/', viewsUser.queryUsers, name='queryUsers'),
    path('queryUserById/', viewsUser.queryUserById, name='queryUserById'),
    path('addUser/', viewsUser.addUser, name='addUser'),
    path('updateUser/', viewsUser.updateUser, name='updateUser'),
    path('deleteUserById/', viewsUser.deleteUserById, name='deleteUserById'),
]
相关文章
|
1月前
|
IDE 关系型数据库 MySQL
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
这篇文章是关于如何创建一个Django框架,介绍Django的项目结构和开发逻辑,并指导如何创建应用和编写“Hello, World!”程序的教程。
37 3
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
|
1月前
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
61 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
5月前
|
编解码 前端开发 JavaScript
技术经验分享:Django学习日记
技术经验分享:Django学习日记
|
5月前
|
JSON 数据库 数据格式
使用 Django Q 对象构建复杂查询条件
通过本文示例,我们展示了如何使用Django的Q对象来构建复杂的查询条件,以及如何实现分页功能。Q对象的强大之处在于它能够轻松地组合多个查询条件,支持“与”、“或”关系,极大地提高了查询的灵活性和可读性。希望本文对你在实际项目中使用Django ORM构建复杂查询有所帮助。
|
6月前
|
测试技术 数据库 数据安全/隐私保护
实现Django Models的数据mock
实现Django Models的数据mock
74 0
|
6月前
|
Python
Django 学习教程-介绍与安装
本章介绍了Django是什么,以及为什么使用Django和安装Django
68 1
Django 学习教程-介绍与安装
|
6月前
|
调度 Apache 数据库
Django 学习教程-第一个 Django 应用
本章主要讲述了如何创建一个Django项目,以一个投票案例程序介绍了Django的请求和响应流程。
85 1
|
前端开发 数据库 网络架构
Python Django框架中文教程:学习简单、灵活、高效的Web应用程序框架
Python Django框架中文教程:学习简单、灵活、高效的Web应用程序框架
|
JSON 缓存 程序员
16 Django视图 - HttpResponse对象
16 Django视图 - HttpResponse对象
32 0
|
SQL 关系型数据库 数据库
总结一下这几天学习django的心得
总结一下这几天学习django的心得 http://www.tuicool.com/articles/jMVB3e 时间 2014-01-12 11:40:11  CSDN博客 原文  http://blog.csdn.net/jackrex/article/details/18180279 主题 Django 数据库 Python 是个门十分简洁 好用的编程语言,我之前熟悉的是Java 但是用了Python之后 ,发现python的语法还有结构十分清晰,比如强制的缩进,空行,给人的感觉是,写出来的代码很整洁,非常干净漂亮。
1355 0