SQL,获取 ID 的历史状态

sas系统的表tb存储病人的医疗历史记录,当Visit_code=Surgery时表示手术,Visit_code=Office表示咨询,每个病人有多条Visit_code,有时只有Surgery或只有Office:
IdVisit_DateVisit_code
A305/15/2004Surgery
A302/5/2005Office
B0112/7/2002Office
B0111/21/2002Surgery
C0112/1/2001Office
C0111/1/2001Office
C015/15/2001Surgery
C014/15/2001Surgery
C0212/1/2001Surgery
C0312/1/2001Office

要求计算出每个病人的历史状态,如果有过咨询,则 Office_Visit=1,否则为 0;如果手术后 6 个月内进行过咨询,则 SX_past_6mo=1,否则为 0:

IdOffice_VisitSX_past_6mo
A3010
B0111
C0111
C0200
C0310

编写SPL代码:

A
1=sas1.query("select * from tb order by Id,Visit_Date")
2=A1.group(Id)
.new(Id,(S=0,~.max( if( Visit_code=="Office", if( S==0 && Visit_code[-1]=="Surgery" && interval@m(Visit_Date[-1],Visit_Date)<=6,S=1,1),0))):Office_Visit, S: SX_past_6mo)

A1:通过JDBC从 sas 表取数,按Visit_code,Visit_Date 的顺序排序。

A2:按 Id 分组,根据分组新建二维表。~ 表示当前组,Visit_code[-1] 表示上一条记录的 Visit_code 字段,interval@m 用于求月份的间隔。

SPL开源地址

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值