在SQL中利用通项公式形成三角序列

在前作 https://www.cnblogs.com/xiandedanteng/p/12735898.html中,我们可以用Java程序制成三角序列.

复制代码
1,
2,2,
3,3,3,
4,4,4,4,
5,5,5,5,5,
6,6,6,6,6,6,
7,7,7,7,7,7,7,
8,8,8,8,8,8,8,8,
9,9,9,9,9,9,9,9,9,
复制代码

其实在SQL里也能做到,程序如下:

select level,floor(sqrt(2*level)+1/2) 
from dual 
connect by level<22;

结果如下:

这种做法的核心是通项公式 f(n)=floor(sqrt(2n)+0.5)

然后利用分析函数来做三角序列就可以了:

select listagg(n,',') within group( order by n) from
(
    select floor(sqrt(2*level)+1/2) as n 
    from dual 
    connect by level<46
)
group by n

结果:

--2020-04-23--

posted @   逆火狂飙  阅读(175)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2018-04-23 【ZT】民间故事:女子怀孕回娘家,遇到流寇被掳,丈夫救人娶娇妻
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示