Step1: Run the given sql Query.
Reference URL: http://blogs.technet.com/corybu/
Copy Follwoing Code:
Use MSDB
Drop table orphanlist
CREATE TABLE [dbo].[orphanlist](
 [farm] [varchar](250) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
 [databasename] [varchar](250) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
 [SiteID] [uniqueidentifier] NULL,
 [sitepath] [varchar](250) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
 [type] [varchar](250) COLLATE SQL_Latin1_General_CP1_CI_AS NULL
)
drop table orphan_hopper   
declare   
@dbname as varchar(250),  
@cmdstr as varchar(2000),  
@dbid as varchar(250),
@configdb as varchar(250)   
 
/** only change the following line and nothing else, change spskills_config_db to your config db name **/
select @configdb = 'spskills_config_db'
/** Change nothing below this line **/
select @cmdstr =  
'select distinct b.name as ''databasename'', b.id as ''dbid'' into orphan_hopper  
from  
 [' + @configdb + '].dbo.sitemap as a inner join    
 [' + @configdb + '].dbo.objects as b on a.databaseid=b.id inner join    
 [' + @configdb + '].dbo.objects as c on c.id=a.applicationid inner join    
 [' + @configdb + '].dbo.objects as d on b.parentid=d.id inner join    
 [' + @configdb + '].dbo.objects as e on d.parentid=e.id  '   
exec (@cmdstr)     
  
DECLARE DBCursor CURSOR For  
  Select databasename, dbid  
  From orphan_hopper  
  
OPEN DBCursor  
FETCH NEXT FROM DBCursor into @DBName, @dbid  
  
WHILE @@FETCH_STATUS =0  
BEGIN  
 INSERT INTO orphanlist([Type], farm, databasename,[sitepath], SiteID)  
 EXEC  
  ('  
select ''Potential ConfigDB orphan:'' + '''+@dbname+'''   as [Type], '''+@configdb+''' as [farm], '''+@dbname+''' as [databasename],path as [sitepath], id as [SiteID] from ['+@configdb+'].dbo.sitemap where id not in (select id from ['+@dbname+'].dbo.sites) and databaseid = '''+@dbid+'''  
union  
select ''Potential ConfigDB orphan:'' + '''+@dbname+'''   as [Type], '''+@configdb+''' as [farm], '''+@dbname+''' as [databasename],path as [sitepath], id as [SiteID] from ['+@configdb+'].dbo.sitemap where id not in (select siteid from ['+@dbname+'].dbo.webs where parentwebid is null) and databaseid = '''+@dbid+'''  
union  
select ''Potential ContentDB orphans:'' + '''+@dbname+''' as [Type], '''+@configdb+''' as [farm], '''+@dbname+''' as [databasename],fullurl as [sitepath], siteid as [SiteID] from ['+@dbname+'].dbo.webs where parentwebid is null and siteid not in (select id from ['+@configdb+'].dbo.sitemap where databaseid = '''+@dbid+''')  
union  
select ''Potential ContentDB orphan:'' + '''+@dbname+'''  as [Type], '''+@configdb+''' as [farm], '''+@dbname+''' as [databasename],fullurl as [sitepath], siteid as [SiteID] from ['+@dbname+'].dbo.webs where parentwebid is null and siteid not in (select id from ['+@dbname+'].dbo.sites)  
')  
 FETCH NEXT FROM DBCursor into @DBName, @dbid  
END  
CLOSE DBCursor  
DEALLOCATE DBCursor  
  
select * from orphanlist  
Step2: Delete the Content DB
stsadm.exe -o deletecontentdb -url http://ServerName -databasename wss_content -databaseserver ServerName
Operation completed successfully.
Step3: Add Content DB
stsadm.exe -o addcontentdb -url http://ServerName -databasename wss_content -databaseserver ServerName
Operation completed successfully.
 
 
No comments:
Post a Comment