前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >load data部分字段的正确写法

load data部分字段的正确写法

作者头像
MySQL轻松学
发布2018-07-26 16:17:13
1.2K0
发布2018-07-26 16:17:13
举报
文章被收录于专栏:MYSQL轻松学MYSQL轻松学

在日常运维中,会经常遇到将文件中数据导入到数据库中,如果是.sql文件,直接采用source方式即可;如果是.csv、.txt文件,可以采用 load data 方式。这两种方式都十分熟悉,这里说一种特殊情况:

需求很简单,有如下txt文件需要将数据导入库表对应字段中

文件已转换到unix,字符类型utf8,跟数据库一致,无乱码

数据对应字段

(date,division_id,division_name,pur_first_dept_cd,pur_first_dept_name,type,cost)

表结构(字符类型足够大):

开始这么写的

load data infile './day.txt' into table day(date,division_id,division_name,pur_first_dept_cd,pur_first_dept_name,type,cost) fields terminated by ',' lines terminated by '\n';

报语法错误:

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'fields terminated by ',' lines terminated by '\n'' at line 1

将分隔符去掉:

load data infile './day.txt' into table day(date,division_id,division_name,pur_first_dept_cd,pur_first_dept_name,type,cost);

Query OK, 5 rows affected, 35 warnings (0.00 sec)

Records: 5 Deleted: 0 Skipped: 0 Warnings: 35

成功,但是35个warnings

查看show warnings ;

数据错位了,显然还是不对,必须得加上分隔符。

最后改成

load data infile './day.txt' into table day fields terminated by ',' lines terminated by '\n' (date,division_id,division_name,pur_first_dept_cd,pur_first_dept_name,type,cost);

Query OK, 5 rows affected (0.00 sec)

Records: 5 Deleted: 0 Skipped: 0 Warnings: 0

没有报错,导入成功。

load data 导入部分字段数据时,需要把字段放到分隔符之后,这点跟之前所理解的有些差异,以后再遇到同类问题不会再走弯路。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-05-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 MYSQL轻松学 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档