首页 > 数据库 > mysql教程 > 如果没有 Oracle 的 CONNECT BY 或类似函数,如何在 MySQL 中生成 JOIN 行?

如果没有 Oracle 的 CONNECT BY 或类似函数,如何在 MySQL 中生成 JOIN 行?

Linda Hamilton
发布: 2025-01-15 10:02:43
原创
141 人浏览过

How Can I Generate Rows for JOINs in MySQL Without Oracle's `CONNECT BY` or Similar Functions?

MySQL JOIN:无需 Oracle 的行生成 CONNECT BY

与 Oracle 用于在连接中生成行集的方便的 CONNECT BY LEVEL 子句不同,MySQL 缺乏直接的等效项。 Oracle 的方法简化了连接序列的创建:

<code class="language-sql">SELECT *
FROM dual
CONNECT BY LEVEL < p></code>
登录后复制

同样,MS SQL Server 使用递归:

<code class="language-sql">WITH hier(row) AS (
    SELECT 1
    UNION ALL
    SELECT row + 1
    FROM hier
    WHERE row < p></code>
登录后复制

PostgreSQL 提供generate_series

<code class="language-sql">SELECT *
FROM generate_series(1, n)</code>
登录后复制

然而,MySQL 需要替代策略来生成 JOIN 操作所需的行。 由于缺乏内置行生成器,这些通常涉及解决方法或外部工具。

以上是如果没有 Oracle 的 CONNECT BY 或类似函数,如何在 MySQL 中生成 JOIN 行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板