开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 445|回复: 7
收起左侧

[已解决] MYSQL 语句相关问题

 关闭 [复制链接]
结帖率:67% (40/60)
发表于 2022-9-9 11:31:37 | 显示全部楼层 |阅读模式   江苏省淮安市
50精币
同一张表中,如何将指定条件的重复记录中,大的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年级









最佳答案

查看完整内容

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

求助知识:请将问题描述清楚,最好把你有问题的源码打包上传上来,这样更方便大家帮助你。
友情提醒:本版被采纳的主题可在 申请荣誉值 帖子申请荣誉值,获得 3点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。

结帖率:100% (1/1)

签到天数: 11 天

发表于 2022-9-9 11:31:38 | 显示全部楼层   河南省郑州市
[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 行受影响)

评分

参与人数 1荣誉 +3 收起 理由
项目部004 + 3 热心帮助他人,荣誉+3,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (15/15)
发表于 2022-9-9 11:53:49 | 显示全部楼层   广西壮族自治区柳州市
如果是cha询而已 不必删除   如果想删除 直接删除年级=null  如果不止2条数据 多条数据直接cha询得了,还有 比较大小最好用数字  年级这里 你可以直接用1234      select ID,学校,学号,姓名,max(年级) as 年级  from  表    直接获取每个姓名的最大年级
回复

使用道具 举报

结帖率:67% (40/60)

签到天数: 10 天

 楼主| 发表于 2022-9-9 12:50:53 | 显示全部楼层   江苏省淮安市
wyz001 发表于 2022-9-9 11:53
如果是cha询而已 不必删除   如果想删除 直接删除年级=null  如果不止2条数据 多条数据直接cha询得了,还有 ...

不是单纯只是为了cha询,表只是示范,如果几百万条数据,出现这样的情况,为了优化数据库,只能将数据进行优化合并,不是单纯的只是cha询一下
回复

使用道具 举报

结帖率:100% (2/2)
发表于 2022-9-9 13:23:10 | 显示全部楼层   江苏省常州市
先用selelct语句把id大的数据单独查出来新建一张临时表,然后把原表中id大的“年级”改为小的,最后在结合两张表删除原表中id小的,试试?
回复

使用道具 举报

结帖率:67% (40/60)

签到天数: 10 天

 楼主| 发表于 2022-9-9 13:29:26 | 显示全部楼层   江苏省淮安市
wpj888 发表于 2022-9-9 13:23
先用selelct语句把id大的数据单独查出来新建一张临时表,然后把原表中id大的“年级”改为小的,最后在结合 ...

思路知道啊,不知道具体怎么写
回复

使用道具 举报

结帖率:93% (13/14)
发表于 2022-9-9 14:13:32 | 显示全部楼层   浙江省绍兴市
本帖最后由 nddb 于 2022-9-9 14:14 编辑

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

使用道具 举报

结帖率:67% (40/60)

签到天数: 10 天

 楼主| 发表于 2022-9-9 14:36:42 | 显示全部楼层   江苏省淮安市
nddb 发表于 2022-9-9 14:13
先把重复数据大的更新到小的里面!在删除你要删除的重复数据就好了啊!就是2条语句啊!
...

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

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表