当前位置: 首页 > news >正文

那个网站报道过鸟巢建设广告文案经典范例200字

那个网站报道过鸟巢建设,广告文案经典范例200字,软件搭建,大连网站推广优化可以把事务理解为一系列操作的集合:这些操作要么全部执行,要么一个也不执行——这样就可以保证数据的一致性和可靠性。在执行更新和删除操作时,尤其要注意利用事务的这个特征。 SQLAlchemy中提供了许多方法来利用事务。 1、如何确保操作生效…

可以把事务理解为一系列操作的集合:这些操作要么全部执行,要么一个也不执行——这样就可以保证数据的一致性和可靠性。在执行更新和删除操作时,尤其要注意利用事务的这个特征。

SQLAlchemy中提供了许多方法来利用事务。

1、如何确保操作生效以及为操作“上保险”?

已经知道,从Engine生成一个Connection对象并执行一些操作的方式如下:

from sqlalchemy import create_engine, text
engine = create_engine("sqlite+pysqlite:///:memory:", echo=True, future=True)
# 存储在内存中的sqlite数据库,这样可以无须启动任何服务,也不会产生任何文件。with engine.connect() as conn:result = conn.execute(text("select 1+1;"))

由于设置了打印执行日志(echo=True),可以在python console中看到整个执行过程:

2023-06-01 16:03:30,189 INFO sqlalchemy.engine.Engine BEGIN (implicit)
2023-06-01 16:03:30,190 INFO sqlalchemy.engine.Engine select 1+1;
2023-06-01 16:03:30,190 INFO sqlalchemy.engine.Engine [generated in 0.00025s] ()
2023-06-01 16:03:30,190 INFO sqlalchemy.engine.Engine ROLLBACK

实际上,上述语句的执行过程是:先开启了一个事务,然后执行对应的操作,最后再回滚。也就是说,通过engine.connect()获取的连接对象,在执行完操作后默认是将事务回滚的,从而不对数据库的数据产生任何影响。因此,如果用户想要执行增删改等操作,那么必须显示地进行提交:

with engine.connect() as conn:conn.execute(text("CREATE TABLE some_table (x int primary key, y int)"))conn.execute(text("INSERT INTO some_table (x, y) VALUES (:x, :y)"),[{"x": 1, "y": 1}, {"x": 2, "y": 4}],)conn.commit()  # 必须手动提交,否则更改不会生效

利用上述特性,将所有需要进行的操作放到一起,最后提交,就可以保证要么全部生效,要么都不生效:

with engine.connect() as conn:conn.execute(text("delete from some_table where x=1"))conn.execute(text("insert into some_table (x, y) values (2, 3)"))# 插入操作由于主键冲突无法执行,那么上一条删除操作也不会生效conn.commit()

利用try...except...,可以进一步对上述语句进行包装:

with engine.connect() as conn:try:conn.execute(text("delete from some_table where x=1"))conn.execute(text("insert into some_table (x, y) values (2, 3)"))conn.commit()print("成功")except:conn.rollback()print("失败,回滚")

2、通过engine.begin()来封装为事务

通过engine.begin()也可以获得一个连接对象,所不同的是,这样获得的连接对象在执行操作后,会自动进行提交。如果执行过程中出错,则会自动回滚:

with engine.begin() as conn:conn.execute(text("delete from some_table where x=1"))conn.execute(text("insert into some_table (x, y) values (2, 3)"))

可以在console中看到如下信息:

2023-06-01 17:38:06,526 INFO sqlalchemy.engine.Engine BEGIN (implicit)
2023-06-01 17:38:06,527 INFO sqlalchemy.engine.Engine delete from some_table where x=1
2023-06-01 17:38:06,527 INFO sqlalchemy.engine.Engine [cached since 1692s ago] ()
2023-06-01 17:38:06,527 INFO sqlalchemy.engine.Engine insert into some_table (x, y) values (2, 3)
2023-06-01 17:38:06,528 INFO sqlalchemy.engine.Engine [cached since 1692s ago] ()
2023-06-01 17:38:06,528 INFO sqlalchemy.engine.Engine ROLLBACK
[错误信息]

最后的ROLLBACK表明,语句执行过程中出现了错误。

类似地,利用try...except...,可以进一步捕获错误:

try:with engine.begin() as conn:conn.execute(text("delete from some_table where x=1"))conn.execute(text("insert into some_table (x, y) values (2, 3)"))
except Exception as e:print(f"出错,回滚, {e}")
http://www.hkea.cn/news/105964/

相关文章:

  • 国外网站在国内做镜像站点网站搭建费用
  • 网站后台如何添加关键词软件开发公司
  • 手机做网站的网站windows优化大师卸载不了
  • 万网速成网站有哪些 功能自己的网站怎么推广
  • 邯郸哪有做网站的河南百度推广公司
  • 我是做环保类产品注册哪些浏览量大的网站推销自己的产品比较好呢西安网站seo优化公司
  • 网页传奇游戏排行昆明网络推广优化
  • 商城模板网站模板网站软文是什么
  • 校园网站推广方案怎么做网站排名推广工具
  • 深圳罗湖企业网站建设报价网络媒体发稿平台
  • 用别人公司域名做网站线下推广的渠道和方法
  • php mysql的网站开发外贸推广平台
  • 济南网站建设认可搜点网络能百度指数有三个功能模块
  • 网上商城网站建设意义在线代理浏览网页
  • 网站图片切换代码百度下载并安装最新版
  • 微信公众平台号申请注册入口杭州seo公司
  • 本周实时热点新闻事件seo文章代写一篇多少钱
  • 旺店通app手机企业版下载网站seo如何优化
  • 宝山区建设用地事务所网站网络公司有哪些
  • 用sql做简单的博客网站大连谷歌seo
  • 新手怎么学做网站就业培训机构有哪些
  • magento网站建设搭建网站步骤
  • 营销网站如何实现差异化南京seo公司
  • 服务器托管是啥搜索引擎优化排名培训
  • 山西手机网站建设网址大全123
  • b2c平台有哪些平台网址新区seo整站优化公司
  • WordPress突然全站404网站如何添加友情链接
  • 复制别人网站做第一站seo短视频网页入口引流下载
  • 基层建设论文收录在哪个网站百度统计api
  • 购买主机可以做网站吗楚雄今日头条新闻