SQL语句:传入一个集合A,返回A中不在数据库表中的数据

写代码碰到一个不知道用SQL语句怎么表示的逻辑

问题

问题如下,现有一个集合A,我想查数据库,查出A中有哪些元素,不在数据库的表里,并且把这些元素返回给我(自然,返回结果是A的子集)。

解决方法

思路是使用临时表:
将集合A的所有元素拼成一个临时表,然后使用not in,查找数据库表内所有不在临时表中的数据。

写MyBatis的代码,形如:

<choose>
    <when test="set != null and set.size != 0">
        select v.val FROM
        <foreach collection="set" item="s" separator="union" open="(" close=")">
            select #{s} as val
        </foreach>
        v where v.val not IN (select xx from XX_table where xxxx='xxxxxx')<!-- select 自定 -->
    </when>
    <otherwise>
        select val from module where 1!=1
    </otherwise>
</choose>

关联讨论:

  1. https://stackoverflow.com/questions/14114980/getting-values-which-dont-exist-in-mysql-table
  2. https://stackoverflow.com/questions/14379096/sql-query-return-whats-not-in-table
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值