放弃原生SQL:Python中更优雅的数据库操作


概要

在Python中,通过原生SQL语句进行数据库操作是一种传统的方式,但现代的Python开发中,使用ORM(Object-Relational Mapping)工具和数据库连接库可以更加高效和优雅地进行增删改查操作。本文将详细介绍Python中放弃原生SQL的理由,并演示使用ORM和数据库连接库的丰富示例代码,助你更好地理解和应用这些技术。


1. ORM的优势

ORM工具,提供了将数据库表映射为Python对象的功能。这种方式的优势在于:

1.1 面向对象

ORM允许开发者使用面向对象的方式来表示和操作数据库表,使得代码更加直观、易读、易维护。

# 使用SQLAlchemy定义一个User模型
from sqlalchemy import create_engine, Column, Integer, String, Sequence
from sqlalchemy.ext.declarative import declarative_baseBase = declarative_base()class User(Base):__tablename__ = 'users'id = Column(Integer, Sequence('user_id_seq'), primary_key=True)name = Column(String(50))age = Column(Integer)

1.2 避免SQL注入

ORM工具通常会使用参数化查询,避免了SQL注入的风险。

# 使用SQLAlchemy进行查询
user_id = 1
result = session.query(User).filter_by(id=user_id).first()

2. 使用SQLAlchemy进行数据库操作

2.1 增加数据

# 添加新用户
new_user = User(name='John Doe', age=30)
session.add(new_user)
session.commit()

2.2 查询数据

# 查询所有用户
users = session.query(User).all()
for user in users:print(f"ID: {user.id}, Name: {user.name}, Age: {user.age}")

2.3 更新数据

# 更新用户信息
user_to_update = session.query(User).filter_by(id=1).first()
user_to_update.age = 31
session.commit()

2.4 删除数据

# 删除用户
user_to_delete = session.query(User).filter_by(id=1).first()
session.delete(user_to_delete)
session.commit()

3. 使用数据库连接库进行操作

除了ORM,数据库连接库(如psycopg2mysql-connector-python等)也提供了直接执行SQL语句的方式。

import psycopg2# 连接到PostgreSQL数据库
conn = psycopg2.connect(host="your_host",database="your_database",user="your_user",password="your_password"
)# 创建游标对象
cursor = conn.cursor()# 执行SQL查询
cursor.execute("SELECT * FROM users;")
records = cursor.fetchall()
for record in records:print(record)# 关闭游标和连接
cursor.close()
conn.close()

4. 使用Django ORM进行数据库操作

对于Django开发者,Django ORM是一个强大而灵活的工具,与Django框架深度整合。以下是Django ORM的示例代码:

4.1 增加数据

# 定义一个模型
from django.db import modelsclass Author(models.Model):name = models.CharField(max_length=100)age = models.IntegerField()# 创建并保存新作者
new_author = Author(name='Jane Doe', age=25)
new_author.save()

4.2 查询数据

# 查询所有作者
authors = Author.objects.all()
for author in authors:print(f"ID: {author.id}, Name: {author.name}, Age: {author.age}")

4.3 更新数据

# 更新作者信息
author_to_update = Author.objects.get(id=1)
author_to_update.age = 26
author_to_update.save()

4.4 删除数据

# 删除作者
author_to_delete = Author.objects.get(id=1)
author_to_delete.delete()

选择适当的数据库操作方式

在实际项目中,选择使用ORM还是直接使用数据库连接库取决于多个因素。如果项目使用了Django框架,或者你更倾向于面向对象的编程方式,Django ORM是一个优秀的选择。对于其他项目,使用SQLAlchemy等独立的ORM工具或直接的数据库连接库也能提供灵活性和性能。

总体而言,选择更加符合项目需求的方式,有助于提高代码的可读性、可维护性和执行效率。在实际开发中,可以根据项目的规模、复杂性和团队的熟悉程度来综合考虑。希望本文提供的示例代码和讨论对你更好地理解和选择Python中数据库操作的方式有所帮助。

总结

本文详细介绍了在Python中放弃原生SQL的优势,并通过SQLAlchemy的ORM工具和数据库连接库展示了更为优雅和高效的数据库操作方式。使用ORM工具可以使代码更加面向对象,避免了SQL注入的风险,而数据库连接库则提供了更直接的SQL语句执行方式。在实际开发中,选择适合项目需求的方式,既可以保证代码的可读性和维护性,又能有效地进行数据库操作。

通过深入理解和实践这些数据库操作方式,更加游刃有余地处理各种数据库任务,提高开发效率。希望本文对你在Python中选择更合适的数据库操作方式有所启发。

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

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

相关文章

解决IDEA中多个项目不在同一窗口下显示的问题和添加新的git的URL

以上是添加显示多个项目 以下是给新添加的项目添加git

LeetCode算法题解(单调栈)|LeetCode84. 柱状图中最大的矩形

一、LeetCode84. 柱状图中最大的矩形 题目链接:84. 柱状图中最大的矩形 题目描述: 给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大…

做外贸很多时候还是要学会随机应变

马上又要到年底了,相信已经有一部分小伙伴开启了催单模式,希望客户尽量在春节前将订单落实下来,自然也有很多客户会在春节前的这一段时间开始陆续拜访自己观望了很久的工厂。 其实对于贸易公司来说,对于来看工厂的客户&#xff0…

ChatGPT,作为一种强大的自然语言处理模型,具备显著优势,能够帮助您在各个领域取得突破

2023年随着OpenAI开发者大会的召开,最重磅更新当属GPTs,多模态API,未来自定义专属的GPT。微软创始人比尔盖茨称ChatGPT的出现有着重大历史意义,不亚于互联网和个人电脑的问世。360创始人周鸿祎认为未来各行各业如果不能搭上这班车…

Kotlin:内置函数let、also、with、run、apply

前言 在Kotlin中,有一些用于扩展 & 方便开发者编码的内置函数,能大大提高开发者的开发效率。今天,我将主要讲解的是: let函数also函数with函数run函数apply函数 基础知识:接口回调中Lambda使用 在Kotlin中可使用…

栈和队列的互相实现

用队列实现栈 OJ链接 请你仅使用两个队列实现一个后入先出(LIFO)的栈,并支持普通栈的全部四种操作(push、top、pop 和 empty)。 实现 MyStack 类: void push(int x) 将元素 x 压入栈顶。int pop() 移除并返…

Mybatis XML增删操作(结合上文)

先来"增"操作 在UserInfoXMLMapper.xml里面写 <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <…

nginx多端口部署

1.配置nginx.conf文件 有几个端口需要部署就写几个server&#xff0c;我这里只部署了两个端口分别为80和81端口&#xff0c;所以有两个server文件。80端口项目入口在根目录的test文件中&#xff0c;81端口项目入口在根目录的test1文件夹中。 2.准备项目文件html文件 在/test1…

Dockerfile部署Java项目挂载使用外部配置文件

Dockerfile部署Java项目挂载使用外部配置文件 技术博客 http://idea.coderyj.com/ 需求是由于java项目使用的是nacos 而且每次部署nacos服务器ip不一样导致要重新打包,想引入外部配置文件进行打包 1.需求是由于java项目使用的是nacos 而且每次部署nacos服务器ip不一样导致要重新…

【论文阅读笔记】序列数据的数据增强方法综述

【论文阅读笔记】序列数据的数据增强方法综述 摘要 这篇论文探讨了在深度学习模型中由于对精度的要求不断提高导致模型框架结构变得更加复杂和深层的趋势。随着模型参数量的增加&#xff0c;训练模型需要更多的数据&#xff0c;但人工标注数据的成本高昂&#xff0c;且由于客观…

将RK3399的挖掘机开发板在Android10下设置系统默认为24小时制

将RK3399的挖掘机开发板在Android10下设置系统默认为24小时制 2023/12/9 22:07 应该也可以适用于RK3399的Android12系统 --- a/frameworks/base/packages/SettingsProvider/res/values/defaults.xml b/frameworks/base/packages/SettingsProvider/res/values/defaults.xml -2…

MagicAnimate

简介 新加坡国立大学 Show 实验室和字节联合做了一项类似的研究。他们提出了一个基于扩散的框架 MagicAnimate&#xff0c;旨在增强时间一致性、忠实地保留参考图像并提升动画保真度。并且&#xff0c;MagicAnimate 项目是开源的&#xff0c;目前推理代码和 gradio 在线 demo …

外包干了三年,我承认我确实废了……

没错&#xff0c;我也干过外包&#xff0c;一干就是三年&#xff0c;三年后&#xff0c;我废了…… 虽说废的不是很彻底&#xff0c;但那三年我几乎是出差了三年、玩了三年、荒废了三年&#xff0c;那三年&#xff0c;我的技术能力几乎是零成长的。 说起这段三年的外包经历&a…

Ubuntu中编译出Windows的可执行程序(.exe)

1、前言 在嵌入式开发中&#xff0c;交叉编译是很常见的情况&#xff0c;如果你把Windows电脑也看做一块高性能的开发板&#xff0c;那在Ubuntu中编译出Windows上运行的可执行程序也是很好理解的行为。 2、安装mingw64环境 sudo apt-get install mingw-w64 3、测试编译链是否安…

打破常规思维:Scrapy处理豆瓣视频下载的方式

概述 Scrapy是一个强大的Python爬虫框架&#xff0c;它可以帮助我们快速地开发和部署各种类型的爬虫项目。Scrapy提供了许多方便的功能&#xff0c;例如请求调度、数据提取、数据存储、中间件、管道、信号等&#xff0c;让我们可以专注于业务逻辑&#xff0c;而不用担心底层的…

Vue2与Vue3的语法对比

Vue2与Vue3的语法对比 Vue.js是一款流行的JavaScript框架&#xff0c;通过它可以更加轻松地构建Web用户界面。随着Vue.js的不断发展&#xff0c;Vue2的语法已经在很多应用中得到了广泛应用。而Vue3于2020年正式发布&#xff0c;带来了许多新的特性和改进&#xff0c;同时也带来…

rpc原理与应用

IPC和RPC&#xff1f; RPC 而RPC&#xff08;Remote Procedure Call&#xff09;&#xff0c;又叫做远程过程调用。它本身并不是一个具体的协议&#xff0c;而是一种调用方式。 gRPC 是 Google 最近公布的开源软件&#xff0c;基于最新的 HTTP2.0 协议&#xff0c;并支持常见…

【SQLite】SQLite3约束总结

前面学习了SQLite数据库的常见使用方法&#xff0c;其中包含许多约束&#xff0c;常见的如NOT NULL、DEFAULT、UNIQUE、PRIMARY KEY&#xff08;主键&#xff09;、CHECK等 本篇文章主要介绍这些约束在SQLite中的使用 目录 什么是约束NOT NULL 约束DEFAULT约束UNIQUE约束PRIMA…

【设计模式-3.2】结构型——适配器模式

说明&#xff1a;本文介绍设计模式中结构型设计模式中的&#xff0c;适配器模式&#xff1b; 插头转换器 适配器模式属于结构型设计模式&#xff0c;设计思想体现在结构上的。以插头转换器为例&#xff0c;当你需要给手机充电&#xff0c;但是眼前只有一个三孔插座&#xff0…

二叉树结点个数、叶子结点个数、树的高度、第k层结点个数的计算(C语言)

目录 前言 分治算法 模拟二叉树代码 结点个数计算 错误方法 不便利方法 基于分治思想的方法 叶子结点个数 树的高度 第k层结点的个数 前言 在链式二叉树的前序、中序、后续遍历中我们模拟了一棵二叉树&#xff0c;并实现了它的前、中、后序遍历&#xff0c;现在我们来…