【BUG】--MySQLSyntaxErrorException

在开发一个维修类别列表的查询功能时,遇到一个问题:当查询条件不为空时,系统报错。错误信息提示SQL语法错误,特别是ORDER BY语句后的WHERE条件。解决方案是将ORDER BY语句移至WHERE条件之后,从而解决了问题。

今天做了一个查询功能,点击查询按钮的时候,总是报错,后台DeBug一下。

这个功能是维修类别的列表页。
在这里插入图片描述

只有查询条件为空的时候,不会报错。

只有查询条件不为空,则报错。
在这里插入图片描述
com.shhx.hxems.mapper.RepairCategoryMapper.selectRepairCategoryList-Inline ### The error occurred while setting parameters ### SQL:
###Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE a.type = 'Y') tmp_count’ at line 12 ; bad SQL grammar []; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘WHERE a.type = ‘Y’) tmp_count’ at line 12

看下SQL :
在这里插入图片描述
这个oder by语句,后面肯定肯定不能带where条件,

所以把oder by 语句,放到where条件后面,就OK了
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值