加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL查询语句误删数据的问题分析

发布时间:2020-12-12 12:39:31 所属栏目:MsSql教程 来源:网络整理
导读:编程之家 jb51.cc 昨天通过查询分析器批量删除垃圾用户的时候,结果把用户表给清空了,上百万条记录没了。经过半小时的数据库还原,问题解决。用户数据都完全恢复。但是那条语句为什么把用户表清空了,令我非常费解,经过分析找出了原因,特别给大家分享。

  编程之家 52php.cn 昨天通过查询分析器批量删除垃圾用户的时候,结果把用户表给清空了,上百万条记录没了。经过半小时的数据库还原,问题解决。用户数据都完全恢复。但是那条语句为什么把用户表清空了,令我非常费解,经过分析找出了原因,特别给大家分享。

  昨日误删数据的语句是这样的:

  1.delete Table_1 where UserID in (select [ID] from Table_2)

  问题是Table_2没有[ID]字段。结果Table_1的数据都清空了。

  于是我做了下面的测试

  1.select [ID] from Table_2

  报错 列名 ‘ID’ 无效。

  1.select top 10 * from Table_1 where UserID in (select [ID] from Table_2)

  列出了10条记录。

  再测试,把[ID]修改为[xxxxx]

  1.select top 10 * from Table_1 where UserID in (select [xxxxx] from Table_2)

  报错 列名 ‘xxxxx’ 无效。

  错误原因分析:当Table2里没有ID,用的就是Table1的ID

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读