前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL语句中出现中文字符时JDBC报错,解决办法

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

作者头像
程裕强
发布2018-01-02 16:37:37
9660
发布2018-01-02 16:37:37
举报
文章被收录于专栏:大数据学习笔记

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

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

代码语言:javascript
复制
严重: 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
复制
<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)解决办法
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档