随心Fly
2015-01-27 14:50:11
完
java读取csv格式的文件,编码是utf-8 mysql也是utf-8,读取打印正常为什么存到数据库文字乱码?
java代码如下:
String filePath = "C://***//**.csv"; BufferedReader bufferedReader = null; Connection conn = null; String driver = "com.mysql.jdbc.Driver"; String url = "jdbc:mysql://192.168.9.90:3306/***"; try { Class.forName(driver); conn = DriverManager.getConnection(url, "**", "***"); bufferedReader = new BufferedReader(new InputStreamReader(new FileInputStream(filePath))); String line =null; File file=new File(filePath); CodepageDetectorProxy detector = CodepageDetectorProxy.getInstance(); detector.add(new ParsingDetector(false)); detector.add(JChardetFacade.getInstance()); detector.add(ASCIIDetector.getInstance()); detector.add(UnicodeDetector.getInstance()); java.nio.charset.Charset charset = null; try { charset = detector.detectCodepage(file.toURI().toURL()); } catch (Exception ex) { ex.printStackTrace(); } String charsetName = null; if (charset != null) { charsetName = charset.name(); } else { charsetName = "UTF-8"; } System.out.println(charsetName); while ((line = bufferedReader.readLine()) != null) { String[] columns = line.split("\t"); String last = columns[1]; System.out.println(last); PreparedStatement pstmt = conn.prepareStatement("insert into ordernew(c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,c11,c12,c13) values(?,?,?,?,?,?,?,?,?,?,?,?,?)"); pstmt.setString(1, columns[0]); pstmt.setString(2, columns[1]); pstmt.setString(3, columns[2]); pstmt.setString(4, columns[3]); pstmt.setString(5, columns[4]); pstmt.setString(6, columns[5]); pstmt.setString(7, columns[6]); pstmt.setString(8, columns[7]); pstmt.setString(9, columns[8]); pstmt.setString(10, columns[9]); pstmt.setString(11, columns[10]); pstmt.setString(12, columns[11]); pstmt.setString(13, columns[12]); pstmt.executeUpdate(); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ try { conn.close(); bufferedReader.close(); } catch (Exception e) { e.printStackTrace(); } }
评论

最代码官方 LV168
2015年1月27日
造成数据库存储乱码的问题很多,你正好涉及了很多流程。
1.读取文件必须是正常的utf8编码
2.写入数据库时编码也必须是正常的utf8编码
3.读取数据库时编码也必须指定。
new BufferedReader(new InputStreamReader(new FileInputStream(filePath)));
未指定读取文件编码,改为
new BufferedReader(new InputStreamReader(new FileInputStream(filePath),"utf-8"));
数据库连接未指定编码:
String url = "jdbc:mysql://192.168.9.90:3306/***";
改为:
String url = "jdbc:mysql://192.168.9.90:3306/***?useUnicode=true&characterEncoding=utf-8";
我记得如果是mysql5.5以上就不需要指定?useUnicode=true&characterEncoding=utf-8也可以。
评论(5)
最佳答案
- 等 最代码怎么获取牛币啊?
- 完 谁来告诉我最代码上线的时间,答对者给5牛币,先来先得
- 等 牛友们,大家好,你们做程序员多久了?现在还好吗?
- 完 在微信打开的页面里进行app下载
- 等 最代码2014年欢乐聚声会
- 完 mysql如何查询表数据并且对3个字段降序的SQL?
- 完 最代码牛币机制改革
- 完 成功的在bae上使用了自定义运行环境 jetty+nginx的组合,大家对jetty+nginx优化有哪些心得?
- 完 进来分享一下各位牛牛是如何加入最代码大家庭的?
- 等 为什么java BufferedImage类处理大图直接抛出内存溢出的异常?
- 等 最代码是否开发手机app客户端?
- 完 java程序员学习哪些java的技术?java有哪些框架?都能做哪方面的开发?
- 等 php格式网页文件怎么运行?
- 等 Java volatile值获取的问题
- 等 前端vue,拦截了登录后台后,返回的token,requests拦截token,但是发送请求的时候,就出现跨越异常
- 等 大专本科计算机科班怎么找到Java工作?
- 等 eclipse怎么把三个java swing游戏项目合成一个项目?
- 完 伙伴们,大家都有什么好的解压方式么,分享一下~
- 完 三四线城市,6、7k,运维工作,索然无味,想去辞职上培训,各位牛牛有什么建议嘛
- 等 jsp页面输入中文变成问号
- 等 JPA在线上运行一段时间后报错Caused by: java.lang.IncompatibleClassChangeError: null
- 等 PHP 这个规则用preg_match_all怎么写
- 等 大佬们,有没有知道Alfresco如何配置LDAP登录呢?
- 等 php的install目录是框架带的吗?


Magic丶M LV6
2021年4月29日
是数据库 LV3
2021年2月6日
码农自带盐啊 LV3
2018年4月23日
touch39 LV10
2015年12月23日
我的最代码 LV20
2015年8月14日
yodang1
2015年6月12日
暂无贡献等级
雨、小雨 LV8
2015年6月10日
cz973409335 LV2
2015年4月30日
1232135543 LV10
2015年3月25日
774529096 LV9
2015年3月9日