sqlachemy中批量删除的问题
db.session.query(Article).filter(Article.id.in_(items)).delete()
报错:
sqlalchemy.exc.InvalidRequestError
InvalidRequestError: Could not evaluate current criteria in Python. Specify 'fetch' or False for the synchronize_session parameter.
但是:
db.session.query(Article).filter(Article.id==1).delete()
db.session.query(Article).filter(Article.id.in_(items))
都能得到正确的结果。为什么不能直接使用.delete()?
我按下面的写法能正常工作。
art_items=Article.query.filter(Article.id.in_(items))
for item in art_items:
db.session.delete(item)
db.session.commit()
就是希望了解一下原理。为什么不能在使用_in的时候直接后面接delete()?
为什么无法删除 in 操作查询出来的记录?
session.query(User).filter(User.id.in_((1, 2, 3))).delete()
抛出这样的异常:
sqlalchemy.exc.InvalidRequestError: Could not evaluate current criteria in Python.  Specify 'fetch' or False for the synchronize_session parameter.
但这样是没问题的:
session.query(User).filter(or_(User.id == 1, User.id == 2, User.id == 3)).delete()
搜了下找到《Sqlalchemy delete subquery》这个问题,提到了 delete 的一个注意点:删除记录时,默认会尝试删除 session 中符合条件的对象,而 in 操作估计还不支持,于是就出错了。解决办法就是删除时不进行同步,然后再让 session 里的所有实体都过期:
session.query(User).filter(User.id.in_((1, 2, 3))).delete(synchronize_session=False)
session.commit() # or session.expire_all()
此外,update 操作也有同样的参数,如果后面立刻提交了,那么加上 synchronize_session=False 参数会更快。
sqlachemy中批量删除的问题的更多相关文章
- SQL中批量删除被注入的恶意代码的方法
		
下文将为您介绍SQL中批量删除被注入的恶意代码的方法,供您参考,如果您也遇到了这样的问题,不妨一看,相信对您会有所帮助. 1,如果你的数据表很少的话,那么写几条简单的sql就搞定了 对于表中的nvch ...
 - excel中批量删除公式,保留数值
		
excel中批量删除公式,保留数值 Sub macro1() Dim sh As Worksheet For Each sh In Sheets sh.UsedRange = sh.UsedRange ...
 - VS中批量删除cs代码中的#region和#endregion
		
Visual Studio中如何批量删除cs代码中的#region和#endregion,不删除它们中间的代码,只删除这两个标记及标记的注解的方法.Vs中提供了很强大的文本查找与替换功能,简单的替换只 ...
 - 【MyBatis】从一千万记录中批量删除八百万条,耗时4m7s
		
批量删除主要借助了MySql的limit函数,其次用了in删除. 代码如下: package com.hy.action; import java.io.Reader; import java.uti ...
 - gitlab中批量删除本地以及远程tag的操作
		
git 批量删除标签# 删除所有远程标签git show-ref --tag | awk '{print ":" $2}' | xargs git push origin # 删除 ...
 - VS中批量删除注释
		
批量删除: 按ctrl+H 选上正则表达式 Find what: //.* Replace with: (空) 点replace all就行了
 - docker中批量删除 tag为none的镜像
		
添加定时任务,批量删除tag 为none 的镜像 ,释放磁盘空间 [root@weifeng]:~# crontab -l */ * * * /usr/bin/docker rmi `docker ...
 - sqlserver 中批量删除\r\n 换行符
		
从Excel中向sqlserver 中批量粘贴数据时 可能会粘贴进去换行符 \r\n 这时候在查询时候是看不见的 只有把该字段赋值到‘’中才能发现换行. 批量替换语句: update [表名]set ...
 - sql中批量删除带有外键的所有表
		
1首先删除所有的外检约束 --删除所有外键约束 DECLARE c1 cursor forselect 'alter table ['+ object_name(parent_obj) + '] dr ...
 
随机推荐
- windows2003密码忘记了该如何处理
			
如果你有sql server的管理员帐号,并且可以登录,尝试用下面的方法: --用管理员连接sql,在查询分析器中执行: --添加用户 exec mas ...
 - (转)CATALINA_BASE与CATALINA_HOME的区别
			
到底CATALINA_HOME和CATALINA_BASE有什么区别呢,之前因为都是小打小闹的在服务器上安装一个tomcat就得了,然后根据前人的配置,将CATALINA_HOME和CATALINA_ ...
 - highstock使用案例(异步请求,懒加载)
			
jsp中导入:<script src="<c:url value="/resources/js/highstock.js"></c:url> ...
 - Go 1.5keyword搜索文件夹、文件、文件内容_修复一个小BUG
			
package main import ( "bufio" "bytes" "flag" "fmt" "io& ...
 - 【laravel5.4】PHP5.6+  调用命名空间下类方法、属性和对象
			
1.调用命名空间的类方法,对象.属性 类对象:\App\User(); 类方法:\App\User::find($this->user_id) //查询构造器方法,将$this->user ...
 - 原创:【微信小程序】客服消息教程(后台以PHP示例)
			
1.不需要自己手动开发客服消息的,直接接入客服,不开启消息推送即可.这种模式不多讲. 2.公众号后台开启消息推送模式,配置服务器URL.TOKEN.随机串.数据模式.数据格式(XML或JSON),这个 ...
 - 【转载】PL/SQL配置连接ORACLE
			
一.需安装ORACL客户端. 配置文件路径: E:\Oracle\product\10.1.0\Client_3\NETWORK\ADMIN\tnsnames.ora 内容如下: # TNSNAMES ...
 - python学习笔记013——内置函数dir()
			
1 描述 dir() 函数 不带参数时,返回当前范围内的变量.方法和定义的类型列表: 带参数时,返回参数的属性.方法列表. 如果参数包含方法__dir__(),该方法将被调用. 如果参数不包含__di ...
 - Python 元组 tuple() 方法
			
描述 Python 元组 tuple() 方法用于将可迭代对象(字符串.列表.元祖.字典)转换为元组. 语法 tuple() 方法语法: tuple(iterable) 参数 iterable -- ...
 - python  map   详解
			
python中的map函数应用于每一个可迭代的项,返回的是一个结果list.如果有其他的可迭代参数传进来,map函数则会把每一个参数都以相应的处理函数进行迭代处理.map()函数接收两个参数,一个是函 ...