基于sqlalchemy对mysql实现增删改查操作的方法
发表于:2025-11-11 作者:千家信息网编辑
千家信息网最后更新 2025年11月11日,这篇文章将为大家详细讲解有关基于sqlalchemy对mysql实现增删改查操作的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。需求场景:老大让我利用爬虫爬取的
千家信息网最后更新 2025年11月11日基于sqlalchemy对mysql实现增删改查操作的方法
这篇文章将为大家详细讲解有关基于sqlalchemy对mysql实现增删改查操作的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
需求场景:
老大让我利用爬虫爬取的数据写到或更新到mysql数据库中,百度了两种方法
1 是使用pymysql连接mysql,通过操作原生的sql语句进行增删改查数据;
2 是使用sqlalchemy连接mysql,通过ORM模型建表并操作数据库,不需要写原生的sql语句,相对简单些;
以下就是本次使用sqlalchemy的经验之谈。
实现流程:连接数据库》通过模型类创建表》建立会话》执行创建表语句》通过会话进行增删改查
from sqlalchemy import exists, Column, Integer, String, ForeignKey, existsfrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy import create_enginefrom sqlalchemy.orm import sessionmaker# 创建的数据库引擎engine = create_engine("mysql+pymysql://user:pwd@ip/数据库名?charset=utf8")#创建session类型DBSession = sessionmaker(bind=engine)# 实例化官宣模型 - Base 就是 ORM 模型Base = declarative_base()# 创建服务单表class ServiceOrder(Base): __tablename__ = 'serviceOrderTable' id = Column(Integer, primary_key=True, autoincrement=True) serviceOrderId = Column(String(32), nullable=False, index=True, comment='服务单ID') serviceDesc = Column(String(268), comment='服务说明') oneLevelName = Column(String(32), comment='C类别') twoLevelName = Column(String(32), comment='T子类') threeLevelName = Column(String(32), comment='I项目') fourLevelName = Column(String(32), comment='S子项') transferTimes = Column(String(32), comment='转派次数') overDueStatus = Column(String(32), comment='过期状态') serviceTimeLimit = Column(String(32), comment='服务时限') serTimeLimitTypeName = Column(String(16), comment='时限类型') # 一对多: # serviceWorkOrder = relationship("ServiceWorkOrder", backref="serviceorder")# 多对一:多个服务工单可以属于服务单class ServiceWorkOrder(Base): __tablename__ = 'serviceWorkOrderTable' id = Column(Integer, primary_key=True, autoincrement=True) serviceWorkOrderId = Column(String(32), nullable=False, index=True, comment='服务工单ID') workOrderName = Column(String(268), comment='工单名称') fromId = Column(String(32), comment='服务单ID') createUserSectionName = Column(String(32), comment='创建人室') createUserName = Column(String(32), comment='创建人') handlerName = Column(String(32), comment='处理人') statusName = Column(String(32), comment='工单状态') createTime = Column(String(32), comment='创建时间') # "多"的一方的book表是通过外键关联到user表的: # serviceOrder_id = Column(Integer, ForeignKey('serviceOrderTable.id'))# 创建数据库 如果数据库已存在 则不会创建 会根据库名直接连接已有的库def init_db(): Base.metadata.create_all(engine)def drop_db(): Base.metadata.drop_all(engine)def insert_update(): # all_needed_data_lists 是需要插入数据库的数据 格式[{key: value, ... }, { }, { }...] for item in all_needed_data_lists: ServiceOrderRow = ServiceOrder(serviceOrderId=item['serviceOrderId'], serviceDesc=item['serviceDesc'], oneLevelName=item['oneLevelName'], twoLevelName=item['twoLevelName'], threeLevelName=item['threeLevelName'], fourLevelName=item['fourLevelName'], transferTimes=item['transferTimes'], overDueStatus=item['overDueStatus'], serviceTimeLimit=item['serviceTimeLimit'], serTimeLimitTypeName=item['serTimeLimitTypeName'], ) try: # 利用exists判断目标对象是否存在,返回True或Faults it_exists = session.query( exists().where(ServiceOrder.serviceOrderId == item['serviceOrderId'] ) ).scalar() except Exception as e: self.log.error(e) break try: # 如果不存在,进行新增;存在的话就更新现存的数据 if not it_exists: session.add(ServiceOrderRow) else: session.query(ServiceOrder).filter(ServiceOrder.serviceOrderId == item['serviceOrderId'])\ .update(item) except Exception as e: self.log.error(e) break try: session.commit() self.log.info('数据更新成功!') except: session.rollback() self.log.info('数据更新失败!')if __name__ == "__main__": # 创建数据库 如果数据库已存在 则不会创建 会根据库名直接连接已有的库 init_db() # 创建session对象,进行增删改查: session = DBSession() # 利用session 增 改数据 记得提交 insert_update() 关于基于sqlalchemy对mysql实现增删改查操作的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
数据
数据库
服务
模型
更新
方法
语句
创建人
对象
就是
时限
更多
状态
篇文章
类型
不错
实用
成功
经验之谈
一方
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
天津方诺互联网科技
郧西互联网软件开发口碑推荐
宿迁filecoin服务器
公安科技 互联网+
关于意识形态网络安全征文
用于统一管理数据库的建立
服务器故障不能上网怎么办
中搜网络技术 招聘
期刊所属数据库怎么查
大势至usb管理服务器破解
下面哪个是客户机 服务器模型
完美服务器如何投降
杭州彩拓网络技术有限公司
海淀区信息化软件开发要求
ssh框架 数据库
服务器怎么搞包替换
aix下创建数据库
如果做好网络安全宣传
关于网络安全的简单的小报
食材信息数据库
select分组显示数据库
服务器怎么做集群
电脑自定义功能软件开发
网络安全科技实拍
广东高科技软件开发技术指导
天互服务器
计算机三级网络技术怎么速成
小学生关于网络安全教育实图
连接磁盘管理服务器
信息系统与数据库