- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要从 MySQL 数据库中获取初始状态和最新状态。这是两个表:
customer
audit_log
我期望的是这样的输出:
我最初有一个 PHP 脚本遍历所有 customer
行,然后将它们与 audit_log
行匹配并从那里生成输出,但速度非常慢并且占用大量资源。
是否可以直接在 MySQL 中执行类似的操作,我该怎么做?
我在 customer
和输出表中添加了额外的行。输出表需要包含 customer
中的所有行,以及从 audit_log
构建的初始行的副本。
最佳答案
尝试以下操作:
SET @rn=0;
SET @cust=null;
SET @pr=null;
SELECT id, name, surname, dob, email, telephone
FROM customer
UNION ALL
(
SELECT CONCAT(T.id, '_', D.rownum) id,
COALESCE(MAX(CASE D.property WHEN 'name' THEN D.old_value END), MAX(T.name)) name,
COALESCE(MAX(CASE D.property WHEN 'surname' THEN D.old_value END), MAX(T.surname)) surname,
COALESCE(MAX(CASE D.property WHEN 'dob' THEN D.old_value END), MAX(T.dob)) dob,
COALESCE(MAX(CASE D.property WHEN 'email' THEN D.old_value END), MAX(T.email)) email,
COALESCE(MAX(CASE D.property WHEN 'telephone' THEN D.old_value END), MAX(T.telephone)) telephone
FROM customer T
JOIN
(
SELECT id, entity_id, property, old_value, new_value,
IF(@cust <> entity_id OR @pr <> property, @rn:=1, @rn:=@rn+1) rownum,
@cust:=entity_id, @pr:=property
FROM audit_log
ORDER BY entity_id, property, id
) D
ON T.ID = D.entity_id
WHERE D.rownum=1
GROUP BY T.id, D.rownum
)
ORDER BY id
查看 demo .
此查询模拟 ROW_NUMBER() OVER (PARTITION BY entity_id, property ORDER BY id)
为 audit_log 表获取每个客户/属性(property)的初始值(其中 rownum = 1)。
COALESCE
用于从 customers 表中获取属性的值,如果此属性未更改,即名称已更改但电子邮件未更改,则对于电子邮件获取最新值(在本例中为 latest=initial,即T.此查询中的电子邮件)。
关于mysql - 如何将一行的初始状态与 MySQL 中的最新状态结合起来?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73703422/
我正在尝试执行 vagrant up 但一直遇到此错误: ==> default: IOError: [Errno 13] Permission denied: '/usr/local/lib/pyt
我在容器 div 中有一系列动态创建的不同高度的 div。 Varying text... Varying text... Varying text... Varying text.
通过 cygwin 运行 vagrant up 时遇到以下错误。 stderr: /bin/bash: /home/vagrant/.ansible/tmp/ansible-tmp-14872260
今天要向小伙伴们介绍的是一个能够快速地把数据制作成可视化、交互页面的 Python 框架:Streamlit,分分钟让你的数据动起来! 犹记得我在做机器学习和数据分析方面的毕设时,
我是 vagrant 的新手,正在尝试将第二个磁盘添加到我正在用 vagrant 制作的虚拟机中。 我想出了如何在第一次启动虚拟机时连接磁盘,但是当我关闭机器时 然后再次备份(使用 'vagrant
我是一名优秀的程序员,十分优秀!