sqlite高级语法实例:子查询+UNION+JOIN实现较复杂的IF逻辑

需求概述

数据库结构

表Features

表Features的列: FeatureType | Removable | RemoveTech | 略

表Features_XP2

表Features_XP2的列: FeatureType | volcano | 略

Features_XP2有可能不存在,Features一定存在。

数据

关注FeatureType值为'FEATURE_FLOODPLAINS','FEATURE_OASIS','FEATURE_REEF','FEATURE_GEOTHERMAL_FISSURE'的记录,其它数据不处理。

一个简单的操作

update Features set Removable=1,RemoveTech='TECH_MASS_PRODUCTION' where FeatureType in
 ('FEATURE_FLOODPLAINS','FEATURE_OASIS','FEATURE_REEF','FEATURE_GEOTHERMAL_FISSURE')

实际需求

在上一节的基础上,判断Features_XP2是否存在,如果存在则不更改FeatureType='FEATURE_FLOODPLAINS'的记录。

实现代码

update Features set Removable=1,RemoveTech='TECH_MASS_PRODUCTION' where FeatureType in
    (
        select FeatureType from
            (select FeatureType from Features where FeatureType='FEATURE_FLOODPLAINS') LEFT OUTER JOIN
            ( select name from sqlite_master where type='table' and name='Features_XP2')
        where name is NULL
        UNION
        select FeatureType from Features where FeatureType in ('FEATURE_OASIS','FEATURE_REEF','FEATURE_GEOTHERMAL_FISSURE')
    );

应用

这是一个游戏插件(MOD)中的代码,作者是本人。

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值