放弃原生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 作用域函数:理解 apply, let, 和 with

Kotlin提供了几个作用域函数来优化和简化代码的结构。 本文将对比分析 apply, let, 和 with 三个函数。 一、对比分析: apply:在其接收者的上下文中执行代码块,并返回接收者对象。let:在其接收者的上下文中执行代码块&#xff…

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不一样导致要重新…

数据结构和算法专题---5、调度算法与应用

本章我们会对调度算法做个简单介绍&#xff0c;包括常用的调度算法&#xff08;FCFS、SJF、RR、HPF&#xff09;的概述、实现方式、典型场景做个说明。 什么是调度算法 调度算法常见于操作系统中&#xff0c;因为系统资源有限&#xff0c;当有多个进程&#xff08;或多个进程…

Oracle 怎樣修改DB_NAME

DBNEWID 是一个数据库实用程序&#xff0c;用于更改 Oracle 数据库的 DBNAME 和 DBID。可以更改 DBID 或 DBNAME 或两者。 DBNAME 是在创建数据库时指定的数据库名称&#xff0c;DBID 是创建数据库时分配给数据库的唯一编号。 以下步骤演示如何使用 DBNEWID 实用程序更改 Oracl…

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

【论文阅读笔记】序列数据的数据增强方法综述 摘要 这篇论文探讨了在深度学习模型中由于对精度的要求不断提高导致模型框架结构变得更加复杂和深层的趋势。随着模型参数量的增加&#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 …

python程序大全(9)——鼠标乱动恶搞小病毒(有资源)

目录 &#x1f3c6;一、前言 &#x1f3c6;二、程序第一版 &#x1f3c6;三、程序大魔改 &#x1f6a9;1、基础改动 &#x1f6a9;2、打包 &#x1f6a9;3、F12保护机制 &#x1f6a9;4、添加开机自启项 &#x1f6a9;5、自己也不懂的线程魔改 &#x1f3c6;四、最终代码 &…

排列游戏 --- 动态规划 --- 题解

目录 排列游戏 题目描述 输入描述: 输出描述: 输入 输出 备注: 思路&#xff1a; 代码&#xff1a; 排列游戏 K-排列游戏_牛客竞赛动态规划专题班习题课 (nowcoder.com) 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#…

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

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

vue中滚轮缩放事件

在Vue中&#xff0c;可以使用原生JS的滚轮事件监听来实现滚轮缩放&#xff1a; 首先在模板中给需要监听滚轮事件的元素添加一个ref属性&#xff0c;用于在Vue中获取元素节点。 <template><div ref"scale"><!-- 需要缩放的内容 --></div> &…

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

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