- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
希望这没有我想象的那么复杂。
我有一个公司表,另一个工作表,第三个表包含每个公司每个工作中每个员工的单个条目。 注意:有些公司不会在某些职位上雇用员工,而有些公司在某些职位上会有不止一名员工。
公司表有一个companyid
和companyname
字段,job表有一个jobid
和jobtitle
字段,员工表有employeeid
、companyid
、jobid
和employeename
字段。
我想建一个这样的表:
+-----------+-----------+-----------+ | Company A | Company B | Company C |------+-----------+-----------+-----------+Job A | Emp 1 | Emp 2 | |------+-----------+-----------+-----------+Job B | Emp 3 | | Emp 4 | | | | Emp 5 |------+-----------+-----------+-----------+Job C | | Emp 6 | | | | Emp 7 | | | | Emp 8 | |------+-----------+-----------+-----------+
我之前一直在遍历工作的结果集,对于每份工作,循环遍历每家公司的结果集,对于每家公司,循环遍历每个员工并将其打印在表格中(总的来说,但绩效是不应该是一个考虑因素)。该应用程序越来越受欢迎,现在我们有 100 家公司和数百个工作岗位,服务器正在崩溃(所有 id 字段都已编入索引)。
关于如何编写单个查询来获取这些数据有什么建议吗?我不需要公司名称或职位(显然),但我确实需要一些方法来确定结果中每一行的打印位置。我想象一个结果集只包含一长串已加入的员工,我可以编写一个循环来使用 companyid
和 employeeid
值来告诉我何时创建新的单元格或表格行。只要没有零员工,这就有效;我认为我需要一个 NULL 员工姓名吗?我完全走错路了吗?
提前感谢您的任何想法!
最佳答案
技巧并不在于查询(类似于
SELECT jobtitle, companyname, employeename
FROM employee AS e
RIGHT JOIN company AS c ON e.companyid = c.companyid
RIGHT JOIN job AS j ON e.jobid = j.jobid
WHERE ...
ORDER BY j.jobtitle, c.companyname
) 作为处理结果的方式。对于每个结果行,当公司发生变化时开始一个新的表格单元格,当职位发生变化时开始一个新的表格行。最棘手的部分是确定何时需要输出结束标记。
关于MySQL 大师 : How to pull a complex grid of data from MySQL database with one query?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2614969/
我有一个使用 c++ 的大型代码库标题和许多std::complex对象。但现在我还想使用其他几个使用 fftw 的库( spinsfast 和 ) .不幸的是,混合这两种类型的复合体似乎与 gc
我是 Maxima 的新手,在文档中找不到如何对复数进行正式计算。当我使用未指定的变量时,Maxima 似乎假设它们是真实的: 例如,共轭(x)返回 x。 有没有办法解决这个问题? 提前致谢。 最佳答
我是学习大O表示法的新手,并想到了这个问题。复杂度 O(a * b) 的名称是什么?是线性复杂度吗?多项式?或者是其他东西。实现代码如下。 function twoInputsMult(a, b) {
我是学习大O表示法的新手,并想到了这个问题。复杂度 O(a * b) 的名称是什么?是线性复杂度吗?多项式?或者是其他东西。实现代码如下。 function twoInputsMult(a, b) {
这是我的 Complex 类,我重载了“+” class Complex(object): def __init__(self, real, imag): self.__ima
我正在使用 R5RS 标准的 Scheme 实现。 现在假设您必须找出一个元素 '(2 3 4) 是否在列表 '(1 2 3 4) 中。 至于示例,更严格地说,您希望: 1. (is-in? '(2
注意事项: 我正在使用 Apple LLVM 版本 6.0 (clang-600.0.56)(基于 LLVM 3.5svn)在 OSX 上编译 具体来说,我正在尝试从 LibIIR 编译一个整体源,这
这段fortran代码最初是用Fortran 77格式编写的(我稍后会展示它)。拿到后,我通过转换工具将其转换为f90免费格式。使用intel fortran编译器 ifort,编译和运行和以前一样好
我有一个实现用户定义的算术类型的MyType类。此类提供以下转换运算符 struct MyType { ... operator double() { return to_double
我目前正在使用 Cxx 来允许 Julia 代码与 C++ 库交互。我想做的一部分是在两个方向上有效地传递复杂数据的集合(通常是 vector )。也就是说,我想要以下内容: cv = [1 + 2i
假设我有一个名为“汽车”的实体。 我使用复杂类型来定义“引擎”部分。 [TableName("T_CAR")] public sealed class Car:IEngine { ... pu
我想使用 static_cast 将 complex 转换为 complex 。 Convert complex to complex 我正在尝试做与这篇文章相同的事情,但我需要使用 static_c
` ?
对于多项式方程求解器,最好将其模板化为任何可用类型: template class PolynomialEquation { public: private: array myEquatio
为了在 cython 中将实部与复部分开,我通常使用 complex.real 和 complex.imag 来完成这项工作。然而,这确实会在 html 输出中生成颜色为“python red”的代码
我的问题很简单: Are both "complex float" and "float complex" valid C? 两者似乎都被 gcc 接受而没有警告。 最佳答案 complex 是 co
以下声明有什么区别? 结构体 *ptr1=(结构体*)malloc(4*sizeof(结构体)); 结构体 (*ptr1)[4]=(结构体*)malloc(sizeof(结构体)); 哪个更好用? 最
我想创建一个 C++ 类的复数。这里是Complex.h(最基本的形式) #ifndef _COMPLEX #define _COMPLEX #include "TVector2.h" class C
我已经使用 Visual Studio 2012 和 NDepend 对我的解决方案进行了代码分析 对于方法 MethodA,Visual Studio 显示复杂度为 105,Ndepend 显示为
我的代码: #include using std::cin; using std::cout; using std::istream; using std::ostream; template cl
我在 swift3 中有以下代码,我正在使用 swift lint 对代码进行 linting。给出代码如下: func selectedMenuInLoggedOutState(sender
我是一名优秀的程序员,十分优秀!