数据库

警惕,MyBatis的size()方法竟然有坑!

时间:2010-12-5 17:23:32  作者:IT科技   来源:IT科技  查看:  评论:0
内容摘要:复制###Errorqueryingdatabase.Cause:org.apache.ibatis.builder.BuilderException:Errorevaluatingexpressio

警惕,MyBatis的size()方法竟然有坑!
警惕复制### Error querying database.  Cause: org.apache.ibatis.builder.BuilderException: Error evaluating expression list != null and list.size() > 0. Cause: org.apache.ibatis.ognl.MethodFailedException: Method "size" failed for object [1] [java.lang.IllegalAccessException: Class org.apache.ibatis.ognl.OgnlRuntime can not access a member of class java.util.Collections$SingletonList with modifiers "public"]  ### Cause: org.apache.ibatis.builder.BuilderException: Error evaluating expression list != null and list.size() > 0. Cause: org.apache.ibatis.ognl.MethodFailedException: Method "size" failed for object [1] [java.lang.IllegalAccessException: Class org.apache.ibatis.ognl.OgnlRuntime can not access a member of class java.util.Collections$SingletonList with modifiers "public"]      at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:23) org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:107)      at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:98)      at cn.com.shaobingmm.MybatisBugTest$2.run(MybatisBugTest.java:88)      at java.lang.Thread.run(Thread.java:745)  Caused by: org.apache.ibatis.builder.BuilderException: Error evaluating expression list != null and list.size() > 0. Cause: org.apache.ibatis.ognl.MethodFailedException: Method "size" failed for object [1] [java.lang.IllegalAccessException: Class org.apache.ibatis.ognl.OgnlRuntime can not access a member of class java.util.Collections$SingletonList with modifiers "public"]      at org.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java      at:47)      at org.apache.ibatis.scripting.xmltags.ExpressionEvaluator.evaluateBoolean(ExpressionEvaluator.java:29)      at org.apache.ibatis.scripting.xmltags.IfSqlNode.apply(IfSqlNode.java:30)      at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:29)      at org.apache.ibatis.scripting.xmltags.TrimSqlNode.apply(TrimSqlNode.java:51)      at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:29)      at org.apache.ibatis.scripting.xmltags.DynamicSqlSource.getBoundSql(DynamicSqlSource.java:37)      at org.apache.ibatis.mapping.MappedStatement.getBoundSql(MappedStatement.java:275)      at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:79)      at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:104)      ... 3 more  Caused by: org.apache.ibatis.ognl.MethodFailedException: Method "size" failed for object [1] [java.lang.IllegalAccessException: Class org.apache.ibatis.ognl.OgnlRuntime can not access a member of class java.util.Collections$SingletonList with modifiers "public"]      at org.apache.ibatis.ognl.OgnlRuntime.callAppropriateMethod(OgnlRuntime.java:837)      at org.apache.ibatis.ognl.ObjectMethodAccessor.callMethod(ObjectMethodAccessor.java:61)      at org.apache.ibatis.ognl.OgnlRuntime.callMethod(OgnlRuntime.java:860)      at org.apache.ibatis.ognl.ASTMethod.getValueBody(ASTMethod.java:73)      at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:170)      at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:210)      at org.apache.ibatis.ognl.ASTChain.getValueBody(ASTChain.java:109)      at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:170)      at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:210)      at org.apache.ibatis.ognl.ASTGreater.getValueBody(ASTGreater.java:49)      at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:170)      at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:210)      at org.apache.ibatis.ognl.ASTAnd.getValueBody(ASTAnd.java:56)      at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:170)      at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:210)      at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:333)      at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:413)      at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:395)      at org.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java:45)      ... 12 more  1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.
copyright © 2025 powered by 编程之道  滇ICP备2023006006号-34sitemap