精易论坛

标题: MYSQL 语句相关问题 [打印本页]

作者: louxu163    时间: 2022-9-9 11:31
标题: MYSQL 语句相关问题
同一张表中,如何将指定条件的重复记录中,大的ID中的某个记录填到小的ID中指定字段的记录中,然后删除掉小的ID的重复记录

如:
ID                  学校 学号姓名年级
10
A学校
1006
张远null
20
A学校
1007
张三4年级
21
B学校
1008
李四null
22
A学校
1006
3年级
23
B学校
1008
4年级



通过学校和学号两个条件进行筛选重复,可cha询出ID 10 和22重复,21和23重复,现在想通过语句将重复数据中id大的“年级字段”记录值填写到id小的当中,并且删除id小的重复数据,达到下表的效果
ID                  学校 学号姓名年级
10
A学校
1006
张远3年级
20
A学校
1007
张三4年级
21
B学校
1008
李四4年级










作者: afu45    时间: 2022-9-9 11:31
[SQL] 纯文本查看 复制代码

select (select top 1 ID from [biao] where a.学校 =[biao].学校 and a.学号=[biao].学号 order by ID asc) ID,
        a.*,
        (select top 1 姓名 from [biao] where a.学校 =[biao].学校 and a.学号=[biao].学号 and biao.姓名<>'' order by ID asc) 姓名,
        (select top 1 年级 from [biao] where a.学校 =[biao].学校 and a.学号=[biao].学号 and biao.年级<>'' order by ID asc) 年级
  from
  (
SELECT
      [学校]
      ,[学号]

  FROM [biao]   group by [学校],[学号]
  )a



ID          学校         学号         姓名         年级
----------- ---------- ---------- ---------- ----------
10          A学校        1006       张远         3年级
20          A学校        1007       张三         4年级
21          B学校        1008       李四         4年级

(3 行受影响)
作者: wyz001    时间: 2022-9-9 11:53
如果是cha询而已 不必删除   如果想删除 直接删除年级=null  如果不止2条数据 多条数据直接cha询得了,还有 比较大小最好用数字  年级这里 你可以直接用1234      select ID,学校,学号,姓名,max(年级) as 年级  from  表    直接获取每个姓名的最大年级
作者: louxu163    时间: 2022-9-9 12:50
wyz001 发表于 2022-9-9 11:53
如果是cha询而已 不必删除   如果想删除 直接删除年级=null  如果不止2条数据 多条数据直接cha询得了,还有 ...

不是单纯只是为了cha询,表只是示范,如果几百万条数据,出现这样的情况,为了优化数据库,只能将数据进行优化合并,不是单纯的只是cha询一下
作者: wpj888    时间: 2022-9-9 13:23
先用selelct语句把id大的数据单独查出来新建一张临时表,然后把原表中id大的“年级”改为小的,最后在结合两张表删除原表中id小的,试试?
作者: louxu163    时间: 2022-9-9 13:29
wpj888 发表于 2022-9-9 13:23
先用selelct语句把id大的数据单独查出来新建一张临时表,然后把原表中id大的“年级”改为小的,最后在结合 ...

思路知道啊,不知道具体怎么写
作者: nddb    时间: 2022-9-9 14:13
本帖最后由 nddb 于 2022-9-9 14:14 编辑

先把重复数据大的更新到小的里面!在删除你要删除的重复数据就好了啊!就是2条语句啊!

作者: louxu163    时间: 2022-9-9 14:36
nddb 发表于 2022-9-9 14:13
先把重复数据大的更新到小的里面!在删除你要删除的重复数据就好了啊!就是2条语句啊!
...

思路知道,不会写SQL语句啊




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4