Mysql 用!填充空数据库列!清空旧的行列

Mysql 用!填充空数据库列!清空旧的行列,mysql,select,merge,rows,Mysql,Select,Merge,Rows,假设我有一个包含以下行的数据库: id (auto_incremented) | id_person | first_name | last_name | phone | email ----------------------------------------------------------------------------- 1 | 12 | kevin | smith |

假设我有一个包含以下行的数据库:

id (auto_incremented) | id_person | first_name | last_name | phone          | email
-----------------------------------------------------------------------------
1                     | 12        | kevin      | smith     |                | kevin@hotmail.com
2                     | 12        | kevin      | smith     | 1-800-123-4567 | 
3                     | 33        | joe        | jones     | 1-800-765-4321 | 
4                     | 33        | joe        | thompson  |                | joe@hotmail.com
5                     | 33        | joe        | thompson  |                | newjoe@hotmail.com
基于
id\u person
,我希望在单个查询中输出以下内容:

id | id_person | first_name | last_name | phone          | email
-----------------------------------------------------------------------------
2  | 12        | kevin      | smith     | 1-800-123-4567 | kevin@hotmail.com
5  | 33        | joe        | thompson  | 1-800-765-4321 | newjoe@hotmail.com
所以基本上,我只想获取最新的行值,如果它们为空,则从第一行中获取非空的值

我该怎么做?希望这是有意义的

SELECT id_person, subQ.lastID
    , GROUP_CONCAT(IF(subQ.lastFieldXId = tblFields.ID, tblFields.fieldX, NULL)) AS fieldX
    , GROUP_CONCAT(IF(subQ.lastFieldYId = tblFields.ID, tblFields.fieldY, NULL)) AS fieldY
    [, ...]
FROM
(SELECT id_person
   , MAX(id) AS lastID
   , MAX(IF(IFNULL(fieldX, '') = '', 0, id) AS lastFieldXId
   , MAX(IF(IFNULL(fieldY, '') = '', 0, id) AS lastFieldYId
[, ....]
FROM theTable
GROUP BY id_person) AS subQ
LEFT JOIN theTable AS tblFields USING (id_person)
;
左连接可能会更快,也可能不会更快

LEFT JOIN theTable AS tblFields 
ON tblFields.ID IN (subQ.lastFieldXId, subQ.lastFieldYId [, ...])
可能还有一种使用会话变量的方法,但我没有精力

select * from(
select p1.id,p1.id_person,p1.first_name,p1.last_name,
ifnull(p1.phone,p2ph.phone) phone ,ifnull(p1.email,p3em.email) email

from person p1
left join person p2ph on(p1.id_person=p2ph.id_person and p2ph.phone is not null)
left join person p3em on(p1.id_person=p3em.id_person and p3em.email is not null)
order by id_person,p1.id desc,p2ph.id desc,p3em.id desc 
  )t group by id_person;

处验证:清理数据比采用某种奇怪的数据检索方案要好。你能告诉我们为什么数据必须是这样吗?我有两个表。一个用于
人员
,另一个用于
人员历史
people\u history
表中每个人可以包含多行。我试图避免在两个表中使用完全相同的列,但这可能是我的最佳选择……那么最好将两个表分开,并在需要最新数据时使用
people
people\u history
表中有重复的数据,这是为了存储个人数据的历史记录。@Populus说了什么,而且您甚至可以通过在“current data”表上使用触发器使历史记录表在某种程度上是自动的。@daygloink:first\u name或last\u name可以有空值吗?