- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 SQL Server 数据库编写报告。
我的表是:
表名:约会
id appointment_number applicant_name appointment_date appointment_time
----- ------------------ ------------------------ ---------------- ----------------
1 APP001 Anuj Tyagi 2022-12-28 11:00 AM
2 APP002 Puneet Pathak 2022-12-28 11:30 AM
3 APP003 Rajeev Kumar 2022-12-28 10:00 AM
表名:payments
id appointment_id fee_Type_name amount
----- ------------------ --------------- ----------
1 1 Consulatncy 500
2 1 Service Fee 100
3 1 Pharmacy 435
4 2 Consulatncy 800
5 2 Service Fee 160
6 2 Pharmacy 833
7 3 Consulatncy 500
8 3 Service Fee 100
表名:tax_details
id payment_id tax_name tax_percentage amount
----- -------------- --------------- -------------- ---------
1 1 CGST 5.00 25.00
2 1 SGST 2.50 12.50
3 2 CGST 8.00 8.00
4 2 SGST 4.00 4.00
5 3 CGST 10.00 43.50
6 3 SGST 8.00 34.80
7 4 CGST 5.00 40.00
8 4 SGST 2.50 20.00
9 5 CGST 8.00 12.80
10 5 SGST 4.00 6.40
11 6 CGST 10.00 83.30
12 6 SGST 8.00 66.64
13 7 CGST 5.00 25.00
14 7 SGST 2.50 12.50
15 8 CGST 8.00 8.00
16 8 SGST 4.00 4.00
我需要生成以下报告:
appointment_number applicant_name appointment_date appointment_time Consulatncy CGST SGST Service Fee CGST SGST Pharmacy CGST SGST
------------------ ------------------------ ---------------- ---------------- -------------- ------ ------ ------------- ------ ------ ---------- ------ ------
APP001 Anuj Tyagi 2022-12-28 11:00 AM 500 25.00 12.50 100.00 8.00 4.00 435.00 43.50 34.50
APP002 Puneet Pathak 2022-12-28 11:30 AM 800 40.00 20.00 160.00 12.80 6.40 833.00 83.30 66.64
APP003 Rajeev Kumar 2022-12-28 10:00 AM 500 25.00 12.50 100.00 8.00 4.00 0.00 0.00 0.00
在创建包含所有数据的 View 后,我尝试使用 PIVOT 将行转换为列。我面临的问题是:
我们将不胜感激。
我的枢轴努力:
SELECT @@AllSumColumns= COALESCE(@AllSumColumns + ',','') + 'SUM(' + QUOTENAME([fee_name])+'))' + ' AS ' + QUOTENAME([fee_name])
FROM (
SELECT DISTINCT [fee_name] FROM [dbo].vw_fee_list_details fld
) AS PivotExample;
SELECT @AllColumns= COALESCE(@AllColumns + ',','') + QUOTENAME([fee_name])
FROM (
SELECT DISTINCT [fee_type_name] FROM [dbo].vw_fee_list_details fld WHERE fee_type = 1 and
fld.appref_id like concat(@appRefId,'%') AND
fld.e_number like concat(@eNumber,'%') AND
fld.service_center like concat(@vscName,'%') AND
CAST(fld.transaction_date AS DATE) >= @startDate AND
CAST(fld.transaction_date AS DATE) <= @endDate
) AS PivotExample
SET @SQLQuery =
N'SELECT
ROW_NUMBER() over (Order by feeTable.appointment_number, feeTable.applicant_name, feeTable.transaction_date) [S.No],
FORMAT(feeTable.transaction_date,''dd-MMM-yy'') as [Transaction Date],
feeTable.transaction_time as [Transaction Time],
feeTable.appointment_number as [Appointment Reference],
feeTable.applicant_name as [Applicant Name],
+@AllSumColumns+'
FROM(
SELECT * FROM(
SELECT * FROM vw_fee_list_details fld
WHERE
fld.appointment_number like '''+@appRefId+'%'+''' AND '+
'fld.e_number like '''+@eNumber+'%'+'''
) a
PIVOT (
sum(amount)
FOR [fee_name]
IN('+@AllColumns+')) AS PivotTable) AS feeTable
GROUP BY feeTable.appointment_number, feeTable.applicant_name, feeTable.transaction_date,feeTable.transaction_time'
EXEC sp_executesql @SQLQuery;
最佳答案
一个建议 - 如果您在问题中添加表格定义和数据,人们将更容易重现您的案例并为您提供帮助。像下面这样:
DROP TABLE IF EXISTS #appointments;
DROP TABLE IF EXISTS #payments;
DROP TABLE IF EXISTS #tax_details;
CREATE TABLE #appointments
(
[id] INT PRIMARY KEY
,[appointment_number] VARCHAR(12)
,[applicant_name] VARCHAR(32)
,[appointment_date] DATE
,[appointment_time] TIME
);
CREATE TABLE #payments
(
[id] INT PRIMARY KEY
,[appointment_id] INT
,[fee_Type_name] VARCHAR(32)
,[amount] MONEY
);
CREATE TABLE #tax_details
(
[id] INT PRIMARY KEY
,[payment_id] INT
,[tax_name] VARCHAR(8)
,[tax_percentage] DECIMAL(9,2)
,[amount] MONEY
);
INSERT INTO #appointments ([id], [appointment_number], [applicant_name], [appointment_date], [appointment_time])
VALUES (1, 'APP001', 'Anuj Tyagi', '2022-12-28', '11:00 AM')
,(2, 'APP002', 'Puneet Pathak', '2022-12-28', '11:30 AM')
,(3, 'APP003', 'Rajeev Kumar', '2022-12-28', '10:00 AM');
INSERT INTO #payments ([id], [appointment_id], [fee_Type_name], [amount])
VALUES (1, 1, 'Consulatncy' ,500)
,(2, 1, 'Service Fee' ,100)
,(3, 1, 'Pharmacy' ,435)
,(4, 2, 'Consulatncy' ,800)
,(5, 2, 'Service Fee' ,160)
,(6, 2, 'Pharmacy' ,833)
,(7, 3, 'Consulatncy' ,500)
,(8, 3, 'Service Fee' ,100);
INSERT INTO #tax_details ([id], [payment_id], [tax_name], [tax_percentage], [amount])
VALUES (1 , 1, 'CGST', 5.00 , 25.00)
,(2 , 1, 'SGST', 2.50 , 12.50)
,(3 , 2, 'CGST', 8.00 , 8.00)
,(4 , 2, 'SGST', 4.00 , 4.00)
,(5 , 3, 'CGST', 10.00, 43.50)
,(6 , 3, 'SGST', 8.00 , 34.80)
,(7 , 4, 'CGST', 5.00 , 40.00)
,(8 , 4, 'SGST', 2.50 , 20.00)
,(9 , 5, 'CGST', 8.00 , 12.80)
,(10, 5, 'SGST', 4.00 , 6.40)
,(11, 6, 'CGST', 10.00, 83.30)
,(12, 6, 'SGST', 8.00 , 66.64)
,(13, 7, 'CGST', 5.00 , 25.00)
,(14, 7, 'SGST', 2.50 , 12.50)
,(15, 8, 'CGST', 8.00 , 8.00)
,(16, 8, 'SGST', 4.00 , 4.00);
那么,如果有些东西很难写成动态的T-SQL,最好先写成静态的,像这样:
SELECT PVT.[id]
,PVT.[appointment_number]
,PVT.[applicant_name]
,PVT.[appointment_date]
,PVT.[appointment_time]
,ISNULL(MAX(PVT.[Consulatncy]), 0) AS [Consulatncy]
,ISNULL(MAX(IIF(PVT.[Consulatncy] IS NOT NULL AND T.[tax_name] = 'CGST', T.[amount], NULL)), 0) AS [CGST]
,ISNULL(MAX(IIF(PVT.[Consulatncy] IS NOT NULL AND T.[tax_name] = 'SGST', T.[amount], NULL)), 0) AS [SGST]
,ISNULL(MAX(PVT.[Service Fee]), 0) AS [Service Fee]
,ISNULL(MAX(IIF(PVT.[Service Fee] IS NOT NULL AND T.[tax_name] = 'CGST', T.[amount], NULL)), 0) AS [CGST]
,ISNULL(MAX(IIF(PVT.[Service Fee] IS NOT NULL AND T.[tax_name] = 'SGST', T.[amount], NULL)), 0) AS [SGST]
,ISNULL(MAX(PVT.[Pharmacy]), 0) AS [Pharmacy]
,ISNULL(MAX(IIF(PVT.[Pharmacy] IS NOT NULL AND T.[tax_name] = 'CGST', T.[amount], NULL)), 0) AS [CGST]
,ISNULL(MAX(IIF(PVT.[Pharmacy] IS NOT NULL AND T.[tax_name] = 'SGST', T.[amount], NULL)), 0) AS [SGST]
FROM
(
SELECT A.[id]
,A.[appointment_number]
,A.[applicant_name]
,A.[appointment_date]
,A.[appointment_time]
,P.[id] AS [payment_id]
,P.[fee_Type_name]
,P.[amount]
FROM #appointments A
INNER JOIN #payments P
ON A.[id] = P.[appointment_id]
) DS
PIVOT
(
MAX([amount]) FOR [fee_Type_name] IN ([Consulatncy], [Service Fee], [Pharmacy])
) PVT
INNER JOIN #tax_details T
ON PVT.[payment_id] = T.[payment_id]
GROUP BY PVT.[id]
,PVT.[appointment_number]
,PVT.[applicant_name]
,PVT.[appointment_date]
,PVT.[appointment_time];
这是解决问题的一种变体,给我们:
不是,上面的query有两个动态部分,可以这样计算:
DECLARE @DynamicTSQLStatement NVARCHAR(MAX)
,@DynamicPVTColumns VARCHAR(MAX)
,@DynamicSELECTColumns VARCHAR(MAX);
SELECT @DynamicPVTColumns = STRING_AGG(QUOTENAME([fee_Type_name]), ', ')
FROM
(
SELECT DISTINCT [fee_Type_name]
FROM #payments
) DS;
SELECT @DynamicSELECTColumns = STRING_AGG(CAST(IIF([tax_name] IS NOT NULL, 'ISNULL(MAX(PVT.[' + [fee_Type_name] + ']), 0) AS [' + [fee_Type_name] + ']', 'ISNULL(MAX(IIF(PVT.[' + [fee_Type_name] + '] IS NOT NULL AND T.[tax_name] = ''' + [tax_name] + ''', T.[amount], NULL)), 0) AS [' + [tax_name] + ']') AS VARCHAR(MAX)), ',') WITHIN GROUP (ORDER BY [ColumnID])
FROM
(
SELECT ROW_NUMBER() OVER (ORDER BY [fee_Type_name], [tax_name]) AS [ColumnID]
,[fee_Type_name]
,[tax_name]
FROM
(
SELECT DISTINCT P.[fee_Type_name]
,T.[tax_name]
FROM #payments P
INNER JOIN #tax_details T
ON p.[id] = T.[payment_id]
UNION ALL
SELECT DISTINCT [fee_Type_name]
,NULL
FROM #payments
) DS ([fee_Type_name], [tax_name])
) DS
SET @DynamicTSQLStatement = N'
SELECT PVT.[id]
,PVT.[appointment_number]
,PVT.[applicant_name]
,PVT.[appointment_date]
,PVT.[appointment_time]
,' + @DynamicSELECTColumns + '
FROM
(
SELECT A.[id]
,A.[appointment_number]
,A.[applicant_name]
,A.[appointment_date]
,A.[appointment_time]
,P.[id] AS [payment_id]
,P.[fee_Type_name]
,P.[amount]
FROM #appointments A
INNER JOIN #payments P
ON A.[id] = P.[appointment_id]
) DS
PIVOT
(
MAX([amount]) FOR [fee_Type_name] IN (' + @DynamicPVTColumns + ')
) PVT
INNER JOIN #tax_details T
ON PVT.[payment_id] = T.[payment_id]
GROUP BY PVT.[id]
,PVT.[appointment_number]
,PVT.[applicant_name]
,PVT.[appointment_date]
,PVT.[appointment_time];
';
EXEC sp_executesql @DynamicTSQLStatement;
这给了我们:
请注意,我按名称订购了 fee_Type_name
和 tax_name
。如果您想以预定义的方式对它们进行排序,则需要在单独的表中指定(可能)。
关于sql - 使用多个表生成将行转换为列的报告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74872042/
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!