收藏本站 收藏本站
积木网首页 - 软件测试 - 常用手册 - 站长工具 - 技术社区
首页 > 数据库 > MsSql > 正文

首页 - PHP - 数据库 - 操作系统 - 游戏开发 - JS - Android - MySql - Redis - MongoDB - Win8 - Shell编程 - DOS命令 - jQuery - CSS样式 - Python - Perl

Access - Oracle - DB2 - SQLServer - MsSql2008 - MsSql2005 - Sqlite - PostgreSQL - node.js - extjs - JavaScript vbs - Powershell - Ruby

Sql Server里删除数据表中重复记录的例子

[项目]

数据库中users表,包含u_name,u_pwd两个字段,其中u_name存在重复项,现在要实现把重复的项删除!

[分析]

1、生成一张临时表new_users,表结构与users表一样;
2、对users表按id做一个循环,每从users表中读出一个条记录,判断new_users中是否存在有相同的u_name,如果没有,则把它插入新表;如果已经有了相同的项,则忽略此条记录;
3、把users表改为其它的名称,把new_users表改名为users,实现我们的需要。

[程序]

declare @id int,@u_name varchar(50),@u_pwd varchar(50)

set @id=1

while @id<1000 begin if exists (select u_name from users where u_id=@id) begin select @u_name=u_name,@u_pwd=u_pwd from users where u_id=@id --获取源数据 if not exists (select u_name from new_users where u_name=@u_name) -- 判断是否有重复的U-name项 begin insert into new_users(u_name,u_pwd) values(@u_name,@u_pwd) end end set @id=@id+1 end

select * from new_users

[方法二]
假设Users表中有相同的name项,id为主键标识字段。现在要求去掉Users中重复的name项。

1、把不重复的ID保存在一个tmp1表里面。

select min([id]) as [id]  into tmp1 from Users group by [name]

2、从Users表中选取tmp1表中的id项,将相应id的数据写入表tmp2
select * into tmp2 from Users where [id] in( select [id] from tmp1)

3、把Users、tmp1两张表Drop掉
drop table Users 

drop table tmp1

4、把tmp2表改名为User表

[注]如果没有主键标识id,可以增加一个标识字段,方法如下:

select identity(int,1,1) as autoID, * into tmp0 from Users

[情况三]
假设有一个User表,id为主键标识字段,但有一些完全重复的项。现在要求去掉Users中这些完全重复的项,只保留一条。

1、把不重复的数据保存在tmp1表中

select distinct * into tmp1 from Users

2、把Users表删除
drop table Users

3、把tmp1表中的数据导入到Users表
select * into Users from tmp1

4、把tmp1表删除
drop table tmp1

如何查看SQLSERVER中某个查询用了多少TempDB空间
在SQLServer中,TempDB主要负责供下述三类情况使用:内部使用(排序、hashjoin、worktable等)外部使用(临时表,表变量等)行版本控制(乐观并发控制)而

在SQL Server中使用ISNULL执行空值判断查询
有如下查询:selectisnull(lastchanged,'')aslastchangedfromvhhostlistwheres_comment='test202'本来,ISNULL函数只有一个参数,它表示的含义就是判断这个参数的值是否为NULL

揭秘SQL Server 2014有哪些新特性(1)-内存数据库
简介SQLServer2014提供了众多激动人心的新功能,但其中我想最让人期待的特性之一就要算内存数据库了。去年我再西雅图参加SQLPASSSummit2012的开幕式时,

本周排行

更新排行

强悍的草根IT技术社区,这里应该有您想要的!
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP备05050695号