ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

从CSV用Java mySQL插入特定的字符集

2019-11-05 18:16:02  阅读:155  来源: 互联网

标签:character-encoding csv jdbc java mysql


我有一个小问题,我正在使用连接到mySQL数据库的Java应用程序从CSV文件构建数据库.

CSV是ISO-8859-1编码的.
通过缓冲的文件读取器读取它,并使用String方法进行解析.
然后,这些字符串通过JDBC驱动程序引入到mySQL中.

问题是:调音中丢失了重音(这是法语应用程序).在mySQL数据库中,它们采用的格式不明,既不是UTF-8,也不是Latin-1 …

我的假设是,字符串被奇怪地编码,并且在重新插入时保持这种编码.如何在Java中为INSERT语句强制执行字符集?

解决方法:

您需要确保使用InputStreamReader和正确的字符集(这是文件本身之一,在这种情况下为ISO-8859-1)读取CSV.

BufferedReader reader = new BufferedReader(new InputStreamReader(input, "ISO-8859-1"));

您还需要确保JDBC连接字符串包含具有正确字符集的characterEncoding参数(这是创建表时使用的字符集,您尚未在MySQL数据库上弄清楚该字符集).如果它看起来像是Unicode字符集,则还需要添加参数useUnicode = true.

String url = "jdbc:mysql://localhost:3306/dbname?characterEncoding=UTF-8&useUnicode=true";

您的下一个问题可能是如何确定我的数据库表正在使用哪个字符集?您可以使用SHOW命令执行此操作.它将包含有关字符集的信息.

SHOW CREATE DATABASE dbname; -- shows CREATE DATABASE statement.
SHOW CREATE TABLE dbname.tblname; -- shows CREATE TABLE statement.

就是说,与问题无关,您是否知道MySQL提供了内置的CSV导入功能,因此您不一定为此需要Java / JDBC?签出LOAD DATA INFILE command.您可以将CSV文件的字符集指定为命令参数,MySQL会担心转换本身是否正确.

标签:character-encoding,csv,jdbc,java,mysql
来源: https://codeday.me/bug/20191105/1996707.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有