请问python SQLAlchemy中flush()、commit()区别是什么,sqlalchemyflush,commit() 和 f
请问python SQLAlchemy中flush()、commit()区别是什么,sqlalchemyflush,commit() 和 f
commit() 和 flush() 实现的功能都一样,为什么两个要写两种,有什么特殊的区别呢?
谁说这两个东西的功能一样了?
在SQLAlchemy中一个Session(可以看作)是一个transaction,每个操作(基本上)对应一条或多条SQL语句,这些SQL语句需要发送到数据库服务器才能被真正执行,而整个transaction需要commit才能真正生效,如果没提交,一旦你的程序挂了,所有未提交的事务都会被回滚到事务开始之前的状态。
flush就是把客户端尚未发送到数据库服务器的SQL语句发送过去,commit就是告诉数据库服务器提交事务。
简单说,flush之后你才能在这个Session中看到效果,而commit之后你才能从其它Session中看到效果。
功能不一样。
简单说:
flush预提交,等于提交到数据库内存,还未写入数据库文件;
commit就是把内存里面的东西直接写入,可以提供查询了;
编橙之家文章,
相关内容
- MAC OS中修改 python环境变量到底应该修改哪个文件?,
- 请教Unity3D中的IronPython问题,unity3dironpython,我想用Iron
- 抓取需要选择日期才有结果的ajax网站需要怎么解决,选
- 自动检测当前运行环境版本的python方法是什么,运行环
- Windows下Python解决乱码问题应该怎么做,python乱码,刚接
- 用python完成依据列表中的元素画条形码怎么写源码,
- jinja2对内容进行替换时排除大括号内容如何操作,jin
- Python字典查找value中包含指定字符串key如何实现,pyth
- python爬虫运行一段时间后,返回403 forbidden原因是什么,
- Python实时数据更新解决方法,python实时数据,比如,实现
评论关闭