SSAS - 生成模拟测试数据

在分析系统中,因为数据量太大,无法直观看出统计结果的正确性。在使用新技术时,需要使用简单的数据,来验证语句的结果。本文介绍SQL Server生成模拟数据的方法。

使用技术

一、静态数据:VALUES

  1. 使用说明
  • 格式:VALUES (列1值, 列2值, 列3值), (列1值2, 列2值2, 列3值2)…
  • 命名:AS 表名(列1名, 列2名, 列3名),列的数量和顺序必须和 VALUES 里的一致
  • 类型:SQL Server 会自动推断列的数据类型(如数字、字符串、小数),也可手动指定(如 CAST(‘产品A’ AS VARCHAR(20)))。
  1. 示例
SELECT*FROM(VALUES(1,'张三','销售部',8000.00),(2,'李四','技术部',9500.50),(3,'王五','财务部',7800.80))ASEmployees(Id,Name,Department,Salary);
  1. 结果
IdNameDepartmentSalary
1张三销售部8000.00
2李四技术部9500.50
3王五财务部7800.80

二、序列数据:master.dbo.spt_values

  1. 使用说明
    利用 spt_values 生成时间序列:master.dbo.spt_values 中 type = ‘P’ 的记录包含连续的数字(0-2047),可以用它来生成 N 个月份的序列(对应 2024-2025 年)。

  2. 示例

SELECTnumberASId,DATEADD(MONTH,number,'2024-01-01')AS[Date]FROMmaster.dbo.spt_valuesWHEREtype='P'ANDnumberBETWEEN0AND23
  1. 结果
IdDate
02024-01-01 00:00:00.000
12024-02-01 00:00:00.000
22024-03-01 00:00:00.000
232025-12-01 00:00:00.000

三、随机数字:ABS(CHECKSUM(NEWID()))

  1. 使用说明
  • ABS(CHECKSUM(NEWID())):核心作用是生成一个随机的 32 位整数(非负数),常用来快速生成无规律的随机数,是 SQL Server 中生成随机整数的经典写法。
  • NEWID():创建一个全球唯一的UNIQUEIDENTIFIER类型值(GUID/UUID),格式如E2B5D86C-7B9F-4A8D-9876-1234567890AB。每次执行都会生成完全不同的值。
  • CHECKSUM():计算哈希值,对输入的任意值计算一个 32 位的整数校验和(哈希值),返回值是INT类型,范围为-21474836482147483647(可能是正数或负数)。
  • ABS():取绝对值
  1. 示例
SELECTABS(CHECKSUM(NEWID())),ABS(CHECKSUM(NEWID())),ABS(CHECKSUM(NEWID()))
  1. 结果
82013466315905810271359169063

实际应用

一、生成2025年目标数据

  1. 语句
SELECTDATEADD(MONTH,sv.number,'2025-01-01')ASDate,p.ProductId,ABS(CHECKSUM(NEWID()))%1000+100ASQuantity,(ABS(CHECKSUM(NEWID()))%1000+100)*10ASTotalFROMmaster.dbo.spt_values svCROSSJOIN(VALUES(101),(102),(103))ASp(ProductId)WHEREsv.type='P'ANDsv.numberBETWEEN0AND11ORDERBYDate,ProductId;
  1. 结果
DateProductIdQuantityTotal
2025-01-01 00:00:00.00010110114210
2025-01-01 00:00:00.0001024098650
2025-01-01 00:00:00.0001036849420
2025-02-01 00:00:00.0001012714340
2025-02-01 00:00:00.0001024116420
2025-02-01 00:00:00.0001032967140
2025-12-01 00:00:00.0001016424680
2025-12-01 00:00:00.00010210033790
2025-12-01 00:00:00.0001031596500
  1. 说明
  • 月份采用日期表示,以与实际完成数据维度对齐
  • 数量通常改为固定值,以方便在测试时判断统计是否正确
  • 用于SSAS命名查询,需去掉order by。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1190513.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于FPGA的图像形态学腐蚀处理Verilog开发与开发板硬件测试

目录 1.前言 2.算法硬件测试效果图预览 3.算法运行软件版本 4.部分核心程序 5.算法测试参数 6.硬件测试说明 7.算法理论概述 8.算法完整程序工程 1.前言 本课题为之前博客中写的文章的硬件调试: 基于FPGA的图像形态学腐蚀算法实现,包括tb测试文件和MATLAB…

【技术分享】让AI变“听话“:AI Agent Skill完全指南,收藏备用

文章介绍AI Agent Skill工具,通过结构化知识文档解决AI自作主张、质量不稳定和重复劳动三大痛点。Skill包含基础架构、流程规范和质量标准三层,提高AI的可控性、一致性和效率。文章详解设计原则、创建步骤和最佳实践,通过写作、代码助手、数据…

NFT:从加密猫到数字资产新纪元的全面解析

1 NFT:数字世界的所有权革命在数字化生存日益深入的今天,我们生产、消费和传播的数字内容比以往任何时候都多。然而,在传统的互联网架构下,这些数字资产极易被复制和传播,导致原创者难以确权和获利。NFT​ 的诞生正是为…

AI智能体的“成长秘诀“:从强化学习到DPO算法,实现从被动执行到自我进化的飞跃【建议收藏】

智能体通过"学习与适应"能力实现从"被动执行"到"主动成长"的进化。文章详细介绍了6种核心学习方式(强化学习、监督学习等)和两大核心算法(PPO与DPO),并通过SICA、AlphaEvolve和OpenEvol…

干货满满:Redis 分布式锁必避的 8 大问题及解决方案

在分布式系统中,Redis 分布式锁虽能高效解决跨服务并发冲突,但实际落地时稍不注意就会踩坑——小到数据不一致,大到服务雪崩,这些问题多源于对 Redis 特性、分布式场景复杂性的考虑不周。之前开发电商库存和订单系…

数字钱包:如何正确选择使用你的数字钱包

加密货币世界里,“不是你的私钥,就不是你的币”​ 这句格言点明了私钥管理的重要性,而钱包正是守护这些私钥的关键工具。了解不同类型的钱包及其安全与便利的平衡,对管理数字资产至关重要。下面这个表格能让你快速把握冷钱包、热钱…

学习进度 4

今天学了点机器学习相关知识。 一、机器学习到底是什么 此前对机器学习的认知停留在“让电脑自己学习”的模糊概念里,今天才算有了清晰界定:机器学习是人工智能的核心分支,本质是让计算机通过数据训练,自动学习规律…

买礼物(洛谷P1194)

题目描述又到了一年一度的明明生日了,明明想要买 B 样东西,巧的是,这 B 样东西价格都是 A 元。但是,商店老板说最近有促销活动,也就是:如果你买了第 I 样东西,再买第 J 样,那么就可以…

SSAS - 步骤一:通过VS2022新建项目

本文介绍如何通过Visual Studio 2022创建SSAS项目。 打开CMD窗口,输入如下命令。注意替换服务器地址和VS2022文件的目录。 runas /netonly /user:192.168.88.74\administrator "C:\Program Files\Microsoft Visual Studio\2022\Enterprise\Common7\IDE\devenv.…

Springboot中使用activemq

1. 引入ActiveMQ的SpringBoot插件<!-- ActiveMQ --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-activemq</artifactId></dependency>2. application中增加activemq的配置spring:acti…

公路修建(洛谷P1265)

题目描述某国有 n 个城市&#xff0c;它们互相之间没有公路相通&#xff0c;因此交通十分不便。为解决这一“行路难”的问题&#xff0c;政府决定修建公路。修建公路的任务由各城市共同完成。修建工程分若干轮完成。在每一轮中&#xff0c;每个城市选择一个与它最近的城市&…

程序监控与异常防护-PART-Simulink-看门狗

程序监控与异常防护-PART-Simulink-看门狗程序监控与异常防护-PART-Simulink-看门狗 关键词 看门狗、程序监控、异常处理、Simulink、自动化控制一、问题分析:为什么需要看门狗 在自动化实验控制平台中,我们经常会遇…

LIDA 477 编码器位移/速度/加速度采集与转换-PART-LIDA 477-采集转换

LIDA 477 编码器位移/速度/加速度采集与转换-PART-LIDA 477-采集转换LIDA 477 编码器位移/速度/加速度采集与转换-PART-LIDA 477-采集转换 关键字:LIDA 477、Hidenhain、磁姗尺、编码器、位移、速度、加速度、Simulin…

1121

编程练习

软件升级回退报告

一、引言为提升软件系统性能、优化现有功能并修复已知问题&#xff0c;本团队于[升级实施日期]对[软件名称]系统开展了版本升级工作&#xff0c;计划将系统从[原版本号]升级至[目标版本号]。升级后&#xff0c;系统出现[简要说明核心问题&#xff0c;如&#xff1a;关键功能异常…

SQL Server数据库

数据库按照特定的数据结构来组织、存储和管理数据的集合作用高效地存储大量数据&#xff0c;并支持快速的查询、修改、删除等操作同时保证数据的安全性、完整性和一致性。一&#xff0c;创建主数据文件命令创建&#xff1a;create 修改&#xff1a;alt…

1124

编程练习

灵活用工系统开发全流程与案例分享【弹性用工解决方案|附源码】

一、模块设计分包商&#xff1a;税地注册公司&#xff0c;用于在当地申请有利的税收政策&#xff0c;是实际报税公司。 代理商&#xff1a;代理商可以邀请客户使用本平台&#xff0c;平台会给予代理商一定的服务费差价作为佣金。 客户&#xff1a;使用本平台进行工资发放的…