【Python】使用SQLAlchemy操作Mysql数据库

一、SQLAlchemy 介绍

SQLAlchemy是Python的SQL工具包和对象关系映射(ORM)库,它提供了全套的企业级持久性模型,用于高效、灵活且优雅地与关系型数据库进行交互。使用SQLAlchemy,你可以通过Python类来定义数据库表的结构,并通过这些类与数据库进行交互,而无需编写复杂的SQL语句。

以下是SQLAlchemy的一些主要特点和功能:

  1. ORM(对象关系映射):SQLAlchemy允许你使用Python类来定义数据库表,并将这些类映射到数据库中的实际表。这使得你可以使用Python代码来创建、查询、更新和删除数据库记录,而无需编写大量的SQL代码。
  2. 灵活的查询系统:SQLAlchemy提供了一个强大而灵活的查询系统,允许你构建复杂的查询语句,包括连接、子查询、聚合函数等。你可以使用Python的语法和逻辑来构建这些查询,而无需直接编写SQL。
  3. 事务管理:SQLAlchemy支持事务管理,允许你在一组数据库操作中执行提交、回滚等操作,以确保数据的完整性和一致性。
  4. 模式/表结构反射:SQLAlchemy可以读取数据库中的表结构,并将其转换为Python的模型代码。这对于理解和操作现有的数据库结构非常有用。
  5. 可连接池:SQLAlchemy提供了一个连接池功能,可以管理和复用数据库连接,以提高性能和资源利用率。
  6. 广泛的数据库支持:SQLAlchemy支持多种关系型数据库,如MySQL、PostgreSQL、SQLite、Oracle等。你可以轻松地在不同的数据库之间迁移和切换。

二、使用步骤(示例)

以下是一个使用SQLAlchemy连接到MySQL数据库并进行基本操作的例子:

1. 安装所需的库

首先,确保你已经安装了SQLAlchemy和MySQL的Python驱动。你可以使用pip来安装它们:

pip install sqlalchemy pymysql

2. 连接到MySQL数据库

from sqlalchemy import create_engine

# 替换为你的MySQL数据库信息
username = 'your_mysql_username'
password = 'your_mysql_password'
host = 'your_mysql_host'  # 例如:'localhost' 或 '127.0.0.1'
port = 'your_mysql_port'  # 通常是 3306
database = 'your_database_name'

# 创建连接引擎
engine = create_engine(f'mysql+pymysql://{username}:{password}@{host}:{port}/{database}')

3. 定义模型

接下来,我们定义一个模型来表示我们想要在数据库中存储的数据。

from sqlalchemy import Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String)
    email = Column(String)

4. 创建表

在数据库中创建表。

Base.metadata.create_all(engine)

5. 添加数据

from sqlalchemy.orm import sessionmaker

# 创建会话
Session = sessionmaker(bind=engine)
session = Session()

# 添加新用户
new_user = User(name='John Doe', email='john.doe@example.com')
session.add(new_user)
session.commit()

# 关闭会话
session.close()

6. 查询数据

session = Session()

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

# 关闭会话
session.close()

请确保在运行代码之前,你已经正确配置了MySQL服务器,并且替换了上述代码中的数据库连接信息(用户名、密码、主机、端口和数据库名)。

这个例子展示了如何使用SQLAlchemy连接到MySQL数据库,定义模型,创建表,添加数据,以及查询数据。在实际应用中,你可能还需要处理更复杂的情况,比如关系、继承、事务管理等。SQLAlchemy提供了丰富的功能来满足这些需求。

三、结合事务使用(示例)

首先,确保你已经按照前面的示例设置好了SQLAlchemy和MySQL的连接。

1. 定义模型

我们继续使用前面的User模型。

from sqlalchemy import Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String)
    email = Column(String)

2. 初始化数据库连接和会话

from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker

# 连接到MySQL数据库(请替换为你的数据库信息)
engine = create_engine('mysql+pymysql://user:password@localhost/dbname')
Session = sessionmaker(bind=engine)
session = Session()

3. 使用事务添加用户

现在,我们将在一个事务中添加用户。如果添加过程中发生任何错误,我们将回滚事务,确保数据库的一致性。

try:
    # 开始一个新的事务
    session.begin()
    
    # 创建新用户对象
    user1 = User(name='Alice', email='alice@example.com')
    user2 = User(name='Bob', email='bob@example.com')
    
    # 添加到会话中
    session.add(user1)
    session.add(user2)
    
    # 提交事务,将所有更改保存到数据库
    session.commit()
    print("Users added successfully.")
except Exception as e:
    # 如果在添加用户过程中发生错误,则回滚事务
    session.rollback()
    print(f"An error occurred: {e}")
finally:
    # 关闭会话
    session.close()

在这个示例中,我们使用session.begin()显式地开始了一个新的事务。然后,我们尝试添加两个新用户到会话中。如果在这个过程中没有发生任何错误,我们使用session.commit()提交事务,将所有更改保存到数据库中。但是,如果在添加用户的过程中发生了任何异常(例如,由于重复的电子邮件地址或数据库连接问题),我们将使用session.rollback()回滚事务,确保数据库的一致性。

请注意,为了简化示例,这里没有包含详细的错误处理和验证逻辑。在实际应用中,你应该根据具体需求添加适当的错误处理和验证。

四、复杂查询条件(示例)

以下是一些使用SQLAlchemy进行复杂查询的示例:

示例1:连接查询(Join)

假设我们有两个模型,UserOrder,并且一个用户可以有多个订单。

from sqlalchemy import Column, Integer, String, ForeignKey
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String)
    orders = relationship("Order", back_populates="user")

class Order(Base):
    __tablename__ = 'orders'
    id = Column(Integer, primary_key=True)
    user_id = Column(Integer, ForeignKey('users.id'))
    product = Column(String)
    quantity = Column(Integer)
    user = relationship("User", back_populates="orders")

现在,如果我们想要查询所有下过订单的用户及其订单信息,我们可以进行连接查询:

from sqlalchemy.orm import joinedload

# 加载所有用户的订单信息
users_with_orders = session.query(User).options(joinedload(User.orders)).all()
for user in users_with_orders:
    print(f"User: {user.name}")
    for order in user.orders:
        print(f"  Order: {order.product}, Quantity: {order.quantity}")

示例2:分组和聚合(Grouping and Aggregation)

假设我们想要统计每个用户下的订单总数。

from sqlalchemy import func

# 按用户分组,并计算每个用户的订单数量
order_count_by_user = session.query(User.id, User.name, func.count(Order.id).label('order_count')).\
    join(Order).group_by(User.id, User.name).all()
for user_id, user_name, order_count in order_count_by_user:
    print(f"User ID: {user_id}, Name: {user_name}, Order Count: {order_count}")

示例3:子查询(Subquery)

如果我们想要找出订单数量超过平均订单数量的用户,我们可以使用子查询。

from sqlalchemy import func, select

# 计算平均订单数量作为子查询
avg_order_quantity = select([func.avg(Order.quantity).label('avg_quantity')]).select_from(Order).alias()

# 查询订单数量超过平均值的用户及其订单信息
users_above_avg = session.query(User, Order.product, Order.quantity).\
    join(Order).filter(Order.quantity > avg_order_quantity.c.avg_quantity).all()
for user, product, quantity in users_above_avg:
    print(f"User: {user.name}, Product: {product}, Quantity: {quantity}")

示例4:复杂筛选条件(Complex Filtering)

假设我们想要找到名字以“A”开头的用户,并且他们的订单中包含“apple”这个产品。

# 查询名字以“A”开头的用户,且订单中包含“apple”产品的用户信息
users_with_apple = session.query(User).join(Order).\
    filter(User.name.startswith('A')).\
    filter(Order.product.contains('apple')).\
    distinct().all()  # 使用distinct()确保结果中的用户不重复
for user in users_with_apple:
    print(f"User: {user.name}")

这些示例展示了SQLAlchemy在处理复杂查询时的一些高级功能,包括连接查询、分组聚合、子查询和复杂筛选条件。

请注意,这些示例代码可能需要根据你的具体数据库模型和表结构进行调整。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

flutter开发实战-webview_flutter 4.x版本使用

flutter开发实战-webview_flutter 4.x版本使用 在之前使用的webview_flutter版本是3.x的,升级到4.x后,使用方式有所变化。 一、webview_flutter 在工程的pubspec.yaml中引入插件 webview_flutter: ^4.4.2二、使用webview_flutter 在4.x版本中&#…

umi6.x + react + antd的项目增加403(无权限页面拦截),404,错误处理页面

首先在src/pages下创建403&#xff0c;404&#xff0c;ErrorBoundary 403 import { Button, Result } from antd; import { history } from umijs/max;const UnAccessible () > (<Resultstatus"403"title"403"subTitle"抱歉&#xff0c;您无权…

如何使用Python为Excel文件添加预设文档属性和自定义文档属性

向Excel文件添加文档属性是专业地组织和管理电子表格数据的关键步骤。这些属性&#xff0c;如标题、作者、主题和关键词&#xff0c;增强了文件的元数据&#xff0c;使得在大型数据库或文件系统中跟踪、排序和搜索文档变得更加容易。通过包含这些信息&#xff0c;您不仅提高了文…

C++map和set(个人笔记)

Cmap和set 1.set1.1set的使用1.1.1 set的模板参数列表1.1.2set的构造1.1.3set的迭代器1.1.4 set的容量1.1.5 set修改操作1.1.6 set的具体使用例子 2.map2.1map的使用2.1.1map的模板参数列表2.1.2map的构造2.1.3map的迭代器2.1.4 map的容量与元素访问2.1.5 map中元素的修改2.1.6…

资源管理游戏模版进入The Sandbox

我们非常高兴地向您介绍 Game Maker 的最新模板&#xff1a;资源管理游戏&#xff01; 这一全新的模板让您能够深入身临其境的游戏体验中&#xff0c;同时掌握令人兴奋的新机制。通过揭开模板的神秘面纱&#xff0c;您可以锤炼您的游戏设计技能。 什么是资源管理游戏&#xff1…

【C语言和Java的对比学习】2(布尔类型、运算符、程序逻辑控制)

【C语言和Java的对比学习】2&#xff08;布尔类型、运算符、程序逻辑控制&#xff09; 1. 布尔类型变量2. 逻辑运算符的短路问题2.1 &&和||使用举例2.2 &和|的使用举例 3.位移运算4. switch语句 1. 布尔类型变量 下面我们直接先看下面一组代码的对比图。 注意&am…

马化腾用了一年多的时间,告诉所有人,视频号小店是新风口!

大家好&#xff0c;我是电商笨笨熊 当腾讯说出自己要做电商的时候&#xff0c;所有人都在说&#xff0c;根本不可能&#xff1b; 甚至在视频号小店正式推出之后&#xff0c;依旧有人说&#xff0c;腾讯做电商就是笑话&#xff1b; 一个“抄”过来的项目&#xff0c;毫无特色…

whisper之初步使用记录

文章目录 前言 一、whisper是什么&#xff1f; 二、使用步骤 1.安装 2.python调用 3.识别效果评估 4.一点封装 5.参考链接 总结 前言 随着AI大模型的不断发展&#xff0c;语音识别等周边内容也再次引发关注&#xff0c;通过语音转文字再与大模型交互&#xff0c;从而…

数据库入门(sql文档+命令行)

一.基础知识 1.SQL&#xff08;Structured Query Language&#xff09;结构化查询语言分类&#xff1a; DDL数据定义语言用来定义数据库对象&#xff1a;数据库、表、字段DML数据操作语言对数据库进行增删改查DQL数据查询语言查询数据库中表的信息DCL数据控制语言用来创建数据…

用数字化武装文物——博物馆文物管理平台

一、引言 在数字化与信息化高速发展的今天&#xff0c;博物馆文物管理面临着前所未有的挑战与机遇。随着科技的不断进步&#xff0c;传统的管理方式已难以满足现代博物馆对文物管理和保护的需求。在此情况下&#xff0c;博物馆文物管理平台以其强大的功能&#xff0c;正成为文物…

快速理解SPI通信协议(超简单)

SPI通信协议 一、SPI协议介绍二、发送数据三、读数据注意 一、SPI协议介绍 SPI是一种全双工的串行通信协议 他有四条线 SCLK&#xff08;Serial Clock&#xff09;&#xff1a;时钟线 MOSI&#xff08;Master Output, Slave Input&#xff09;&#xff1a;关键字母"O&q…

Highcharts 实现3D饼图 tooltip轮播

实现3D饼图&#xff0c;并且轮播显示tooltip 自定义toottip样式 import Highcharts from highcharts; import highcharts from highcharts; import highcharts3d from highcharts/highcharts-3d;highcharts3d(Highcharts); highcharts3d(highcharts); import { useEffect, use…

Docker安装达梦数据库

1.确保已安装Docker 可参考&#xff1a;Linux安装Docker-CSDN博客 2.上传dm镜像并导入安装包 可以从&#xff1a;产品下载 | 达梦数据库下载dm镜像&#xff0c;如下图&#xff1a; docker load -i dm8_20230808.tar 3.导入后查看镜像 docker images 4.启动容器 docker run …

工业数据采集软件 高效的数字化信息管理系统

近年来&#xff0c;随着产线自动化程度的提升&#xff0c;越来越多的工业设备被运用到自动化生产中&#xff0c;产线中各位置所产生的数据也越来越多&#xff0c;每个设备又都是独立的&#xff0c;如何将其整合&#xff0c;进行系统化查看处理&#xff0c;就是工业数据采集软件…

数据结构05:树与二叉树 习题01[C++]

考研笔记整理&#xff0c;本篇作为树与二叉树的基本概念习题&#xff0c;供小伙伴们参考~&#x1f95d;&#x1f95d; 之前的博文链接在此&#xff1a;数据结构05&#xff1a;树与二叉树[C]-CSDN博客~&#x1f95d;&#x1f95d; 第1版&#xff1a;王道书的课后习题~&#x1…

有什么方便实用的黏土特效教程?6个软件教你快速进行特效制作

有什么方便实用的黏土特效教程&#xff1f;6个软件教你快速进行特效制作 作为时尚小达人&#xff0c;你自己是否想要制作出属于自己的黏土特效照片呢&#xff1f;比如下面几种。 看到这些黏土特效软件有没有心动&#xff0c;下面我也为大家详细的介绍一下可以制作出对应特效的…

金石传拓非遗研学基地 入驻蔚蓝书店

好消息&#xff01;&#xff01;&#xff01; 金石传拓非遗研学基地&#xff0c;正式入驻蔚蓝书店啦&#xff01;&#xff01;&#xff01; “缣竹易销&#xff0c;金石难灭&#xff0c;托以高山&#xff0c;永留不绝。”“金”指的是三代青铜器上的铭文。 “石”指的是石刻、…

视频号小店应该如何开店呢?详细的开店流程分享给你!

大家好&#xff0c;我是电商小V 视频号小店就是威信视频号团队为咱们商家提供的卖货平台&#xff0c;可以说是支持咱们商家在视频号场景中开店进行经营的模式&#xff0c; 视频号大概的开店流程那就是&#xff1a;找到视频号开店&#xff0c;选择企业入驻&#xff0c;填写信息&…

win7安装camera raw13.0.2详解。

首先win7是不能直接安装camera raw13.0.2的。所以我安装的是camera raw12版本。 然后就是重点了&#xff0c;打开文件C:\Program Files\Common Files\Adobe\Plug-Ins\CC\File Formats&#xff0c; 复制下载的camera raw13.0.2的8bi文件。 替换 这样就能在window7中使用了。网…

LinkedList链表

LinkedList 的全面说明 LinkList底层实现了双向链表和双端队列特点可以添加任意元素&#xff08;元素可以重复&#xff09;&#xff0c;包括null线程不安全&#xff0c;没有实现同步 LinkedList 的底层操作机制 LinkedList底层维护了一个双向链表LinkList中维护了两个属性fi…
最新文章