最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
使用ORM新增数据在Mysql中操作代码
时间:2022-06-29 08:41:08 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下使用ORM新增数据在Mysql中操作代码,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
【前言】
想要使用ORM在数据库中进行操作数据,前提是已经新建了ORM模型
【ORM操作步骤】
构造ORM模型对象
添加到session
提交到数据库
出现异常,回滚事务(可选)
【构造ORM模型对象】
user_obj = User( username="use1", password="123456", real_name = "用户1", age=12 )
【添加到session】
# 添加1个对象 session.add(user_obj) # 添加多个对象 session.add_all([user1,user2,user3])
【session的作用】
建立与数据库之间的会话
使用session对数据库中的数据进行增删改查
使用session进行事务控制(提交和回滚)
使用完后需要关闭它 session.close()
【session的创建】
有两种方法,下图代码示例
# 方法一 实例化session
from sqlalchemy.orm import Session
with Session(engine) as session:
session.add(User())
session.commit()
# 方法二 使用工厂函数创建
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(engine)
with Session.begin() as session:
session.add(User())
【数据提交到数据库】
with Session(engine) as session:
session.add(user_obj)
session.add_all([user1,user1,user1])
session.commit()
【出现异常,回滚事务】
with Session(engine) as session:
session.begin()
try:
session.add(user1)
session.add(user2)
except:
session.rollback()
raise
else:
session.commit()
【Session对象中其他的常用方法】
1. excute(statement, params=None,*args) 执行SQL查询
2. delete(instance) 物理删除数据
3. get(entity,idnet,*args) 根据主键返回满足条件的ORM对象/None
4. query(*entities,**kwargs)
使用ORM查询,返回Query对象
相关文章
- 过山车之星2游乐园声誉提升方法分享 11-04
- 过山车之星2独特景点作用介绍说明 11-04
- 炉石传说标准模式轮盘术卡组推荐分享 11-04
- 炉石传说标准小行星萨卡组推荐分享 11-04
- 炉石传说基尔加丹轮盘术卡组推荐分享 11-04
- 炉石传说宇宙彩虹DK高胜率卡组推荐分享 11-04