> 데이터 베이스 > MySQL 튜토리얼 > select into outfile导出数据sql语句

select into outfile导出数据sql语句

WBOY
풀어 주다: 2016-06-07 17:53:01
원래의
2432명이 탐색했습니다.

select into outfile命令是mysql中一种用来导出数据的一个常用的命令,下面我来介绍select into outfile的用法,有需要的朋友可参考。

mysql管理数据当然可以很方便的导出数据,但是当数据量很大是,phpmyadmin很可能会发生执行超时,其实很容易用select into outfile解决!

SELECT...INTO OUTFILE语句的主要作用是让您可以非常快速地把一个表转储到服务器机器上。如果您想要在服务器主机之外的部分客户主机上创建结果文件,您不能使用SELECT...INTO OUTFILE。在这种情况下,您应该在客户主机上使用比如“mysql –e "SELECT ..." > file_name”的命令,来生成文件。

SELECT...INTO OUTFILE是LOAD DATA INFILE的补语;用于语句的exort_options部分的语法包括部分FIELDS和LINES子句,这些子句与LOAD DATA INFILE语句同时使用


如下:(将数据库wordpress中的wp_posts表导出到D盘)

 代码如下 复制代码

select * into outfile 'd:data.txt' from wp_posts

需要注意的是:使用select into outfile语句,必须要有执行权限,路径必须存在,否则使用当前数据库目录,

例2

 代码如下 复制代码

表结构及测试数据
CREATE TABLE `tab`(

  `id` INT(1) NOT NULL AUTO_INCREMENT PRIMARY KEY,

  `name` VARCHAR(10) NOT NULL,

  `add` VARCHAR(20) CHARACTER SET gbk NOT NULL

)ENGINE=InnoDB DEFAULT CHARSET=utf8;

 

INSERT INTO `tab`(`name`,`add`) VALUES

('中文', '这列不会乱码'),

('汉字', '这列不会乱码');

 

SELECT * FROM `tab`;

 

+----+------+--------------+

| id | name | add          |

+----+------+--------------+

|  1 | 中文 | 这列不会乱码 |

|  2 | 汉字 | 这列不会乱码 |

+----+------+--------------+
 rows in set (0.00 sec)

代码

 代码如下 复制代码

在 INTO OUTFILE 中使用变量
SET @tmp_sql = CONCAT(
  "SELECT * INTO OUTFILE 'C:\\sql_", DATE_FORMAT(NOW(), '%Y%m%d%H%i%s'),
  ".txt' FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY "'" LINES TERMINATED BY 'rn' FROM `tab`;");
PREPARE s1 FROM @tmp_sql;
EXECUTE s1;
DROP PREPARE s1;

上面的代码会在C盘下生成“sql_当前时间.txt”的文件,避免INTO OUTFILE文件已存在错误

注:直接在命令行中SELECT显示无乱码,但使用 INTO OUTFILE 导出后有乱码,此时必须修改显示乱码的列的字符集

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿