玩蛇网提供最新Python编程技术信息以及Python资源下载!

请问python SQLAlchemy中flush()、commit()区别是什么

commit()flush() 实现的功能都一样,为什么两个要写两种,有什么特殊的区别呢?

谁说这两个东西的功能一样了?
在SQLAlchemy中一个Session(可以看作)是一个transaction,每个操作(基本上)对应一条或多条SQL语句,这些SQL语句需要发送到数据库服务器才能被真正执行,而整个transaction需要commit才能真正生效,如果没提交,一旦你的程序挂了,所有未提交的事务都会被回滚到事务开始之前的状态。
flush就是把客户端尚未发送到数据库服务器的SQL语句发送过去,commit就是告诉数据库服务器提交事务。
简单说,flush之后你才能在这个Session中看到效果,而commit之后你才能从其它Session中看到效果。

功能不一样。
简单说:
flush预提交,等于提交到数据库内存,还未写入数据库文件;
commit就是把内存里面的东西直接写入,可以提供查询了;

玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd19298.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年05月24日 - 20时12分16秒 发布自玩蛇网

您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules