SQL语句中出现中文字符时JDBC报错,解决办法
2017-09-19 10:05
344 查看
(1)当SQL中出现汉字时,直接执行SQL命令,可以得到正确结果
(2)当使用JDBC查询时,报错
严重: 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,需要将&转义
<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&characterEncoding=UTF-8"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/>
相关文章推荐
- 有关list和dic包含中文字符时出现乱码的解决办法
- 使用JDBC中PreparedStatement时,sql语句中中文出现问号
- substr截取中文字符出现乱码的解决办法
- PL/SQL 别名时用中文字符报错ora-00911 或中文乱码解决办法
- 解决SQL语句中含有中文字符无法查询问题
- jsp界面写入数据库时中文乱码(sql语句执行中文乱码)解决办法
- 解决eclipse中执行sql语句时出现中文乱码的问题
- 解决SQL语句中含有中文字符无法查询问题
- mysql的sql查询语句含有中文,rs.next()就false的解决办法
- 关于执行Oracle下Sql语句中遇到的特殊字符问题解决办法。
- 更新OPC点位值,值中带有特殊字符影响sql语句执行的解决办法
- 软件读写中文字符的文件出现乱码的解决办法
- PHP函数substr截取中文字符出现乱码的解决办法
- osql执行SQL脚本内容包含中文时出现乱码问题的解决办法
- java中利用JDBC向MySql数据库中插入中文出现乱码解决办法
- osql执行SQL脚本内容包含中文时出现乱码问题的解决办法
- Android服务器端接收中文字符出现“?”问题解决办法
- PHP substr截取中文字符出现乱码的具体解决办法
- 在java代码中sql语句出现start before result set的错误解决办法
- PHP截取中文字符出现乱码的具体解决办法