现在的位置: 首页 > 数据库 > 正文

MySQL查询结果集中得到记录行号如何实现?MySQL查询结果导出到文件的方法有哪些

2020年05月08日 数据库 ⁄ 共 1692字 ⁄ 字号 评论关闭

  如果要在MySQL查询结果集中得到记录行号,应该如何实现呢?在计算某特定记录在查询结果中的位置用到。下面学步园小编来讲解下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查询结果导出到文件的方法有哪些”的内容,希望对大家有用。更多资讯请关注学步园。学步园,您学习IT技术的优质平台!

抱歉!评论已关闭.