如果满足某些条件,则从行中获取信息

Posted

技术标签:

【中文标题】如果满足某些条件,则从行中获取信息【英文标题】:Obtain information from a row if it meets certain criteria 【发布时间】:2013-09-05 13:19:33 【问题描述】:

好的,所以问题的总体范围是我正在使用表值函数,因此 s-s-rS 可以根据数据创建各种报告,然后我使用另一个程序将所有这些报告拼接在一起。所以无论如何,问题是如果该行中的另一列包含某个值,我需要获取该列的值。然后在将该值添加到另一个地方后,将一个新值放回数据库行的列中,以便其他报告和使用该数据。比如:

RETURNS @ReportTable table
(
str_beta_group varchar(64) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
str_alpha_group varchar(64) COLLATE SQL_Latin1_General_CP1_CI_AS NULL, 
str_group varchar(64) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
debit decimal(24, 6) NULL, 
credit decimal(24, 6) NULL,
    credit_total decimal(24,6) NULL

)

我是数据库开发的新手,我尝试了各种方法,但无法弄清楚如何使语法正确,并且总是以错误告终。那么根据上表,我将如何用 T-Sql 语法编写这个逻辑:

 decimal epsilon_temp, gamma_temp;
  if(str_group='epsilon')
 
epsilon_temp = credit; --the credit from that row where str_group = epsilon 
 
 else if(str_group='gamma')
 
gamma_temp = credit; --the credit from that row where str_group = gamma
 
 --Then after that UPDATE
 UPDATE @ReportTable
SET credit_total = SUM(epsilon_temp + gamma_temp )
WHERE str_group = epsilon

【问题讨论】:

【参考方案1】:

我正在猜测您需要什么。这是关于如何从数据中获取总和并按 str_group 对结果进行分组吗?这看起来如何:

SELECT
  CASE WHEN str_group is NULL THEN 'TOTAL' ELSE str_group END str_group
  SUM(credit) credit
FROM 
  table
GROUP BY GROUPING SETS 
  ((),(str_group))

【讨论】:

感谢您的回答。然而,这并不是我真正想要的。我想也许我解释得有点麻烦。所以我现在会尝试更好地解释它。上表中的一行将有 str_beta_group、str_alpha_group、str_group、debit、credit 和 credit_total 的列...抱歉不小心按了 enter development..

以上是关于如果满足某些条件,则从行中获取信息的主要内容,如果未能解决你的问题,请参考以下文章

DataTable 从行中获取修改后的数据

双击后获取行信息

熊猫将非空值从行中获取到一个单元格中[重复]

python如何从行中提取符合的信息,正则表达式

Pandas 用 NaN 值填充列中的单元格,从行中的其他单元格中获取值

如果某些陈述为真,则从列表中删除对象[重复]