grails中执行sql操作的代码很简单,如下:
def dataSource
def sql = new Sql(dataSource)
def institutionId = 123
def loanFeeSql = "SELECT NVL(SUM(B.LOAN_FEE),0) AS SUM,COUNT(B.ID) AS NUM FROM FUND_ACCOUNT A,LOAN_FEE B,INSTITUTION C "
+"WHERE A.INSTITUTION_ID = C.ID AND C.ID =? AND A.BANK_ACCOUNT = B.REMIT_BANK_ACCOUNT"
def loanFeeList = sql.rows(loanFeeSql,institutionId)
本来不会觉得有任何问题,但执行之后却发生异常:
No signature of method: java.lang.String.positive() is applicable for argument types: () values: []
Possible solutions: notify(), size(), size(), tokenize(), tokenize(). Stacktrace follows:
groovy.lang.MissingMethodException: No signature of method: java.lang.String.positive() is applicable for argument types: () values: []
Possible solutions: notify(), size(), size(), tokenize(), tokenize()
这个异常还真是百思不得其解啊,和java.lang.String.positive()有什么关系呢,百度之,查了好久,又问了我的一个同事,才发现,groovy中因为没有分号作为每一行的分隔符,所以,如果一个字符串需要使用“+”拼起来,则需要把“+”写在上一行的末尾,如果写到下一行的开头,则可能默认下一行是另外一条语句,晕。。。
所以,正确的写法是:
def loanFeeSql = "SELECT NVL(SUM(B.LOAN_FEE),0) AS SUM,COUNT(B.ID) AS NUM FROM FUND_ACCOUNT A,LOAN_FEE B,INSTITUTION C "+
"WHERE A.INSTITUTION_ID = C.ID AND C.ID =? AND A.BANK_ACCOUNT = B.REMIT_BANK_ACCOUNT"
或者使用三个分号,这样编译器会将上下两行自动识别为一个字符串:
def loanFeeSql = """SELECT NVL(SUM(B.LOAN_FEE),0) AS SUM,COUNT(B.ID) AS NUM FROM FUND_ACCOUNT A,LOAN_FEE B,INSTITUTION C
WHERE A.INSTITUTION_ID = C.ID AND C.ID =? AND A.BANK_ACCOUNT = B.REMIT_BANK_ACCOUNT"""
参考资料:http://heqiang421.blog.163.com/blog/static/232275071201472924551504/
一个加号引发的问题
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...