- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的数据库中有四个表:
Metrics
->id
->description
Agents
->id
->name
Forms
->id
->agent_id
->campaign_id
->calldatetime
->phone
Forms_Responses
->id
->form_id
->metrics_id
->response
其中一位用户要求我做一份这样的报告:
Metric ID | Agent_name | Agent_name | Agent_name .. and so on (depends how many from db)
__________|____________|____________|______________
| | |
1 | 90% | 80% | 70%
__________|____________|____________|_______________
2 | 80% | 100% | 50%
报告可以水平和垂直缩放。横向 Agent_ID
为了获得水平缩放(列),我有这个查询
SELECT a.id, b.name FROM forms a
INNER JOIN agents b ON a.agent_id = b.id
WHERE a.calldatetime >= '2015-12-12 00:00:00'
AND a.calldatetime <= '2015-12-17 23:00:37' AND campaign_id = 22 GROUP BY agent_id ORDER BY id ASC;
我有GROUP BY agent_id
所以不会有重复的数据。然而我的问题是在 ROWS
。到目前为止我已经
select form_id, metrics_id, response, remarks
from forms_responses
where form_id >= 6951 and form_id <= 6953 ORDER BY id ASC;
不要介意where form_id >= 6951 and form_id <= 6953
。那么这应该是我的行吗?问题是我如何将其链接到我的列中加上值 90%, 80%..
基于公式
Yes Counts / (Yes Counts + No Counts)
在 response
Forms_Responses
栏目 table 。
基本上,这是一个评分报告,它根据给定公式中的响应值获取每个代理在每个指标上的百分比。
我在 Laravel PHP 中执行此操作,并将以提到的格式输出为 excel,但我不知道我的查询会是什么样子或处理如何进行或可能吗?
最佳答案
您应该在 PHP 中进行交叉表,因为 MySql 不支持这种枢轴格式。
使用 SQL 查询,您的目标是输出如下内容:
metrics_id agent_name score
1 Chewbacca 1
1 Luke 0.5
1 Yoda 0
2 Chewbacca 1
2 Luke 1
2 Yoda 1
3 Chewbacca 1
3 Luke 0.5
3 Yoda 0
这可以通过像这样的select
来完成:
select r.metrics_id,
a.name as agent_name,
sum(if(r.response='Yes',1,0))/count(*) as score
from forms_responses r
cross join agents a
inner join forms f
on f.id = r.form_id
and f.agent_id = a.id
and f.calldatetime between '2015-12-12 00:00:00' and '2015-12-17 23:00:37'
and f.campaign_id = 22
where a.id in (
select agent_id
from forms
where calldatetime between '2015-12-12 00:00:00' and '2015-12-17 23:00:37'
and campaign_id = 22
)
group by r.metrics_id, a.name;
这是一个SQL fiddle .
此查询可确保您获得每个指标的所有相关代理,即使对于某些指标他们还没有响应。这使得 PHP 中的处理变得更加容易。
在 PHP 中,您将执行旋转:
$header = array("Metric ID");
$scores = array();
$current_metric = "-1";
$rowno = 0;
$mysqli->query($sql); // SQL as provided above
while ($row = $result->fetch_assoc()) { // fetch from query
if ($row["metrics_id"] <> $current_metric) {
// new metrics_id, start a new line
$current_metric = $row["metrics_id"];
$rowno++;
$scores[$rowno] = array();
$scores[$rowno][] = $current_metric;
}
if ($rowno == 1) {
$header[] = $row["name"];
}
$scores[$rowno][] = $row["score"];
}
// put header row (with agent names) at top of table
array_unshift($scores, $header);
// output table -- you would do this with CSV or Excel library
echo "<table>";
foreach ($scores as $line) {
echo "<tr>";
foreach ($line as $cell) {
echo "<td>$cell</td>";
}
echo "</tr>";
}
echo "</table>";
上面的输出是这样的:
Metric ID Chewbacca Luke Yoda
1 1 0.5 0
2 1 1 1
3 1 0.5 0
如果您更喜欢输出百分比,则只需将分数乘以 100 并添加“%”符号即可,但请注意,在 Excel 中,这通常是通过格式化完成的,而不是通过实际数字(保持在 0 到 1 之间)来完成的。
关于php - 复杂的报告 PHP MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34415198/
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!