mybatis java sql_mybatis java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax;

You have an error in your SQL syntax;  这个错误 是报的 sql 语法不对;

解决起来 还是有点麻烦的,如果sql 单独运行没有问题,就需要考虑 mybatis的解析运行的问题;

1, 取值错误

例如:   select * from table limit #{startPage},#{endPage}

上边 sql 语句 一眼看到 是没什么问题;

但是 mybatis 就会报错;

原因类型不对;

解释:  #{}  mybatis 中是 字符串替换 默认是  加 引号的

正确用法:

select * from table limit ${startPage},$endPage}

2. 多加了标识符

例如 select * from table;

上边语句 单独执行也是没问题的,但是 mybatis会有问题

原因;mybatis 在解析的时候会解析这个分号,但是它不认识 就会 返回报错

正确用法: select * from table

sql 中 多加 逗号也是同理;

本文地址:https://blog.csdn.net/HDXxiazai/article/details/107152046

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 根据引用\[1\]的错误信息,出现了一个SQL语法错误,具体是在MySQL服务器版本中的语法错误,错误的原因是在第4行附近的语法有问题。解决这个问题的方法需要根据具体的错误信息进行调整。另外,引用\[2\]提到了数据库字段使用了小驼峰命名法,而在Java代码中也使用了小驼峰命名法,但是由于mybatis-plus会自动识别小驼峰命名法的属性在数据库中的字段名是experienceo_openness的形式,可能导致错误。所以,可能需要检查数据库中的字段命名是否与Java代码中的属性命名一致。至于引用\[3\]中提到的Unknown database 'szy_mana'错误,这表示数据库中不存在名为'szy_mana'的数据库。因此,需要确保数据库名正确并存在。 #### 引用[.reference_title] - *1* [【解决问题】Error updating ... Cause: java.sql.SQLSyntaxErrorException: You have an error in your S](https://blog.csdn.net/weixin_44436677/article/details/130043463)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Error updating database. Cause: java.sql.SQLSyntaxErrorException: Unknown column ‘experience_openne](https://blog.csdn.net/weixin_55229531/article/details/125021940)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值