解决方案 兼容 Oracle 和 MySQL for LIMIT 子句

Posted

技术标签:

【中文标题】解决方案 兼容 Oracle 和 MySQL for LIMIT 子句【英文标题】:Solution Compatible Oracle and MySQL for LIMIT clause 【发布时间】:2013-05-26 08:46:51 【问题描述】:

有没有兼容Oracle和mysql的解决方案来限制查询返回的行数?

例如在mysql中有LIMT子句

SELECT * FROM myTable LIMT 10;

在 Oracle 中,我们对 rownum 列使用条件

我想要一些适用于 MySQL 和 Oracle 的代码

【问题讨论】:

【参考方案1】:

我不知道没有数据库抽象层的解决方案,特别是如果要执行此解决方案。

即使您找到了解决这个特定问题的方法,在实现数据库可移植性的道路上还会遇到另外 99 个问题。我在回答类似问题here 时发布了我的经验

这个特定问题的好消息是,对于 DB2、PostgreSql、Oracle 和 MySql,您可以简单地包装/扩展查询以成为有限制的查询。但是您需要在应用程序的某个地方处理这个问题。

【讨论】:

【参考方案2】:

如果您的表有唯一的 id 列(或列组合),您可以执行以下操作:

select t.*
from t
where (select count(*) from t t2 where t2.id <= t.id) <= 10;

where 子句中的相关子查询是标准 SQL 语法,因此它应该在任何数据库中运行。

在小桌子上性能应该没问题。可以通过t(id) 上的索引来改进它。

【讨论】:

【参考方案3】:

假设有完美的自增(不跳过数字)字段且没有其他条件

获取最后 5 条记录

SELECT * FROM account
HAVING (SELECT MAX(id) FROM account) - 5 < id  

获取前 5 条记录

SELECT * FROM account
HAVING (SELECT MIN(id) FROM account) + 5 > id

【讨论】:

【参考方案4】:

在 oracle 中是

select * from mytable where rownum < 11

替代方法是分析函数,但 mysql 不支持。

【讨论】:

我相信@abderrahim_05 想要一个无需任何修改即可与它们一起使用的 SQL。 嗯,我正在开发必须同时适用于 Oracle 和 MySQL 的应用程序。

以上是关于解决方案 兼容 Oracle 和 MySQL for LIMIT 子句的主要内容,如果未能解决你的问题,请参考以下文章

MySql和Oracle加密函数兼容性

mysql和oracle兼容

多数据库适配 | 记一次数据源从Oracle到MySQL兼容切换历程

多数据库适配 | 记一次数据源从Oracle到MySQL兼容切换历程

多数据库适配 | 记一次数据源从Oracle到MySQL兼容切换历程

多数据库适配 | 记一次数据源从Oracle到MySQL兼容切换历程