SELECT INTO…OUTFILE语句和LOAD DATA …INFILE语句使用说明

来源:互联网 发布:ps8.0软件下载 编辑:程序博客网 时间:2024/06/08 04:26

SELECT INTO…OUTFILE语句把表数据导出到一个文本文件中,并用LOAD DATA …INFILE语句恢复数据。但是这种方法只能导出或导入数据的内容,不包括表的结构,如果表的结构文件损坏,则必须先恢复原来的表的结构。

一、SELECT INTO…OUTFILE语法:

select * from Table into outfile '/路径/文件名'    fields terminated by ','           enclosed by '"'    lines terminated by '\r\n'

说明:
1. 路径目录必须有读写权限777
2. 文件名必须唯一
3. fields terminated by ‘,’必须存在,否则打开的文件的列在同一的单元格中出现

  • FIELDS子句:在FIELDS子句中有三个亚子句:TERMINATED BY、 [OPTIONALLY] ENCLOSED BY和ESCAPED BY。如果指定了FIELDS子句,则这三个亚子句中至少要指定一个。
    • TERMINATED BY用来指定字段值之间的符号,例如,“TERMINATED BY ‘,’”指定了逗号作为两个字段值之间的标志。
    • ENCLOSED BY子句用来指定包裹文件中字符值的符号,例如,“ENCLOSED BY ’ ” ‘”表示文件中字符值放在双引号之间,若加上关键字OPTIONALLY表示所有的值都放在双引号之间。
    • ESCAPED BY子句用来指定转义字符,例如,“ESCAPED BY ‘*’”将“*”指定为转义字符,取代“\”,如空格将表示为“*N”。
  • LINES子句:在LINES子句中使用TERMINATED BY指定一行结束的标志,如“LINES TERMINATED BY ‘?’”表示一行以“?”作为结束标志。

示例:

select * from(select `PhoneNo`        ,`TaskName`        ,`Status`        ,`Dialdtimes`        ,`Agent`        ,`DialTime`        ,`DialEndTime`        ,`DialResult`        ,`TalkEndTime` from t_title  union all select *  from (select t.PhoneNo         ,'task_20_2' as Name         ,IFNULL(b.status_name,'') as Status_name          ,IFNULL(t.DialedTimes,'')         ,IFNULL(t.AgentAccount,'')          ,IFNULL(t.DialTime,'')         ,IFNULL(t.DialEndTime,'')         ,'未呼' as result         ,IFNULL(t.TalkEndTime,'')  from t_od_taskphoneno t left join biz_outdial.phone_status b  on t.Status = b.status_id  where t.enterprise_id = "30092638"        AND TaskId = "49"        AND DialTime is null   order by ID desc limit 10) as tmp1 ) as tmpinto outfile  '/mnt/backup/test00001.csv'fields terminated by ','enclosed by '"'lines terminated by '\r\n

说明:
1. union all 和 union的区别
* Union,对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
* Union All,对两个结果集进行并集操作,包括重复行,不进行排序;
* Intersect,对两个结果集进行交集操作,不包括重复行,同时进行默认规则的排序;
* Minus,对两个结果集进行差操作,不包括重复行,同时进行默认规则的排序
2. IFNULL(t.AgentAccount,”),如果是缺省值,则用空来代替。因为不想要这个效果,所以加IFNULL(t.AgentAccount,”)这个限定条件
3. as tmp1必须要有,否则进行排序时 order by ID decs 提示”ID 不存在”的错误

二、LOAD DATA …INFILE语法

LOAD DATA …INFILE语句是SELECT INTO…OUTFILE语句的补语,该语句可以将一个文件中的数据导入到数据库中。基本语法:

load data [low_priority] [local] infile 'file_name txt' [replace | ignore]into table tbl_name[fields[terminated by't'][OPTIONALLY] enclosed by ''][escaped by'\' ]][lines terminated by'n'][ignore number lines][(col_name, )]

参考链接:
1. http://blog.sina.com.cn/s/blog_82f200cb01012aor.html
2. http://blog.csdn.net/vbloveshllm/article/details/42965317

0 0