sql一对多的两个表的update

scie_apprecord仪器表   和   scie_apporder仪器预约时间表 ,一个仪器可以有多条预约时间。

仪器表:

预约时间表:

需求:

由于一个仪器有好多条预约记录,将预约时间表的最早开始时间(startDate)给仪器表的全局开始时间(globalSdate)

-- 更新预约全局开始时间	
UPDATE scie_apprecord A 
INNER JOIN 
(
    SELECT apparId  ,basiId , MIN(startDate) AS newdate FROM scie_apporder  GROUP BY apparId,basiId
)B
ON A.apparId = B.apparId AND A.basiId = B.basiId
SET A.globalSdate = B.newdate

  

 

posted @ 2017-01-04 15:39  张昊亮  阅读(4590)  评论(0编辑  收藏  举报