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