Tuesday 14 May 2013

Database Restoration at WSS 3.0

A - OBJECTIVE: to restore an .mdf file to an existing SharePoint farm (a backup file is an older version of the existing database).

B - PROBLEMS :

 1. The content database can be restored by the MS SQL server. However, the web application cannot recognize the attached database (Number of Sites is 0)

2. The Site ID of the backup database is the same as the Site ID of the current database.


C - SOLUTION:

To manually configure the stsadm & Powershell commands

D - SOURCE CODE:

1)
Detach site
stsadm -o deletecontentdb -url http://test/teams/site -databasename DMS_Teams_Site -databaseserver DBSERVER

2)
Restore new DB

3)
Attach Site
stsadm -o addcontentdb -url http://test/teams/site -databasename DMS_Teams_Site  -assignnewdatabaseid

4)
Check if the contentDB is listed Sharepoint admin under Content Databases
If the “Current Number of sites is 0′ then follow this process to resolve

5)
Check is the site is listed under Site Collections
e.g /teams/site

6)
create a site collection with same settings

7) Check content Database list again to see if there if current number of Sites = 1

8) Goto database server

use DMS_Teams_Site
select ID, TimeCreated from dbo.Sites

You will see two ID’s listed and the one old one is next to the earliest date.

05D84414-B498-455C-BA15-3155C92349C3 2008-06-13 13:30:02.000
5FC42416-6554-4E4F-B55B-3E106110A20E 2009-09-30 13:39:35.000

Copy the old ID to the clipboard

9) Now check the ID ised in the SharePoint_Config for the site.

use SharePoint_Config
select ID, Path from dbo.SiteMap where path = ‘/teams/site’

5FC42416-6554-4E4F-B55B-3E106110A20E /teams/site
10) Now replace the ID of site in SharePoint_Config with the old ID

use SharePoint_Config
update dbo.Sitemap
set Id = ’05D84414-B498-455C-BA15-3155C92349C3′
where Path = ‘/teams/site’

11) Perform an IISRESET on all the servers

Note: to change SiteID of the backup database, please go through all tables in the database & manually change the SiteID :

    AllDocs
    AllDocStreams
    AllDocVersions
    AllLinks
    AllUserData
    AlluserDataJunctions
    AuditData
    BuildDependencies
    ComMd
    ContentTypes
    ContentTypeUsage
    Deps
    Features
    GroupMembership
    Groups
    ImmedSubscriptions
    NameValuePair
    NavNodes
    Perms
    RecycleBin
    RoleAssignment
    Roles
    SchedSubscriptions
    ScheduledWorkItems
    Sites
    SiteVersion
    UserInfo
    Webs
    WebpartList
    WebParts
    Workflow
    WorkflowAssociation

ALL DONE Now should see the correct website.

Note: at step 10, attaching the content DB to the same SP farm that is using the current content DB will cause a problem because SP won’t allow two databases with the same ID –> use PowerShell to “mount” the content DB:

Mount-SPContentDatabase [-Name] <String> [-WebApplication] <SPWebApplicationPipeBind> [-AssignNewDatabaseId]
Example:
Mount-SPContentDatabase “Contoso Sales” -WebApplication http://contoso/sales -AssignNewDatabaseId

Friday 15 March 2013

Remove Pending Deployed Solutions

A - OBJECTIVE: to describe a high-level objective.

B - PROBLEMS :

Using stsadm to deploy a solution, a timer job for deployment is created but its state is always “pending”

C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\BIN>stsadm -o enumdeployments
<Deployments Count=”1″>
<Deployment JobId=”7547c94e-5b2a-4619-88a4-93306319ec6d”>
<Title>Windows SharePoint Services Solution Deployment for “samplesolution.wsp”</Title>
<Type>Deployment</Type>
<State>Pending</State>
<Schedule>3/15/2013 12:14 PM</Schedule>
<File>sharepointboost.licensecentersetup12.3.wsp</File>
<ServerType>Front-end Web server</ServerType>
<Target>http://feowss01/</Target&gt;
</Deployment>
</Deployments>

Troubleshooting:

– Ensure that the deployment lock is released at all server by stsadm:

stsadm -o removesolutiondeploymentlock


C - SOLUTION:

– In my case, there was a server which had been removed out of the farm. Hence, deployment for the whole farm (including all servers) will surely encounter the above problem.

– The expected stsadm command is to use “local” parameter for one current server at a time

stsadm -o deploysolution -name “timerjobmanager.wsp” -url “http://testsite&#8221; -local -allowgacdeployment -force

Tuesday 26 February 2013

Change Values at "Read-Only" fields

A - OBJECTIVE: to complete a proper data migration with correct authors & editors ("Created By" & "Modified By")

B - PROBLEMS :

Admins cannot "edit" Read-Only fields at SharePoint in a straight-forward method.

C - SOLUTION:

As an admin, you can open Powershell and run the below code to update these Read-Only fields:

Experiment 1: to update Modified Time, Created Time, Author & Editor

$author = New-Object Microsoft.SharePoint.SPFieldUserValue($web,”1111;#User Display Name”)  #1111 is User ID in All People List
$item[“Author”] = $author
$item.Properties[“vti_author”] = $author.User.LoginName
$item[“Editor”] = $author
$item.UpdateOverwriteVersion()

Result : Successful

Experiment 2: to update File/Folder Name, Modified/Created Time & Author/Editor

First Try:


# get the original metadata
$personEditor = $Folder.Item["Editor"]
$timeModified = $Folder.Item["Modified"]

# update the folder name
$Folder.Item["Name"] = "New Name"

# revert the original metadata back
$Folder.Item["Editor"] = $personEditor
$Folder.Item["Modified"] = $timeModified

$Folder.Item.UpdateOverwriteVersion()

Result : Failed (Folder Name is updated but Modified Time & Editor are not updated)

Second Try:

# get the original metadata
$personEditor = $Folder.Item["Editor"]
$timeModified = $Folder.Item["Modified"]

# update the folder name
$Folder.Item["Name"] = "New Name"

# THIS LINE IS IMPORTANT TO BE ADDED IN
$Folder.Item.UpdateOverwriteVersion()

# revert the original metadata back
$Folder.Item["Editor"] = $personEditor
$Folder.Item["Modified"] = $timeModified

$Folder.Item.UpdateOverwriteVersion()

Result : Successful (All fields are updated properly).

D - SOURCE CODE:

[System.Reflection.Assembly]::LoadWithPartialName(“Microsoft.SharePoint”)
$site = New-Object Microsoft.SharePoint.SPSite(“http://sharepoint/subsite”)
$web = $site.OpenWeb()
$doclib = $web.Lists[“TestDocLib”]
Write-Host “SharePoint Object: ” $doclib.basetype
foreach($item in $doclib.Items){
Write-Host “Created By – Old Value: ” $item[“Author”]
$author = New-Object Microsoft.SharePoint.SPFieldUserValue($web,”1111;#User Display Name”)  #1111 is User ID in All People List
$item[“Author”] = $author
$item.Properties[“vti_author”] = $author.User.LoginName
$item[“Editor”] = $author
$item.UpdateOverwriteVersion()
Write-Host “Created By – New Value: ” $item[“Author”]
}

Wednesday 23 January 2013

Update Search Results in WSS 3.0

A - OBJECTIVE: to manually run Search Crawling & Indexing at WSS 3.0 (aka SharePoint 2007)

B - PROBLEM:

A new list with its items was created but it is not shown in the Search result (even 2 weeks after the creation date).

C - SOLUTION:

To configure database settings & use stsadm commands.

D - SOURCE CODE:

1. Database Permission: ensure the account (used for Search crawling/indexing) should have expected access rights (e.g. dbowner, dbcreator, etc):

– Open the DB server by Management Studio

– Right click at the Server Name, then choose Properties

– At Permission option, select the Account & grant permissions

2. SharePoint Config:

– Central Administration > Operations > Services on Server > Windows SharePoint Services Search Service Settings => Configure “Indexing Schedule”

* Note (9 Mar 2013): if you don’t see “WSS Search Sevice”, you can start it by stsadm -o spsearch -action start

– Site Actions > Site Settings > Search Visibility => to ensure the web is visible for Search

– Listing Settings > Advanced Settings > Allow items from this list to appear in search results? Yes => Allow list items to be searchable

3. Manual Crawl:

– Stop Crawling by: stsadm –o spsearch –action fullcrawlstop
– Start a Full Crawl: stsadm –o spsearch –action fullcrawlstart

* Note: Full command guide: http://technet.microsoft.com/en-sg/library/cc288507%28v=office.12%29.aspx

4. Check Database: Open the Search Database & look for information at:

– [MSSCrawlContent]: list all crawls so far => after you start a new crawl, a new row is added for your reference.

– [MSSScopes]: show Search Scopes (e.g. All Sites or People Search).

– [MSSCrawlHostList]: show all crawl rules with the success/error/warning messages for the latest crawl => it can be used to check if the crawl is happening by refreshing the SELECT statement frequently.

– [MSSCrawlURL]: show successful crawled URLs