• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

select into outfile导出数据sql语句

mysql 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

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 TERMIN本文来源gaodai#ma#com搞*!代#%^码网5ATED 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 导出后有乱码,此时必须修改显示乱码的列的字符集


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:select into outfile导出数据sql语句

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址