如何从 SQL Server 查询数据?
Posted
技术标签:
【中文标题】如何从 SQL Server 查询数据?【英文标题】:How to Query Data From SQL Server? 【发布时间】:2012-12-12 03:55:34 【问题描述】:我在从数据库中查询数据以在 VB.NET 中生成报告时遇到问题。我使用业务对象来做报告。这是我的示例数据:
___________________________________________________________________________
| | | | | | |
| Id | Item | Unit | Unit Price | Quantity | Amount |
|____|_______________|__________|_____________|___________|_______________|
| 1 | Gasoline | L | $ 2.00 | 10 | $ 20.00 |
| 1 | Gasoline | L | $ 2.50 | 20 | $ 50.00 |
| 2 | Water | Bottle | $ 5.00 | 10 | $ 50.00 |
| 3 | Meat | Kg | $ 14.90 | 15 | $ 223.50 |
| 1 | Gasoline | L | $ 8.00 | 50 | $ 400.00 |
| 4 | Milk | Can | $ 7.45 | 30 | $ 223.50 |
| 1 | Gasoline | L | $ 6.99 | 10 | $ 69.90 |
|____|_______________|__________|_____________|___________|_______________|
在报告中,我想查看“Id”、“Item”、“Unit”、“Unit Price”(是的,如果它们具有不同的值,我将显示“Undefined”)、“Quantity "(同一项目的总和)和“金额”(同一项目的总和)。但是我试了几次,结果是错误的。如果它们的“单价”根本不是相同的价格,如何计算所有相同项目的“金额”。这是我的预期结果:
___________________________________________________________________________
| | | | | | |
| Id | Item | Unit | Unit Price | Quantity | Amount |
|____|_______________|__________|_____________|___________|_______________|
| 1 | Gasoline | L | Undefined | 90 | $ 539.90 |
| 2 | Water | Bottle | $ 5.00 | 10 | $ 50.00 |
| 3 | Meat | Kg | $ 14.90 | 15 | $ 223.50 |
| 4 | Milk | Can | $ 7.45 | 30 | $ 223.50 |
|____|_______________|__________|_____________|___________|_______________|
请帮帮我....
【问题讨论】:
你能显示你正在使用的代码不起作用吗?看起来Amount
只是Unit Price * Quantity
。这可以在数据库视图、SQL 语句、业务对象、UI 视图等中完成。
你能告诉我们你的预期输出吗?
@kimleng 如果您有两个来自具有相同unit_price
的项目的条目怎么办?我相信您想在这种情况下显示正确的 unit_price ;)
【参考方案1】:
如果我理解正确,这应该可以满足您的要求:
SELECT A.Id,
A.Item,
A.Unit,
CASE WHEN B.Id IS NOT NULL THEN 'Undefined' ELSE [Unit Price] END [Unit Price],
A.Quantity,
A.Amount
FROM ( SELECT Id, Item, Unit,
CAST(MIN([Unit Price]) AS VARCHAR(20)) [Unit Price],
SUM(Quantity) Quantity, SUM(Amount) Amount
FROM YourTable
GROUP BY Id, Item, Unit) A
LEFT JOIN ( SELECT Id
FROM YourTable
GROUP BY Id
HAVING COUNT(DISTINCT [Unit Price]) > 1) B
ON A.Id = B.Id
添加了sql fiddle 供您试用。 (感谢@bonCodigo,因为我的小提琴基于他已经拥有的小提琴,但使用了我的代码)。
这是结果:
ID ITEM UNIT PRICE QUANTITY AMOUNT
1 Gasoline L Undefined 90 539.9
2 Water Bottle 5.00 20 99.9
3 Meat Kg 14.90 15 223.5
4 Milk Can 7.45 30 223.5
【讨论】:
+1 为答案。当一个项目有两个具有相同unit_price
的条目时,这是否支持?因为我只设法提供显示 undefined
的答案,如果一个项目有多个条目,无论 unit_price 相同还是不同:)
@bonCodigo 是的,它确实考虑到了这一点。这就是为什么在使用COUNT(DISTINCT
的派生表上有一个LEFT JOIN
,在SELECT
上有一个CASE
谢谢,顺便说一句,您可能需要在 group by
子句中包含 UNIT
;)我正准备通过编辑组将 SQLFIDDLe 添加到您的答案中:D
@bonCodigo 我添加了一个基于您拥有的 sqlfiddle,但如果您还想尝试结果,请使用我的代码。我已经在答案中添加了Unit
列,谢谢。
我想让你的答案漂亮所以我冒昧地用结果更新它大声笑:D欢呼。【参考方案2】:
请试试这个代码,
select Id, item, unit, sum(quantity) totoal_Qt ,
sum(amount) total_Px from td
group by id, item, unit
;
结果:
ID ITEM UNIT TOTOAL_QT TOTAL_PX
1 Gasoline L 90 539.9
2 Water Bottle 10 50
3 Meat Kg 15 223.5
4 Milk Can 30 223.5
SQLFIDDLE
使用 CASE 编辑
这是我能得到的最接近的。这是一个很好的问题。为此+1。所以这个编辑过的答案的缺陷是它会显示一个具有多个unit_prices
的项目“未定义”,但是即使一个项目的多重条目具有相同,它也不会显示unit_price unit_price
。答案是完整的ANSI
语法。
*SQLFIDDLE
更改了样本数据以测试各种场景。
ID ITEM UNIT UNIT_PRICE QUANTITY AMOUNT
1 Gasoline L 2 10 20
1 Gasoline L 2.5 20 50
2 Water Bottle 5 10 50
3 Meat Kg 14.9 15 223.5
1 Gasoline L 8 50 400
4 Milk Can 7.45 30 223.5
1 Gasoline L 6.99 10 69.9
2 Water Bottle 5 10 49.9
查询:
select distinct x.id, x.item, x.unit,
x.total_Qt, x.total_Amt,
case when x.unitPrice = 0
then 'Undefined'
else cast(y.unit_price as varchar(9))
end as UP
from(
select Id, item, unit, sum(quantity) total_Qt ,
sum(amount) total_Amt,
case when count(unit_price)>1
then 0
else 1
end unitPrice
from td
group by id, item, unit) as x
left join
(select distinct id, item, unit, unit_price
from td) as y
on x.id = y.id
and x.item = y.item
and x.unit = y.unit
;
结果:
ID ITEM UNIT TOTAL_QT TOTAL_AMT UP
1 Gasoline L 90 539.9 Undefined
2 Water Bottle 20 99.9 Undefined
3 Meat Kg 15 223.5 14.90
4 Milk Can 30 223.5 7.45
【讨论】:
@kimleng 这是个好问题。我已经更新了答案,以更接近您的需要。但它有一个缺陷。请阅读更新和评论。 :)以上是关于如何从 SQL Server 查询数据?的主要内容,如果未能解决你的问题,请参考以下文章
如何从 SQL Server 2014 中的 Select 查询中将数据分配给用户定义的表类型