随心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(); } }
评论
所有回答列表(6)
最代码官方 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日