http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 3874|回复: 0

[Sql Server] insert into select复制表并去重复的方法

[复制链接]
发表于 2013-11-29 11:03:10 | 显示全部楼层 |阅读模式
[SQL] 纯文本查看 复制代码
INSERT newtabname NAME, sex
SELECT  NAME, sex  FROM (
SELECT DISTINCT  NAME, sex 
FROM oldtabname
  WHERE NAME='123456'
  ) AS t  WHERE t.NAME 
  NOT IN(SELECT NAME FROM  newtabname 
  WHERE t.NAME=NAME AND t.sex=sex)



代码都在上面大家自己看吧。我就是做个记录方便 查找

下面我做一下分析吧。
[SQL] 纯文本查看 复制代码
SELECT DISTINCT  NAME, sex 
FROM oldtabname
  WHERE NAME='123456'
这个是查询老表里面所有不重复的数据列
[SQL] 纯文本查看 复制代码
INSERT newtabname NAME, sex
SELECT  NAME, sex  FROM (
SELECT DISTINCT  NAME, sex 
FROM oldtabname
  WHERE NAME='123456'
  ) AS t

当然这个是将查询到的数据写入到新表
[SQL] 纯文本查看 复制代码
WHERE t.NAME 
  NOT IN(SELECT NAME FROM  newtabname 
  WHERE t.NAME=NAME AND t.sex=sex)

这是排除老表在新表中存在的数据
连接在一起就是这样了
[SQL] 纯文本查看 复制代码
INSERT newtabname NAME, sex
SELECT  NAME, sex  FROM (
SELECT DISTINCT  NAME, sex 
FROM oldtabname
  WHERE NAME='123456'
  ) AS t  WHERE t.NAME 
  NOT IN(SELECT NAME FROM  newtabname 
  WHERE t.NAME=NAME AND t.sex=sex)



大家可以做做测试有问题再讨论




1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-12-22 09:44

© 2014-2021

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