- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个简单的数据库,它包含三个表(company
、phone
、email
),它们通过规则关联:
这是 MySQL 代码:Pastebin
假设有以下两种情况:
~
我想创建一个返回以下内容的 SELECT:
案例一
Company Phone E-mail
--------------------------------------------
Test Company 1111222 export@testco.co
Test Company 2222222 import@testco.co
Test Company 3333222
--------------------------------------------
案例二
Company Phone E-mail
--------------------------------------------
Test Company 1111222 export@testco.co
Test Company 2222222 import@testco.co
Test Company sales@testco.co
--------------------------------------------
对于给定的公司,SELECT 应该“知道”哪个实体具有更多元素(phone
或 email
),然后返回一个结果,其中数字行数等于具有更多元素的实体中的元素数(phone
在情况 1 中;email
在情况 2 中)。
我不知道该怎么做。这是我能做的最好的:Pastebin
最佳答案
这在 MySQL 中很难做到,但它是可能的。这是逻辑。枚举每个公司的电子邮件和电话的值。然后根据公司和序列号聚合这些:
select ep.company, min(ep.email) as email, min(ep.phone) as phone
from ((select e.company, e.email, NULL as phone,
(@rne := if(@company = company, @rne + 1, if(@company := company, 1, 1)) ) as seqnum
from email e cross join
(select @rne := 0, @company := '') vars
order by e.company
) union all
(select p.company, NULL, p.phone,
(@rnp := if(@companyp = company, @rnp + 1, if(@companyp := company, 1, 1)) ) as seqnum
from phone p cross join
(select @rnp := 0, @companyp := '') vars
order by p.company
)
) ep
group by ep.company, ep.seqnum
order b ep.company, ep.seqnum;
表达式:
(@rne := if(@company = company, @rne + 1, if(@company := company, 1, 1)) ) as seqnum
设置seqnum
是一种在MySQL 中安全使用变量的方法。请注意,MySQL 不保证 select 中表达式的求值顺序,因此更自然:
@rne := if(@company = company, @rne + 1, 1), @company := company
可能不起作用,因为第二个将首先被评估。这种带有嵌套赋值的方法没有这个问题。
关于mysql - 如何使 SELECT "knows"哪个实体具有更多元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24507901/
我正在使用 COM 库 RCWs 。我一直发现最好的做法是在所有非托管资源超出范围之前手动释放它们并进行垃圾收集。我不希望这“减慢”我的应用程序的速度,并且我不在乎这实际上何时完成(如果有的话)在应用
我认为作为一个挑战,我应该编写一个基于 javascript 的游戏。我想要声音、图像和输入。模拟屏幕的背景(例如 640x480,其中包含我的所有图像)对于将页面的其余部分与“游戏”分开非常有用。我
在抓取网站的单个页面时,我使用 Beautiful Soup 取得了巨大成功,但我有一个新项目,我必须在其中检查大量网站,看看它们是否包含指向我网站的提及或链接。因此,我需要检查每个站点的整个站点。
我期待构建一个高度依赖地理数据的应用程序。 该应用程序将使用 HTML5 获取 GPS 数据的能力,并将进行诸如寻找最近的街道、寻找两点之间的最短路径等计算。我正在考虑使用 Google map 等平
我在使用 liquibase 时遇到问题。当我运行我的 J2EE 应用程序时,liquibase 告诉我: liquibase.exception.ValidationFailedException:
我的 iphone 上有一个应用程序,它允许我也可以通过 ftp 从我的 linux 桌面传输歌曲。应用显示主机地址为192.168.0.4并且要使用的端口是5021 .我可以从 filezilla
回答者已经知道的东西,但无论如何在这里展示我的思考过程: 从 HLL 到机器代码,这里有一组粗略的发生的事件(有链接器和其他东西,但现在让我们忽略它): HLL --> 编译器 --> 汇编器 ---
显然,下面的函数是不可能的,因为不可能永久地解开一个 IO 值(忽略 unsafePerformIO 或类似的): unwrapIO :: IO String -> String unwrapIO (
我在测试机器上安装了 Java 版本 45。高安全性设置表示无法在旧版本的 Java 上运行未签名或自签名的应用程序,事实上它无法运行自签名的小程序。 这个版本如何能够检测到它是旧版本?首次部署时它肯
怎么可能跳过 SemaphoreCI 上的一些测试?换句话说,是否有可能知道我们何时对 Semaphore 运行特定测试? 最佳答案 SemaphoreCI 将 CI 环境变量设置为 true。 有关
我知道我可以使用 xcodebuild 启动应用程序的单元测试,但我想知道什么告诉应用程序在启动期间运行测试,它是发送给应用程序的特殊参数还是它为了运行测试(使用 XCTest)进行不同的编译? 最佳
我对 Joomla 相当陌生(我更喜欢使用 Wordpress),我有一个关于模块位置的问题。 模块可以知道它所处的位置吗?例如我可以做这样的事情: if(modulePosition =='left
我有一个简单的 Spring Boot 应用程序,它从 Kafka 读取并写入 Kafka。我写了一个 SpringBootTest使用 EmbeddedKafka测试这一切。 主要问题是:有时测试失
我想知道 R 对它运行的硬件/系统有什么了解。 例如,我知道使用“sessionInfo()”会发现一些事情。但是是否也可以检查计算机的 CPU/内存?是否可以为所使用的计算机设置一些唯一标识符? 动
我试图掌握 PHP 和 MYSQL 编程,但在看到示例后,我无法理解 mysql_fetch_row 如何知道要返回哪一行。例如: 在上面的代码中,echo $row[0]; 返回表中第一列的数据,
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我得到了一个 makefile,我将其修改为: ############################################ # Makefile using OCI (Oracle Ca
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 4 年前。 Improve this qu
相关:What does casting do at compiler/machine level? 假设我有自定义类型。 A 型是 B 型的子类型。 最初,我的变量类型为 A 类型。然后我将其转换为
想到这里有个奇怪的问题。例如,假设您在服务器上部署了执行以下操作的代码: //GET request called when a URL is hit public void gETCalled(){
我是一名优秀的程序员,十分优秀!