网站建设资讯

NEWS

网站建设资讯

MySQL查询结果怎么导出到文件-创新互联

本篇内容主要讲解“MySQL查询结果怎么导出到文件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL查询结果怎么导出到文件”吧!

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名雅安服务器托管、营销软件、网站建设、吉林网站维护、网站推广。

如果需要在查询语句返回的列中包含一列表示该条记录在整个MySQL查询结果集中的行号,ISOSQL:2003标准提出的方法是提供ROW_NUMBER()/RANK()函数。Oracle中可以使用标准方法(8i版本以上),也可以使用非标准的ROWNUM;MSSQLServer则在2005版本中提供了ROW_NUMBER()函数;但在MySQL中似乎还没有这样的系统自带功能。虽然LIMIT可以很方便的对返回的结果集数量和位置进行过滤,但过滤出来的记录的行号却没办法被SELECT到。据说MySQL是早就想增加这个功能了,但我是还没找到。

解决方法是通过预定义用户变量来实现:

set@mycnt=0;select(@mycnt:=@mycnt1)asROWNUM,othercolfromtblnameorderbyothercol;

这样查询出来的结果集中ROWNUM就保存了行编号信息。这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据,并且希望知道这行数据在之前排序中的位置时就用得着了。比如:

set@mycnt=0;select*from(select(@mycnt:=@mycnt1)asROWNUM,othercolfromtblnameorderbyothercol)asAwhereothercol=OneKeyID;

当然你也可以通过创建临时表的方法把查询结果写到某个拥有auto_increment字段的临时表中再做查询,但考虑到临时表在MySQLmaster/slave模式下可能产生的问题,用这样临时用户定义变量的方式来计算查询结果集每一行对应的行号还是更为简洁--除非你愿意在PHP或其他语言脚本中对返回的整个结果集再作处理。

MySQL查询结果导出到文件的方法有哪些

mysql>select1intooutfile'/tmp/t1.txt';QueryOK,1rowaffected(0.00sec)mysql>select1intooutfile'/tmp/t1.txt';ERROR1086(HY000):File'/tmp/t1.txt'alreadyexists

还可以使用另外一种方法:

mysql>pagercat>/tmp/t1.txtPAGERsetto'cat>/tmp/t1.txt'mysql>select1;\!cat/tmp/t1.txt1rowinset(0.00sec)+---+|1|+---+|1|+---+

这样你能很方便的查询到2条sql的差异:

mysql>pagercat>/tmp/t01.txtPAGERsetto'cat>/tmp/t01.txt'mysql>select12345unionselect67890;2rowsinset(0.02sec)mysql>pagercat>/tmp/t02.txtPAGERsetto'cat>/tmp/t02.txt'mysql>select12345unionselect67891;2rowsinset(0.00sec)mysql>\!vimdiff-o/tmp/t0[12].txt2filestoedit+-------+|12345|+-------+|12345||67890|+-------+/tmp/t01.txt+-------+|12345|+-------+|12345||67891|+------+/tmp/t02.txt

到此,相信大家对“MySQL查询结果怎么导出到文件”有了更深的了解,不妨来实际操作一番吧!这里是创新互联建站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


新闻名称:MySQL查询结果怎么导出到文件-创新互联
本文路径:http://cdweb.net/article/ddgjpo.html