根据值将时间日志从单列转换为Saprate列-MySQL到PostgreSQL Syntex问题
下面是一个SQLFiddle链接 问题 我是一名软件开发人员,在我的项目中使用MYSQL。现在,我正在开发一个硬件控制器应用程序,在这个应用程序中,我必须检查继电器是否开启或关闭。当我从硬件获取数据时,我将其存储在数据库中 模式 我在MYSQL中的工作 现在,当我试图用PostgreSQL写这篇文章时,我没有明确的选择 要求 数据库表 期望输出根据值将时间日志从单列转换为Saprate列-MySQL到PostgreSQL Syntex问题,mysql,postgresql,Mysql,Postgresql,下面是一个SQLFiddle链接 问题 我是一名软件开发人员,在我的项目中使用MYSQL。现在,我正在开发一个硬件控制器应用程序,在这个应用程序中,我必须检查继电器是否开启或关闭。当我从硬件获取数据时,我将其存储在数据库中 模式 我在MYSQL中的工作 现在,当我试图用PostgreSQL写这篇文章时,我没有明确的选择 要求 数据库表 期望输出 你的问题,并添加一些样本数据和所需的结果。编辑完成后,我附上了输入和输出的图片也。 create table t ( id int, datet
你的问题,并添加一些样本数据和所需的结果。编辑完成后,我附上了输入和输出的图片也。
create table t (
id int, datetime timestamp, door varchar(255)
);
select (@rn := @rn + 1) as id,
max(case when door = 'On' then datetime end) as clockin,
max(case when door = 'Off' then datetime end) as clockout
from (select t.*,
@grp := if(@d = door, @grp,
if(@d := door, @grp + 1, @grp + 1)
) as grp
from t cross join
(select @d := '', @grp := 0) param
order by id
) t cross join
(select @rn := 0) param
group by floor((grp - 1) / 2)