Python的ORM框架sqlalchemy如何使用
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,这篇文章主要介绍"Python的ORM框架sqlalchemy如何使用"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Python的ORM框架sqlalchem
千家信息网最后更新 2025年01月23日Python的ORM框架sqlalchemy如何使用
这篇文章主要介绍"Python的ORM框架sqlalchemy如何使用"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Python的ORM框架sqlalchemy如何使用"文章能帮助大家解决问题。
安装
1、安装
#进入虚拟环境#执行./python3 -m pip installimport sqlalchemyprint(sqlalchemy.__version__) # 1.1.15我这里使用的版本是1.1.15
创建连接对象
from sqlalchemy import create_engine# 连接本地test数据库engine = create_engine("mysql://root:root@localhost/test?charset=utf8")
运行时会出错,因为需要驱动库,默认会调用MySQLdb。
ImportError: No module named "MySQLdb"
我们前面安装了pymysql,因此完整的要这么写:
engine = create_engine("mysql+pymysql://root:root@localhost/test?charset=utf8")
简单使用
SQL语句查询
result = engine.execute("select * from news")print(result.fetchall())#[(1, "本机新闻标题"), (2, "今天的新闻"), (3, "新闻标题1"), (4, "新闻标题2"), (5, "元组新闻1"), (6, "元组新闻2")]
创建映射
既然我们用ORM,就是为了少写甚至不写SQL语句。
ORM是数据表和对象之间的映射。
1、创建一个Infos.py文件,这个文件我们来做数据表的映射
from sqlalchemy.ext.declarative import declarative_baseBase = declarative_base()from sqlalchemy import Column, Integer, Stringclass News(Base):# 表名称__tablename__ = "news"# news表里id字段id = Column(Integer, primary_key=True, autoincrement=True)# news表里title字段title = Column(String(length=255), nullable=False)
News类就是我们数据表news的映射(字段:id、title)。
2、使用
from sqlalchemy import create_enginefrom mappers.Infos import Newsfrom sqlalchemy.orm import sessionmaker# 连接本地test数据库engine = create_engine("mysql+pymysql://root:root@localhost/test?charset=utf8")# 创建会话session = sessionmaker(engine)mySession = session()# 查询结果集result = mySession.query(News).all()print(result[0])
我们要注意最后的查询结果,看看结果集中的元素长什么样?^_^
查询处理的记录都是对象。
各种查询
只查询第一条记录
# 查询第一条result = mySession.query(News).first()print(result.title) #打印对象属性通过id字段查询# 查询id为2的result = mySession.query(News).filter_by(id=2).first()print(result.title)# 查询id为2的result = mySession.query(News).filter(News.id==2).first()分页查询# 分页查询 0,2result = mySession.query(News).filter(News.id>1).limit(2).offset(0).all()print(result)自定义过滤条件# 自定义过滤条件result = mySession.query(News).filter(text("id>:id")).params(id=2).all()
根据主键查询
result = mySession.query(News).get(3)print(result.title)
新增和修改
# 新增news = News(title="新增测试标题")mySession.add(news)mySession.commit()#修改mySession.query(News).filter(News.id==7).update({"title":"修改之后的标题"})mySession.commit()
Python利用sqlacodegen自动生成ORM实体类示例
前面方法我们是手动创建了一个名叫Infos.py的文件,然后定义了一个News类,把这个类作为和我们news数据表的映射。
from sqlalchemy.ext.declarative import declarative_baseBase = declarative_base()from sqlalchemy import Column, Integer, Stringclass News(Base):# 表名称__tablename__ = "news"# news表里id字段id = Column(Integer, primary_key=True, autoincrement=True)# news表里title字段title = Column(String(length=255), nullable=False)
现在我们来看看sqlacodegen这个工具,自动生成像上面那样的类文件。
1、安装sqlacodegen
#cd 项目虚拟环境#执行./python3 -m pip install sqlacodegen
2、使用sqlacodegen生成案列
#注意还是在虚拟环境目录下执行./sqlacodegen --tables fund --outfile ../../mappers/Found.py mysql+pymysql://root:root@localhost/test?charset=utf8
关于"Python的ORM框架sqlalchemy如何使用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。
查询
字段
数据
新闻
标题
对象
数据表
文件
表里
框架
环境
知识
结果
生成
名称
就是
数据库
方法
条件
自动生成
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
枣庄网络安全招聘
飞象数据库
高新区知名服务器应用范围
四方后台监控系统数据库安装
中国移动宽带能用电信服务器吗
建党百年网络安全演练
江苏应用软件开发定做
电商计算机网络技术
软件开发豆腐渣工程
安徽三户网络技术
对讲机软件开发主要开发什么
计算机三级网络技术配置
哪种酒店安全叫服务器
网络安全u盾股票
bt资源服务器
提高软件开发书籍
java数据库入门
网络安全创意文案案例
360网络安全大学基地
尤禧核酸检测报告显示服务器超时
中国文化特色词数据库
数据库统计缺失字段
中山路街道网络安全宣传
江西日报网络安全知识竞赛答题
pr是啥意思软件开发
介绍美国互联网科技前沿的书
软件开发云技术
江苏交友软件开发哪家好
青藤云网络安全公司
vnp帐号密码服务器地址