科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道SQL Server 数据库操作技巧锦集(2)

SQL Server 数据库操作技巧锦集(2)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

包括安装时提示有挂起的操作、收缩数据库、压缩数据库、转移数据库给新用户以已存在用户权限、检查备份集、修复数据库等 K-F<X85m :zH`@!h\"sE

作者:赛迪网技术社区 来源:赛迪网技术社区 2007年9月2日

关键字: 技巧 SQL Server SQL Server 各版本 数据库

  • 评论
  • 分享微博
  • 分享邮件
8.删除数据库中重复数据的几个方法 nO-.)=LPk  
t@?\L>k  
数据库的使用过程中由于程序方面的问题有时候会碰到重复数据,重复数据导致了数据库部分设置不能正确设置…… U"*/Y}\  
uq>ecp\jG  
方法一 0/EEGH!|6.  
ErJoP#TS_  
declare @max integer,@id integer x8MN TPdoF  
declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1 wsiYz.   
open cur_rows +Xkqi   
fetch cur_rows into @id,@max rF4.yY~'  
while @@fetch_status=0 K:!>AmsJs  
begin Mm9,3b4  
select @max = @max -1 CD!]|0  
set rowcount @max I ;%AF|%/  
delete from 表名 where 主字段 = @id GJv7?cC8^  
fetch cur_rows into @id,@max 3ld!L>|Sh  
end XXh}h6  
close cur_rows !zMW',K  
set rowcount 0 WoYHmU6ic  
{J .   
方法二 GZcciW'  
sm*wz;r/  
有两个意义上的重复记录: @@/$Q+=U  
tYhG3^*v  
一是完全重复的记录,也即所有字段均重复的记录, mQOGn<&L_v  
二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。 'gL.^Mk  
" PLA5=.I  
A、对于第一种重复,比较容易解决,使用 "\)@v2U  
select distinct * from tableName ]Q`@2D  
就可以得到无重复记录的结果集。 v10.V1N3#m  
如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除 sBu_@HTdg  
select distinct * into #Tmp from tableName :u`'(0fV  
drop table tableName iu&@R6bQ*  
select * into tableName from #Tmp Dx=MDFFC  
drop table #Tmp h N8R*e  
发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。 {bO@A%l'  
5e\j4fh|  
B、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下 EJK_VBCB  
假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集 @0H&+)  
select identity(int,1,1) as autoID, * into #Tmp from tableName v\NTXhg+  
select min(autoID) as autoID into #Tmp2 from #Tmp group by Name,autoID +G)9Kuwy  
select * from #Tmp where autoID in(select autoID from #tmp2) MvFZUd(__  
最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列) DfWpi( 4[  
A DiwIf"  
!j>{~K?F  
/iYgH@^ z  
9.更改数据库中表的所属用户的两个方法 i5 n vd3  
qk2G"X2nA  
大家可能会经常碰到一个数据库备份还原到另外一台机器结果导致所有的表都不能打开了,原因是建表的时候采用了当时的数据库用户…… }ht|jPX  
)|Mn`=Xz  
qg?j%Jhf  
--更改某个表 uiY$=  
exec sp_changeobjectowner 'tablename','dbo' Vl 9nqVL  
& {jhX|  
n 2o! ;}@  
--存储更改全部表 ?ZzX(+tJ  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch >5fPz90  
@OldOwner as NVARCHAR(128), k^-UbVi  
@NewOwner as NVARCHAR(128) Lf1TmX*  
AS l^N:2noS<[  
UiR"PR5  
DECLARE @Name as NVARCHAR(128) H'y JdP  
DECLARE @Owner as NVARCHAR(128) AUFz^RH  
DECLARE @OwnerName as NVARCHAR(128) =pl}uy(Qd  
8V /'ns*  
DECLARE curObject CURSOR FOR [Ws]]Eun  
select 'Name' = name, ;QJ/XYh8  
'Owner' = user_name(uid) &]4Z&H4`PC  
from sysobjects WI%*Z%"BqG  
where user_name(uid)=@OldOwner 8H>@q_sa]  
order by name s#]!k15@X  
m}bkY1Ds  
OPEN curObject qfcH,0pC  
FETCH NEXT FROM curObject INTO @Name, @Owner ly^*xcB  
WHILE(@@FETCH_STATUS=0) MkQZ:t  
BEGIN -6NtN _D  
if @Owner=@OldOwner vKWU*M4;  
begin OBx Q  
set @OwnerName = @OldOwner + '.' + rtrim(@Name) hR TA6  
exec sp_changeobjectowner @OwnerName, @NewOwner {Wg+zQ;'  
end gTSWJb%&  
-- select @name,@NewOwner,@OldOwner $WgA$>k  
QeY-zwiRh  
FETCH NEXT FROM curObject INTO @Name, @Owner :M2j-(kS`  
END ElW *,tr4  
9M`HuKs*  
close curObject T{%, g<917  
deallocate curObject QZ={  
uUkFqNDqB  
8qFe81?~K  
GO mPZ]R'T@K  
58H|$dM{
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章