case mybatis 不同表_解决mybatis case when 报错的问题
在mybatis中使用case when進(jìn)行條件篩選判斷時(shí)遇到
Failed to process, please exclude the tableName or statementId.
這樣的報(bào)錯(cuò)信息,報(bào)錯(cuò)的信息是語法錯(cuò)誤
但是我在mysql的命令行中運(yùn)行sql語句是沒問題的
//我的case when語句
WHERE dept.type = 1
AND
(
CASE agent.dept_type
WHEN "agent" THEN dept.id=30
END
)
//當(dāng)agent的dept_type為"agent"時(shí),將添加dept.id = 30的判斷
這段sql語句在命令行內(nèi)運(yùn)行沒問題但是放到mybatis上執(zhí)行就會(huì)報(bào)錯(cuò)
//修改后
WHERE dept.type = 1
AND dept.id=
(
CASE agent.dept_type
WHEN "agent" THEN 30
END
)
后來將dept.id放到外面就解決了這個(gè)問題
20190718-補(bǔ)充記錄 :遇到另一個(gè)問題,如果dept這個(gè)表是聯(lián)查來的有可能會(huì)沒有數(shù)據(jù),在dept無數(shù)據(jù)的時(shí)候我們就無法給dept.id賦上啥參數(shù)了,并且不可以影響原表數(shù)據(jù)的查詢,我改成了下面這樣:
//修改后
WHERE dept.type = 1
AND (dept.id=
(
CASE agent.dept_type
WHEN "agent" THEN 30
ELSE 0
END
) or dept.id is null)
添加dept.id為空的判斷即可
(在mysql語句里可以有很多方法解決,但是在mybatis上就會(huì)報(bào)錯(cuò) -_-||)
2019-7-30-補(bǔ)充說明:
如果是空字符串不可以使用""要改成單引號''
CASE WHEN *** THEN ***
ELSE "" =>這樣也會(huì)報(bào)錯(cuò),需要改成=> ELSE''
補(bǔ)充:Mybatis case when test 注意事項(xiàng)
p_id areaId,
c_id areaId,
r_id areaId,
test 中 用 == 不能用 = ,否則報(bào)錯(cuò)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
總結(jié)
以上是生活随笔為你收集整理的case mybatis 不同表_解决mybatis case when 报错的问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 操作系统:Linux虚拟内存知识介绍
- 下一篇: tomcat多域名访问