django中实现数据库操作

在Django中,数据库操作通常通过Django的ORM(Object-Relational Mapping)来实现。ORM允许你使用Python类来表示数据库表,并可以使用Python语法来查询和操作数据库。

以下是在Django中实现数据库操作的基本步骤:

一:定义模型
首先,你需要在Django应用中定义模型。模型是数据库表的抽象表示,通常定义在models.py文件中。例如,假设我们有一个名为Person的模型,可以像这样定义:

from django.db import models  
  
class Person(models.Model):  
    name = models.CharField(max_length=100)  
    age = models.IntegerField()

二:运行迁移(Migrations)


在定义了模型后,需要运行迁移以在数据库中创建相应的表。可以通过以下命令来创建和应用迁移:

python manage.py makemigrations  
python manage.py migrate

三:查询数据库
Django的ORM提供了许多方法来查询数据库。以下是一些基本示例:

获取所有记录:

persons = Person.objects.all()

获取特定记录:

person = Person.objects.get(name="John Doe")

过滤记录:

persons = Person.objects.filter(age__gt=30)

要插入新记录,可以创建模型的实例并调用save()方法。例如:

new_person = Person(name="Jane Doe", age=25)  
new_person.save()

要更新记录,可以获取该记录的实例,修改其属性,然后再次调用save()方法。例如:

person = Person.objects.get(name="Jane Doe")  

person.age = 30  

person.save()

要删除记录,可以调用delete()方法。例如:

person = Person.objects.get(name="Jane Doe")  
person.delete()

这些只是Django ORM的一些基本功能。Django还提供了许多高级功能,如复杂查询、聚合、事务管理等。

事物操作例子:

以下是一个使用Django ORM进行数据库事务的简单例子:

 

首先,假设我们有两个模型:BankAccount 和 Transaction。

from django.db import models  

  

class BankAccount(models.Model):  

    account_name = models.CharField(max_length=100)  

    balance = models.DecimalField(max_digits=10, decimal_places=2)  

  

class Transaction(models.Model):  

    from_account = models.ForeignKey(BankAccount, on_delete=models.CASCADE, related_name='transactions_from')  

    to_account = models.ForeignKey(BankAccount, on_delete=models.CASCADE, related_name='transactions_to')  

    amount = models.DecimalField(max_digits=10, decimal_places=2)

现在,我们想要执行一个转账操作,即从一个账户扣款并给另一个账户存款。这个操作需要确保原子性,即如果扣款成功但存款失败,那么扣款操作也应该被撤销。

from django.db import transaction  

from .models import BankAccount, Transaction  

  

def transfer_money(from_account_name, to_account_name, amount):  

    try:  

        # 开始一个新的事务  

        with transaction.atomic():  

            # 获取账户实例  

            from_account = BankAccount.objects.get(account_name=from_account_name)  

            to_account = BankAccount.objects.get(account_name=to_account_name)  

  

            # 检查转账金额是否有效  

            if from_account.balance < amount:  

                raise ValueError("Insufficient balance")  

  

            # 创建转账记录  

            transaction = Transaction(  

                from_account=from_account,  

                to_account=to_account,  

                amount=amount  

            )  

            transaction.save()  

  

            # 更新账户余额  

            from_account.balance -= amount  

            from_account.save()  

  

            to_account.balance += amount  

            to_account.save()  

  

            # 如果一切顺利,事务将在此处提交  

  

    except ValueError as e:  

        # 如果发生错误,事务将在此处回滚  

        print(f"Transaction failed: {e}")  

  

    except Exception as e:  

        # 其他任何异常也会导致事务回滚  

        print(f"An error occurred: {e}")  

  

# 使用示例  

transfer_money("Alice", "Bob", 100)

在上面的代码中,transfer_money 函数使用 transaction.atomic() 上下文管理器来确保转账操作在事务中执行。如果在转账过程中遇到任何错误(例如,账户余额不足或数据库保存失败),那么事务将自动回滚,所有更改都不会保存到数据库中。

为了更深入地了解Django的数据库操作,建议查阅Django官方文档。

 

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

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

相关文章

2.11 假期作业

1、若有以下说明语句&#xff1a;int a[12]{1,2,3,4,5,6,7,8,9,10,11,12};char c’a’,d,g;则数值为4的表达式是&#xff08;D&#xff09;。 A&#xff09;a[g-c] B&#xff09;a[4] C&#xff09;a[‘d’-‘c’] D&#xff09;a[‘d’-c] 2、假…

C++入门篇——类与对象重点解析(中篇)

1. 类的6个默认成员函数 如果一个类中什么成员都没有&#xff0c;简称为空类。 空类中真的什么都没有吗&#xff1f;并不是&#xff0c;任何类在什么都不写时&#xff0c;编译器会自动生成以下6个默认成员函数。 class Date {}; 默认成员函数&#xff1a;用户没有显式实现&a…

WordPress修改所有用户名并发送邮件通知的插件Easy Username Updater

前面跟大家介绍了『如何修改WordPress后台管理员用户名&#xff1f;推荐2种简单方法』一文&#xff0c;但是对于有很多用户的站长来说&#xff0c;操作有点复杂&#xff0c;而且无法发邮件通知对方&#xff0c;所以今天boke112百科向大家推荐一款可以直接在WordPress后台修改所…

Rust语言之哈希表

文章目录 哈希表&#xff08;Hash map)一、新建哈希表二、访问某个元素索引访问GET方法 二、插入新元素三、遍历哈希表四、检查某个元素是否存在contains_key方法entry方法 五、元素更新使用contains_keyinsert 的方法使用entry方法 六、删除元素 Rus设计语言官方教程 哈希表&…

全面详细对比@Resource和@Autowired

版权声明 本文原创作者&#xff1a;谷哥的小弟作者博客地址&#xff1a;http://blog.csdn.net/lfdfhl Resource和Autowired概述 在Java的Spring框架中&#xff0c;Resource和Autowired都是用于实现依赖注入&#xff08;Dependency Injection, DI&#xff09;的重要注解。依赖…

洛谷UVA题目Unknown Error

UnexpectedResponseStatus: expect status code: 301 Moved Permanently on https://onlinejudge.org/index.php?optioncom_comprofiler&tasklogin, got: 200 OK 如果你绑定了账号&#xff0c;去原站Online Judge - Home 登录一下&#xff0c;好久没登陆&#xff0c;需要激…

[2-远程开发-01]idea远程连接开发

背景 因为本次的项目使用到一些网络相关的库只在linux可使用&#xff0c;项目本身也会在linux运行&#xff0c;而且如果在mac上进行开发的话&#xff0c;也涉及到部署的问题&#xff0c;而且也不能调试。 所以直接在本专栏第一篇的centos主机上进行开发&#xff0c;以远程连接…

Junit常用断言

0.断言简介 断言:assert Q:断言的作用 更方便的对结果进行判定 "有针对性"的if判断 针对两个变量值是否相同 使用assertEquals针对两个对象是否相同 使用assertSame针对返回值是否为True 使用assertTrue 1.断言的参数 assertXXX(”断言失败时提升的信息“&#x…

MD5 哈希

md5DigestAsHex 是 Spring Framework 中 DigestUtils 类的一个方法&#xff0c;用于计算 MD5 哈希并返回十六进制表示的字符串。这个方法的主要作用是将输入的字节数组进行 MD5 哈希处理&#xff0c;并返回结果的十六进制表示形式。 MD5&#xff08;Message Digest Algorithm …

【开源】SpringBoot框架开发校园疫情防控管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 学生2.2 老师2.3 学校管理部门 三、系统展示四、核心代码4.1 新增健康情况上报4.2 查询健康咨询4.3 新增离返校申请4.4 查询防疫物资4.5 查询防控宣传数据 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVueSpringBoot…

C# Thread的使用

在C#中&#xff0c;线程用于实现程序的并发执行。通过创建和管理多个线程&#xff0c;可以同时处理不同的任务或操作&#xff0c;从而提高程序性能和响应性。以下是如何在C#中使用线程的基本步骤&#xff1a; 创建新线程 // 使用System.Threading命名空间 using System.Threa…

【Java程序设计】【C00253】基于Springboot的在线考试管理系统(有论文)

基于Springboot的在线考试管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的在线考试系统 本系统分为系统功能模块、管理员功能模块以及用户功能模块。 系统功能模块&#xff1a;系统登录&#xff0c;管理…

WordPress后台编辑个人资料页面直接修改用户名插件Change Username

前面跟大家介绍了『如何修改WordPress后台管理员用户名&#xff1f;推荐2种简单方法』一文&#xff0c;但是对于新站长或者有很多用户的站长来说&#xff0c;操作有点复杂&#xff0c;所以今天向大家推荐一款可以直接在WordPress后台编辑个人&#xff08;用户&#xff09;资料页…

网络安全漏洞管理十大度量指标

当前&#xff0c;网络安全漏洞所带来的风险及产生的后果&#xff0c;影响到网络空间乃至现实世界的方方面面&#xff0c;通信、金融、能源、电力、铁路、医院、水务、航空、制造业等行业各类勒索、数据泄露、供应链、钓鱼等网络安全攻击事件层出不穷。因此&#xff0c;加强对漏…

python打印圆形

要打印一个圆形&#xff0c;你可以使用turtle模块来绘制图形。以下是一个示例代码&#xff1a; import turtledef draw_circle(radius):turtle.penup()turtle.goto(0, -radius)turtle.pendown()turtle.circle(radius)# 调整画笔速度&#xff08;可选&#xff09; turtle.speed…

【GameFramework框架内置模块】1、全局配置(Config)

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 【GameFramework框架】系列教程目录&#xff1a; https://blog.csdn.net/q7…

vue安装使用less,解决与webpack的冲突

第077个 查看专栏目录: VUE ------ element UI 专栏目标 在vue和element UI联合技术栈的操控下&#xff0c;本专栏提供行之有效的源代码示例和信息点介绍&#xff0c;做到灵活运用。 提供vue2的一些基本操作&#xff1a;安装、引用&#xff0c;模板使用&#xff0c;computed&a…

Git分支规范和迭代流程

Git分支 feature分支&#xff1a;功能分支 dev分支&#xff1a;开发分支 test分支&#xff1a;测试分支 master分支&#xff1a;生产环境分支 hotfix分支&#xff1a;bug修复分支。从master拉取&#xff0c;修复并测试完成merge回master和dev。 某些团队可能还会有 reale…

Day47- 动态规划part15

一、不同的子序列 题目一&#xff1a;115. 不同的子序列 115. 不同的子序列 给你两个字符串 s 和 t &#xff0c;统计并返回在 s 的 子序列 中 t 出现的个数&#xff0c;结果需要对 109 7 取模。 定义一个二维数组dp&#xff0c;其中dp[i][j]表示s的前i个字符中t的前j个字符…