如何在 MySQL 中制作行生成器?

时间:2023-05-01
本文介绍了如何在 MySQL 中制作行生成器?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

有没有办法生成可以在类似于 Oracle 语法的 JOIN 中使用的任意数量的行:

Is there a way to generate an arbitrary number of rows that can be used in a JOIN similar to the Oracle syntax:

SELECT LEVEL FROM DUAL CONNECT BY LEVEL<=10

推荐答案

讨厌这么说,但是 MySQL 是四大中唯一一个没有的 RDBMS有这个功能.

Hate to say this, but MySQL is the only RDBMS of the big four that doesn't have this feature.

Oracle中:

SELECT  *
FROM    dual
CONNECT BY
        level < n

MS SQL中(最多100行):

WITH hier(row) AS
        (
        SELECT  1
        UNION ALL
        SELECT  row + 1
        FROM    hier
        WHERE   row < n
        )
SELECT  *
FROM    hier

或使用提示32768

WITH hier(row) AS
        (
        SELECT  1
        UNION ALL
        SELECT  row + 1
        FROM    hier
        WHERE   row < 32768
        )
SELECT  *
FROM    hier
OPTION (MAXRECURSION 32767) -- 32767 is the maximum value of the hint

PostgreSQL中:

SELECT  *
FROM    generate_series (1, n)

MySQL中,什么都没有.

这篇关于如何在 MySQL 中制作行生成器?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

上一篇:Mysql:选择两个日期之间的所有数据 下一篇:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT 最大存储大小

相关文章