免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3511 | 回复: 7
打印 上一主题 下一主题

LOAD DATA INFILE源文件是繁体中文的问题【已解决】 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-11 11:07 |只看该作者 |倒序浏览
源文件内容是用shell产生的随机数据,如下:
1 顧客1 男 10000000 1928-01-01 80 200000000 300000000 800000000 customer1@gmail.com 杭州 1 會計師 1234567890 是
2 顧客2 男 10000000 1953-01-01 55 200000000 300000000 800000000 customer2@gmail.com 成都 2 會計師 1234567890 是
3 顧客3 女 10000000 1978-01-01 30 200000000 300000000 800000000 customer3@gmail.com 杭州 3 會計師 1234567890 是
4 顧客4 男 10000000 1913-01-01 95 200000000 300000000 800000000 customer4@gmail.com 成都 4 商人 1234567890 是

使用load data时并没有报错:
mysql> LOAD DATA INFILE '/tmp/customer.txt' INTO TABLE customer;
Query OK, 10001 rows affected, 65535 warnings (0.13 sec)
Records: 10001  Deleted: 0  Skipped: 0  Warnings: 150015

但是查询下来只有第一列数据生效了:
mysql> select * from customer limit 1;
+------------+------+-----+---------------+----------+-----+----------+------+--------+-------+--------+-------------+------------+----------------+--------------+
| CustomerID | Name | Sex | HKIDOrPportNo | Birthday | Age | Telphone | Fax  | Mobile | Email | Region | HomeAddress | Occupation | CustomerSerial | IsLikeAccept |
+------------+------+-----+---------------+----------+-----+----------+------+--------+-------+--------+-------------+------------+----------------+--------------+
|          1 |      |     |               | NULL     |   0 | NULL     | NULL |   NULL | NULL  | NULL   | NULL        | NULL       |                | NULL         |
+------------+------+-----+---------------+----------+-----+----------+------+--------+-------+--------+-------------+------------+----------------+--------------+

有什么办法解决这个问题吗?

ps:上面的文件在linux直接more是乱码的,我down下来用ultraedit查看是没有问题的

[ 本帖最后由 geyun616 于 2008-7-11 12:18 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-07-11 11:11 |只看该作者
有很多的warning,show warnings看一下什么警告

论坛徽章:
0
3 [报告]
发表于 2008-07-11 11:13 |只看该作者
mysql> show warnings;
+---------+------+-------------------------------------------------+
| Level   | Code | Message                                         |
+---------+------+-------------------------------------------------+
| Warning | 1265 | Data truncated for column 'CustomerID' at row 1 |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |
| Warning | 1261 | Row 1 doesn't contain data for all columns      |

论坛徽章:
0
4 [报告]
发表于 2008-07-11 11:14 |只看该作者
表一共15列,我产生的数据也有15列啊

论坛徽章:
0
5 [报告]
发表于 2008-07-11 11:42 |只看该作者
彻底解决MySQL中文乱码

建议去google一下。

论坛徽章:
0
6 [报告]
发表于 2008-07-11 12:02 |只看该作者
可能是shell脚本的原因,虽然看上去每列都有空格隔开,但是mysql好像并没有识别。
改成用,号分隔在load时用FIELDS TERMINATED BY ',';就可以了

[ 本帖最后由 geyun616 于 2008-7-11 12:20 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2008-07-11 21:24 |只看该作者

论坛徽章:
0
8 [报告]
发表于 2008-08-03 22:40 |只看该作者
原帖由 geyun616 于 2008-7-11 12:02 发表
可能是shell脚本的原因,虽然看上去每列都有空格隔开,但是mysql好像并没有识别。
改成用,号分隔在load时用FIELDS TERMINATED BY ',';就可以了

原来是这样
学习了:)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP