SQL生成序列浅析

01.sqlserver版本

使用sqlserver将数据复制n条

复制代码
 select
      t.indx,
      t.name,
      tmp.vlue
from (
     values(1,'苹果')
)  as t(indx,  name)
,(
    select
         [number]  as vlue
     from master.dbo.spt_values
     where [type] = 'p'
        and [number] between 1 and 10
) as tmp

spt_values是什么

spt_values是SQL Server新增的一个系统表,表里面都是一些枚举数据。 (因为该表属于系统数据库master下面,所以通常在表名前面添加库名master) **解释:但是通常我们使用的是Type='P'的数据记录,master.dbo.spt_values表的字段值为"P"的对应number字段值是从0-2047。

master.dbo.spt_values使用示例

制作日历

复制代码
SELECT 
  CONVERT(NVARCHAR(10), DATEADD(DAY, number, '2024-01-01'), 120) AS calendar
FROM 
  master..spt_values 
WHERE TYPE = 'P' 
 AND number <= DATEDIFF(DAY, '2024-01-01', '2024-01-31')

02.postgresql版本

使用sqlserver将数据复制n条

复制代码
 select
      t.indx,
      t.name,
      tmp.vlue
from (
     values(1,'苹果')
)  as t(indx,  name)
,(
    select
         vlue
     from  generate_series(1,  10,  1)tmp(vlue)

) as tmp

generate_series(start, stop, step)函数

generate_series是PostgreSQL提供的一个内置的函数,可以用在SQL语句中,生成一个数字序列和日期序列的记录集。函数generate_series(start, stop, step)的参数分别是序列开始值,序列结束值和步长值。

generate_series()日期序列 示例

复制代码
SELECT * FROM generate_series('2022-01-01'::date, '2022-01-05'::date, '1 day'::interval);
相关推荐
todoitbo3 分钟前
使用n8n搭建服务器监控系统:从Webhook到Telegram告警的完整实现
运维·服务器·数据库·ai·向量数据库·流处理·n8n
only-code9 分钟前
MCP驱动的Rgentic RRG(向量数据库+网络搜索)
数据库·python·大模型·函数调用·mcp
dongchen。1 小时前
MySQL第四次作业
数据库·mysql
普普通通的南瓜1 小时前
SM2 vs RSA/ECC:双算法 SSL 证书的性能对比与优化方案
数据库·网络协议·ssl
九章-2 小时前
中旅国际数据库国产化升级:以金仓KES打造安全可控的旅游服务底座
数据库·安全·旅游
pipip.3 小时前
Redis vs MongoDB:内存字典与文档库对决
数据库·redis·缓存
小白银子4 小时前
零基础从头教学Linux(Day 62)
数据库·mysql·oracle
Boilermaker19927 小时前
【MySQL 进阶】高性能优化
数据库·sql·mysql
CoderOnly7 小时前
SQL,CROSS JOIN速度优化
数据库·sql·mysql
Highcharts.js8 小时前
入门指南|从文件到图表:Highcharts对接数据库(CSV、Excel)实现数据同步绘制图表
数据库·excel·数据同步·highcharts·数据对接·文件导入