- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
起初我的问题可能看起来很简单并且之前已经被问过。请耐心等待 - 我认为这是一个独特的问题。
表 A 有列 State
, County
, Month
, Year
, 和 Rate
.每个州、县的复合 Material 都以不同的日期和比率多次列出。有些行设置了州和县,该行中的其他所有内容均为 NULL。
表 B 有每个月和每年的违约率。列是 Month
, Year
, 和 Rate
.在这张表中,我有几年的默认数据。
因此,对于表 A 中的每个州、县组合,我想用表 B 中的数据填充任何缺失的数据。
我创建了一个看起来像表 A 的表 C,除了所有数据都用表 B 中的默认数据填充。然后我尝试将表 A 和表 C 联合在一起。但我最终遇到了两个问题。
首先,我最终得到了重复的行,除了比率之外,其他所有内容都相同。在这种情况下,我只想保留最初在表 A 中的行(而不是“默认率”)。
其次,我以设置了州和县但其他所有内容均为 NULL 的行结束。我需要将这些行替换为每个违约率的行。
所以最后我想为每个 State,County,Month,Year 组合各占一行。
是否可以按照我所描述的那样组合表格。
如果您需要任何澄清,请告诉我。谢谢。
表 A 有几千行。每个州、县组合的 1 到 48 行:
+-------+--------+-------+------+------+| State | County | Month | Year | Rate |+-------+--------+-------+------+------+| NY | Albany | 1 | 2011 | ### || NY | Albany | 2 | 2011 | ### |...| NY | Albany | 12 | 2011 | ### || NY | Albany | 1 | 2012 | ### |...| NY | Albany | 12 | 2012 | ### || NY | Monroe | 1 | 2011 | ### |...| NY | Monroe | 12 | 2011 | ### || NY | Essex | NULL | NULL | NULL |+-------+--------+-------+------+------+
表 B 有 36 行。 3 年内每个月一行:
+-------+------+------+| Month | Year | Rate |+-------+------+------+| 1 | 2011 | *** || 2 | 2011 | *** || ... | | || 12 | 2011 | *** || 1 | 2012 | *** || ... | | || 12 | 2012 | *** || 1 | 2013 | *** || ... | | || 12 | 2013 | *** |+-------+------+------+
结果表的行数比表 A 多。每个 State,County 组合至少有默认表中的 36 行:
+-------+--------+-------+------+------+| State | County | Month | Year | Rate |+-------+--------+-------+------+------+| NY | Albany | 1 | 2011 | ### || ... | | | | || NY | Albany | 12 | 2011 | ### || NY | Albany | 1 | 2012 | ### || ... | | | | || NY | Albany | 12 | 2012 | ### || NY | Albany | 1 | 2013 | *** || ... | | | | || NY | Albany | 12 | 2013 | *** || NY | Monroe | 1 | 2011 | ### || ... | | | | || NY | Monroe | 12 | 2011 | ### || NY | Monroe | 1 | 2012 | *** || ... | | | | || NY | Monroe | 12 | 2012 | *** || NY | Monroe | 1 | 2013 | *** || ... | | | | || NY | Monroe | 12 | 2013 | *** || NY | Essex | 1 | 2011 | *** || ... | | | | || NY | Essex | 12 | 2011 | *** || NY | Essex | 1 | 2012 | *** || ... | | | | || NY | Essex | 12 | 2012 | *** || NY | Essex | 1 | 2013 | *** || ... | | | | || NY | Essex | 12 | 2013 | *** |+-------+--------+-------+------+------+
key :***
是默认表中的比率。 ###
是另一个表的费率
最佳答案
我认为最好的方法是生成地理和时间的所有组合。您可以通过从 tablea
中获取 state
和 county
并与 year
和 交叉连接来做到这一点来自
。然后用tableb
的月份left join
查看tablea
有没有值。如果是这样,请选择它。否则,从 tableb
中取值:
select sc.state, sc.county, ym.year, ym.month, coalesce(a.rate, ym.rate) as rate
from (select distinct state, county from tablea) sc cross join
tableb ym left outer join
tablea a
on a.state = sc.state and a.county = sc.county and
a.year = ym.year and a.month = ym.month ;
+7 个字符
关于mysql - 填充表格中缺失的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25297594/
我编写了一个 Android 应用程序,它使用 Azure 来执行用户通过 Google、Twitter 和 Facebook 的登录;它使用 Microsoft.WindowsAzure.Mobil
我想将 AdomdClient 引用添加到 C# 项目,但它不在引用列表中。客户端列在程序集文件夹 C:\Windows\Assembly 中。 计算机上安装了 SQL Server 2012。 最佳
我正在学习“绘图应用程序”的教程。当我在 Firefox 上启动我的应用程序时,Firebug 告诉我“在语句之前缺少 ;” 我在第 9 行调用函数的位置。我只是不明白应该将这些“;”放在哪里. va
我想将 AdomdClient 引用添加到 C# 项目,但它不在引用列表中。客户端列在程序集文件夹 C:\Windows\Assembly 中。 计算机上安装了 SQL Server 2012。 最佳
我在 Firebug 中不断收到关于 onClick 事件的错误。 我已经尝试了 "和 ' 的各种不同组合,但无济于事。在添加 onClick 事件之前,这工作正常。 有人能发现我可能做错了什么吗?
Visual Studio 2015 告诉我找不到 WSASetSocketSecurity。 该 dll 存在并且还包括似乎没问题。 我的包括: windows.h stdio.h Wincrypt
我需要访问 eloquent 的 whereHasNot方法(此处添加: https://github.com/laravel/framework/commit/8f0cb08d8ebd157cbfe
跟随宠物物体检测的 TF 教程:https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/run
构建路径 > 添加库 > JUnit 无法添加 JUnit3 或 JUnit4 组件。 我在.log 中看到这样的消息 !MESSAGE No property tester contributes
我正在运行此脚本来查看网络上的摄像机: gst-launch udpsrc port=1234 ! "application/x-rtp, payload=127" ! rtph264depay !
我正在使用http://java.sun.com/jsp/jstl/fmt用于从 Spring 配置中设置的 Message Resource Bundle 输出消息的标签库。消息解析也可以放在 Co
我正在将 Ninject 与 MVC4 连接起来,并让它工作到尝试实际解决依赖关系的程度。但是,我收到以下异常: Method not found: 'System.Web.Http.Services
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我在启动 ASP.NET MVC5 应用程序时遇到问题。到目前为止一切正常。启动应用程序时出现以下错误: Could not load file or assembly 'Microsoft.Appl
我已经使用以下方法创建了一个环境: conda create --prefix C:\Users\Dell\Dropbox\DjangoProjects\webenv python=3.6 执行后:c
我们有一个遗留的 Web 窗体应用程序,我们最近将其从网站项目转换为 Web 应用程序项目。 Web 窗体项目是解决方案的“启动”项目。 有一个 MVC 项目是对 Web 窗体项目的引用。 在 MVC
使用某种字体,我使用Java的FontLayout来确定它的上升、下降和行距。 (参见 Java 的 FontLayout 教程 here) 在我的具体案例中,我使用的是 Arial Unicode
我正在尝试在 linux 下编译 qt ffmpeg 包装器简单编码/解码示例 QTFFmpegWrapper source # Set list of required FFmpeg librari
我正在使用来自开发人员 android 页面的 SlidingTabLayout.java。在我使用 slidingTabLayout.setDistributeEvenly(true); 使 sli
我正在尝试使用 v360 filter 将 180° 鱼眼视频转换为普通/常规视频的 FFmpeg . 这是我尝试过的命令:ffmpeg -i in.mp4 -vf "v360=input=fishe
我是一名优秀的程序员,十分优秀!