首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >SQL语句中出现中文字符时JDBC报错,解决办法

SQL语句中出现中文字符时JDBC报错,解决办法

作者头像
程裕强
发布于 2018-01-02 08:37:37
发布于 2018-01-02 08:37:37
1K00
代码可运行
举报
运行总次数:0
代码可运行

(1)当SQL中出现汉字时,直接执行SQL命令,可以得到正确结果

(2)当使用JDBC查询时,报错

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
严重: Servlet.service() for servlet [springMvc] in context with path [/web_store] threw exception [Request processing failed; nested exception is org.springframework.jdbc.BadSqlGrammarException: StatementCallback; 
bad SQL grammar [select remainGB 空闲,usedGB 已使用,usedNonDFSGB 非HDFS使用 from hdfsData  limit 1]; nested exception is java.sql.SQLException: You have an error in your SQL syntax; 
check the manual that corresponds to your MariaDB server version for the right syntax to use near '??,usedGB ???,usedNonDFSGB ?HDFS?? from hdfsData  limit 1' at line 1] with root cause
java.sql.SQLException: You have an error in your SQL syntax; 
check the manual that corresponds to your MariaDB server version for the right syntax to use near '??,usedGB ???,usedNonDFSGB ?HDFS?? from hdfsData  limit 1' at line 1

(3)解决办法

在JDBC连接的url中加入useUnicode=true&characterEncoding=UTF-8, 比如: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8

这样,SQL语句可以将中文正确编码,查询出结果。

如果JDBC连接的url在XML,需要将&转义

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" >
        <property name="driverClassName" value="${jdbc.driverClassName}"/>
        <property name="url" value="${jdbc.url}${jdbc.dbName}?useUnicode=true&amp;characterEncoding=UTF-8"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-09-19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • (1)当SQL中出现汉字时,直接执行SQL命令,可以得到正确结果
  • (2)当使用JDBC查询时,报错
  • (3)解决办法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档