- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
第一次发帖,希望得到一些帮助。
极少的编码经验,所以行话可能会造成混淆。
我正在尝试在 Zoho 中使用 SQL 来清理数据。
数据包括A) 每份保单的交易数据(保费、费用、净收入)B) 理赔数据(发生金额)
问题与唯一标识符有关 - 同一客户可能有多个保单编号,其中 A) 或 B) 未存储在一起。我一直在使用的是系统自己的客户端代码(不同于保单编号),它将所有保单编号存储在同一客户端下。第二个问题是 claim 数据未映射到此“客户端代码”。 Excel 索引/匹配/vlookup 一直是我的首选,并且运行良好,但是我们正在转向通过 SQL 运行的 Zoho。
例如
| Client Code | Policy Number | Premium | Claims |
| -------- | -------------- | -------- | ------ |
| C1 | 123 | 500 | 300 |
| C2 | 456 | 100 | |
| C1 | 767 | 0 | | <---
| | 767 | | 800 | <--- want these columns put all under C1
问题:如何使用 SQL 将左下角的空白填入 C1,然后将每个客户(C1 和 C2)的总保费和理赔金额分组?
目标:
| Client Code | Premium | Claims |
| -------- | --------- | ------ |
| C1 | 500 | 1100 |
| C2 | 100 | |
我想过使用 Self Join -
SELECT
t1."Client Code",
t1."Policy Number",
t1."Premium",
t1."Claims",
t2."Client Code"
FROM table1 as t1
FULL OUTER JOIN
(SELECT
"Policy Number",
"Client Code"
FROM table1) t2
ON t1."Policy Number" = t2."Policy Number"
这显然行不通,更不用说当我尝试按保费计算总和时,我开始收到按子句分组的错误消息。
如有任何帮助,我们将不胜感激。
结果:
我排除的其他要考虑的因素:保单年份、由于每月/每年付款等导致的更多交易数据行。
最佳答案
如果您有一个唯一的标识符,那就告诉我您想要一个 INNER 连接。查看内部连接与外部连接的维恩图。内部连接只会让你有交集,所以没有空白。左外连接或右外连接将在一个中显示值,在另一个中显示可能的空白。您可能不需要完整的其他加入。我很少遇到这种情况。
关于聚合或分组。您需要 GROUP BY 和 SUM。通过按客户端代码分组,该字段将变得唯一。
在这种情况下,您只有一个包含所有数据的表,因此不需要看到对表 1 本身进行联接的必要性。哦,我看到一个问题,即针对同一保单的多项 claim 将使保费费用出现多次,然后将其加起来不正确。
我将把保单编号从这里省略,因为您的理想表格确实使用它并且希望跨保单而不是保单的总计。
把它们放在一起。
首先,忽略溢价。不要一次做太多。建立起来。
SELECT
"Client Code",
SUM("Claims") AS `Total Claims`
FROM table1
GROUP BY "Client Code"
Client code Total claims
C1 800
C2 0
现在只处理溢价。我假设保费将固定为保单编号(也许不是?)但是同一客户的多个保单可能恰好具有相同的保费。我不知道你如何随着时间的推移增加保费......?您必须根据业务逻辑来解决这个问题。
SELECT DISTINCT
"Client Code",
"Policy Number",
"Premium"
FROM table1
结果将是唯一的行。客户 ID 将重复,但如果保持保费值(value)不变,保单编号应该是唯一的。
然后您添加聚合以获得客户跨保单的总保费。但我们会把它留到下面。
然后将这两个表连接在一起以处理 claim 和保费。
SELECT
table1."Client Code",
SUM(table1.Claims) AS `Total Claims`,
SUM(Policy.Premium) AS `Total Premiums`
FROM table1
INNER JOIN (
SELECT DISTINCT
"Client Code",
"Policy Number",
Premium
FROM table1
) AS Policy ON Policy."Client Code" = table1."Client Code"
GROUP BY "Client Code"
如果您想查看基础数据以了解联接是否有意义,那么您可以删除 SUM 和 SUM 并删除 GROUP BY 行。
您的表和字段的命名也很笨拙。 table1 和 t1 和 t2 是模糊的。您所有的数据都来自 table1,这不利于建模。您宁愿需要一个包含客户及其代码的表,而其他表通过行 ID(如“1”或“789”)引用客户。
而且您到处都需要现场引用。
更好的结构应该是这样的。也许是 claim 表(基于事件)和政策(基于契约(Contract))。
client.code
policy.client_id
policy.policy_number
policy.premium_value
claim.value
claim.policy_id
也许 Zoho 不允许您这样改造。希望你能做到。
关于填充唯一标识符空白行的SQL方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66595150/
C++ Primer 说: The identifier we define in our programs may not contain 2 consecutive underscores, no
标识符术语在文档 alongside constants 中定义。 , 使用几乎相同的用例,尽管术语在运行时计算它们的值,而常量在编译时得到它。潜在地,这可能会使术语使用全局变量,但这是一个遥远而丑陋
我想知道,.Net 标识符中接受哪些字符? 不是 C# 或 VB.Net,而是 CLR。 我问这个的原因是我正在查看 yield return 语句是如何实现的 (C# In Depth),并看到
在PowerShell中,当我专门使用Active Directory时,通常会编译一个包含一组人群列表的对象,通常使用$x = get-adgroup -filter {name -like "*"
使用 hibernate 时: 我必须为每个实体指定一个 ID 或复合 ID,如果我想使用没有任何主键且没有复合键的表怎么办... 提前致谢 最佳答案 没有键的表不是一个好的关系模型。我不会推荐它。
所以我有一些代码正在尝试编译,但我不断收到此错误: 3SATSolver.java:3: expected 这是代码。我只是没有看到什么吗? import java.util.ArrayList;
我正在寻找有关 C 标准(C99 和/或 C11)部分内容的一些说明,主要是关于标识符的使用。 上下文是一个完整的C99标准库的实现,我希望它完全符合标准。 基本问题是:C 标准允许我在多大程度上声明
我有这个 Shader.h 文件,我正在用这段代码制作它: #include #include #include #include in vec2 TexCoords; out vec4 co
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
这是我的代码: #include "stdafx.h" #include #include #include #include using namespace std; int _tmain(
pthread_create() 的第一个参数是一个thread 对象,用于标识新创建的线程。但是,我不确定我是否完全理解其中的含义。 例如,我正在编写一个简单的聊天服务器并且我计划使用线程。线程会随
我想从我的标识符中获得匹配项。 我在 {/describe:foo} 中有一个这样的字符串,我正在尝试匹配 {/describe:} 以返回 foo,但我没有得到正确的正则表达式,会有人介意指出我做错
我遇到了一个奇怪的问题,我似乎找不到答案,但我想我不妨问问。 我有一个执行碰撞检查的抽象类,它有一个“更新”函数,以及“updateX”和“updateY”函数。 class MapCollidabl
我正在尝试创建一个程序来将所有文件从一个目录复制到另一个目录。但我遇到了一个基本问题。它说当我尝试在第 52 行编译时需要标识符。 public bool RecursiveCopy() {
1>cb.c(51): error C2061: syntax error : identifier 'SaveConfiguration' 1>cb.c(51): error C2059: synt
我刚刚发现命名变量 arguments 是个坏主意。 var arguments = 5; (function () { console.log(arguments); })(); Outpu
我们对我们的网站进行了安全测试,并发现了一个漏洞。 问题 If the session identifier were known by an attacker who had access to t
为了估计程序在一次内核启动中可以处理多少数据,我尝试使用 cudaMemGetInfo() 获取一些内存信息。但是,编译器告诉我: 错误:标识符“cudaMemGetInfo”未定义 cudaGetD
我发现我需要使用 xpath 查询来定位几乎是 regexp 类型的字符串,但无法看到如何管理它。我正在使用的当前查询是: $result = $xpath->query('//ul/li[sta
我正在创建我的学生计划表的虚拟版本,它基本上可以让你记下你有哪些科目的作业。 这是界面: 用户从组合框中选择主题,并在相邻的备忘录中输入一些注释。完成后,他们将单击“保存”按钮,将其保存到 .ini
我是一名优秀的程序员,十分优秀!