提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:王香|2018-08-22 09:55:39.000|阅读 460 次
概述:本文详细介绍了如何在FastReport.Net中使用SQL函数,以及表函数返回表,标量函数返回单个值。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
【下载FastReport.Net最新版本】
要在MS SQL中获取数据,可以使用sql查询,存储过程和存储函数,之前我们已经讨论了如何使用动态查询和存储过程作为报表数据源,在本文中,我们将创建一个表和标量函数,并在报表中使用它们,表函数返回表,标量函数返回单个值。首先,在MS SQL中创建一个表函数:
USE [testdb] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ============================================= -- Description: Returns customers who live in the specified city -- ============================================= CREATE FUNCTION [dbo].[GetCustomersFromCity] ( @city VARCHAR(20) ) RETURNS TABLE AS RETURN ( SELECT * FROM dbo.CUSTOMER WHERE CITY = @city )
该函数采用一个参数——城市名称,并返回此城市中的客户列表。再添加一个现在的标量函数:
USE [testdb] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ============================================= -- Description: Returns last added customer -- ============================================= CREATE FUNCTION [dbo].[GetLastCustomer] () RETURNS VARCHAR(30) AS BEGIN DECLARE @Name VARCHAR(30) SELECT TOP 1 @Name = CONCAT(ind.FIRST_NAME, ' ', ind.LAST_NAME) FROM dbo.Customer cus JOIN dbo.Individual ind ON ind.CUST_ID = cus.CUST_ID ORDER BY cus.CUST_ID RETURN @Name END
此函数不接受参数,但返回最后注册的客户端名称。现在让我们继续查看报表。首先,在报表中创建一个参数,我们将使用它将城市名称转移到函数,以检索数据。
添加到MS SQL数据库的连接:
然后,在下一步中,我们被要求选择表,但我们将使用Add SQL query ...按钮
在下一步中,设置新表的名称——TableFunction,点击Next:
与存储过程不同,函数用作表,也就是说,需要使用Select来获取数据:
在下一步中,我们需要添加city查询参数,在其Expression属性中,选择报表的Param参数,单击Finish,得到一个新的数据源:
现在添加对话框窗体并将报表的Param参数拖到它上面,将字段从TableFunction表拖到Data band,运行报表,在对话框中输入值:
从表函数中获取样本:
文章开头我们创建了两个函数,这个例子更简单,因为我没有向这个函数添加一个传入参数。让我们再创建一个数据源,另外,至于第一次——connection to MS SQL,再次单击Add SQL query ...按钮,调用标量函数与调用表函数略有不同:
跳过所有其他步骤:
再添加一页报表并将数据拖动到新数据源的单个字段——ScalarFunc,运行报表,转到第二页:
如上所示,使用函数获取数据非常简单,它们将帮助您在开发报表及其执行时节省时间。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢