MySQL Update 使用

备忘:

复制代码
USE `xxx`;
SET SQL_SAFE_UPDATES = 0;

UPDATE `TB_MB_1` T
SET T.`MedicalCount` = 
(
    SELECT S.Total-- ,S.`HospitalID`
    FROM(
            SELECT DISTINCT Base.`HospitalID`
                ,Fix.Total AS FixCount
                ,CASE WHEN Self.Total>0 THEN 1 ELSE 0 END AS SelfCount
                ,CASE WHEN Self.Total>0 THEN Fix.Total+1 ELSE Fix.Total END AS Total
            FROM `TB_MB_2` AS Base
            LEFT JOIN (
                SELECT HospitalID,Total
                FROM(
                    SELECT HospitalID,COUNT(1) AS Total
                    FROM `TB_MB_2`
                    WHERE `STATUS` = 0 AND IsBySelf = 0 AND ServeType = 0
                    GROUP BY HospitalID) AS Temp
                )AS Fix
            ON Base.`HospitalID` = Fix.HospitalID
            LEFT JOIN (
                SELECT HospitalID,Total
                FROM(
                    SELECT HospitalID,COUNT(1) AS Total
                    FROM `TB_MB_2`
                    WHERE `STATUS` = 0 AND IsBySelf = 1
                    GROUP BY HospitalID) AS Temp
                )AS Self
            ON Base.`HospitalID` = Self.HospitalID
    )AS S
    -- ORDER BY S.`HospitalID`
    WHERE T.`MemberID` = S.`HospitalID`
);
复制代码

 

posted @   xachary  阅读(283)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示