问题描述
部分框架:springboot + mybatis + druid + oracle
在mapper的xml文件中编写sql,执行测试,报错
....
... sql injection violation,syntax error:todo: values values
...
caused by com.alibaba.druid.sql.parser.ParserException
原因分析
这个问题的本质就是 编写的sql没有解析出来,从而认为那条sql的语法有问题。
解决方法
第一种说法:
数据库版本与Druid 冲突,更换Druid 版本为1.1.10以后的版本,但是并没有解决这个问题。
第二种说法
druid内部做sql格式化时出现的错误,不影响SQL在数据库中的执行(即,虽然报错,但该执行的还是执行了,去数据库查询可以看到执行后的数据)
第三种说法
取别名问题,我们执行SQL时一般会取别名,但是也没有解决这个问题
第四种说法
mybatis里面的SQL有注释(-- xxx),会影响SQL运行
第五种说法
#与$符号问题
第六种
SQL问题,SQL是不能嵌套的,嵌套查询在mybatis里面是不能执行的
第七种:一定要认真检查
仔细检查sql语句是否有多余的内容,比如:逗号,分号...
第八种:解决方法
在数据源配置或SqlSessi