罗汉松驻扎的工作基地 2021-07-09 08:58 采纳率: 44.4%
浏览 12
已结题

批量查询dataTable是否存在于数据库中。

我程序里面有一个datatable是从外部的webserivce取过来的,
根据不同的条件可以取得几十条或者几千条数据(最多大概是6000行)

Datatable apiTable= WebServer.GetTable(condition)

我现在需要对比sql server数据库中 OddInfo 表是否存在记录,
这两个数据表可以通过字段 odd_no 和 odd_date 来作为标记,其他field就不相同了。

请问有什么方法能搜索出 in apiTable but not in OddInfo ?
存在于apiTable但不在OddInfo里面。

我现在的做法是:
foreach(var row in apiTable){
select * from OddInfo where odd_no=row.odd_no and odd_date=row.odd_date
如果存在则remove
}

这样写就太慢了。

  • 写回答

1条回答 默认 最新

  • weixin_42033508 2023-02-11 01:33
    关注

    可以使用SQL语句来查询出不在OddInfo中的记录。您可以使用 LEFT JOIN 语法,并且使用 IS NULL 判断,以此来找到不存在于OddInfo中的数据。

    SELECT apiTable.*
    FROM apiTable
    LEFT JOIN OddInfo
    ON apiTable.odd_no = OddInfo.odd_no AND apiTable.odd_date = OddInfo.odd_date
    WHERE OddInfo.odd_no IS NULL
    

    这个查询语句将会返回 apiTable 中不存在于 OddInfo 表的所有记录。

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月1日
  • 创建了问题 7月9日

悬赏问题

  • ¥60 Python如何后台操作Vmwake虚拟机键鼠
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容