<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Personal Weblog of John Wood</title>
	<atom:link href="http://www.webofwood.com/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.webofwood.com</link>
	<description>Wordpress weblog of John Wood, a Database Administrator</description>
	<lastBuildDate>Thu, 29 Jul 2010 14:00:56 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>Using Powershell to Set Up SQL Server Mirroring</title>
		<link>http://www.webofwood.com/2010/07/29/powershell-sqlserver-mirroring/</link>
		<comments>http://www.webofwood.com/2010/07/29/powershell-sqlserver-mirroring/#comments</comments>
		<pubDate>Thu, 29 Jul 2010 13:50:07 +0000</pubDate>
		<dc:creator>John Wood</dc:creator>
				<category><![CDATA[Powershell]]></category>
		<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[Powershell sqlserver mirror script]]></category>

		<guid isPermaLink="false">http://www.webofwood.com/?p=123</guid>
		<description><![CDATA[Management recently decided to use database mirroring as our DR solution. Because mirroring is done at the database level and not at the server level, I had a lot, a very lot of databases to be mirrored. To make it easier I decided to cobble together a simplistic script to do this. I typically use [...]]]></description>
			<content:encoded><![CDATA[<p>Management recently decided to use database mirroring as our DR solution. Because mirroring is done at the database level and not at the server level, I had a lot, <strong><em>a very lot</em></strong> of databases to be mirrored. To make it easier I decided to cobble together a simplistic script to do this. </p>
<p>I typically use a &#8216;management&#8217; server for most of my needs and have therefore written the script to use UNC type pathing for the primary as well as mirror server. You will also notice I defaulted several of the parameters. This is handy when working on a set of servers for multiple databases.</p>
<p>I hope you find the script useful. You can also find a copy of the script at <a title="scriptinganswers.com" href="http://www.scriptinganswers.com" target="_blank">www.scriptinganswers.com</a>.</p>
<div style="padding-bottom: 0px; margin: 0px; padding-left: 0px; padding-right: 0px; display: inline; float: none; padding-top: 0px" id="scid:0767317B-992E-4b12-91E0-4F059A8CECA8:6127b23c-ffcb-4ec0-83a2-518000bca639" class="wlWriterEditableSmartContent">del.icio.us Tags: <a href="http://del.icio.us/popular/powershell" rel="tag">powershell</a>,<a href="http://del.icio.us/popular/sqlserver" rel="tag">sqlserver</a>,<a href="http://del.icio.us/popular/mirror" rel="tag">mirror</a></div>
<pre class="brush: ps">&lt;#
	.SYNOPSIS
		Set up an SQL Server mirrored database
	.DESCRIPTION
		Backs up a database and tlog, copies it to the destination,
		Restores the database on the mirror server, sets up the partner,
		and starts the mirror.
	.PARAMETER  database
		The name of the database to be mirrored
	.PARAMETER  SourceServer
		The name of the primary server
	.PARAMETER  SourcePath
		Local Path for the backup
	.PARAMETER  DestServer
		The name of mirror server
	.PARAMETER  DestPath
		Local path for restore file
	.EXAMPLE
		PS C:\&gt; Invoke-Mirror -database 'string value' `
			-SourceServer 'string\string' -SourcePath 'string' `
			-DestServer 'string\string' -DestPath 'string'
	.NOTES
		The SQL connections rely on Windows authentication and assumes Endpoints
		already exist. Error checking is minimal (i.e. no check is made to
		verify the recovery model is FULL).
	.AUTHOR
		John P. Wood
		07/28/2010
#&gt;
Param(
	[Parameter(Mandatory=$true)]
	[string]$database,
	[string]$SourceServer='Server1\Instance',
	[string]$SourcePath='K:\SQL Backups',
	[string]$DestServer='Server2\Instance',
	[string]$DestPath='K:\SQL Backups'
	)
[Void][System.Reflection.Assembly]::LoadWithPartialName(&quot;Microsoft.SqlServer.ConnectionInfo&quot;)
[Void][System.Reflection.Assembly]::LoadWithPartialName(&quot;Microsoft.SqlServer.SMO&quot;)
[Void][System.Reflection.Assembly]::LoadWithPartialName(&quot;Microsoft.SqlServer.SmoExtended&quot;)
Function New-SMOconnection {
    Param (
		[string]$server
	)
	$conn = New-Object Microsoft.SqlServer.Management.Common.ServerConnection($server)
	$conn.applicationName = &quot;PowerShell SMO&quot;
	$conn.StatementTimeout = 0
	$conn.Connect()
	if ($conn.IsOpen -eq $false) {
		Throw &quot;Could not connect to server $($server) for database backup of $($dbname).&quot;
	}
	$smo = New-Object Microsoft.SqlServer.Management.Smo.Server($conn)
	$smo
}
Function Invoke-SqlBackup {
	$dbbk = new-object ('Microsoft.SqlServer.Management.Smo.Backup')
	$dbbk.Action = [Microsoft.SqlServer.Management.Smo.BackupActionType]::Database
	$dbbk.BackupSetDescription = &quot;Full backup of &quot; + $database
	$dbbk.BackupSetName = $database + &quot; Backup&quot;
	$dbbk.Database = $database
	$dbbk.MediaDescription = &quot;Disk&quot;
	$device = &quot;$SourcePath\$bkpfile&quot;
	$dbbk.Devices.AddDevice($device, 'File')
	$smo = New-SMOconnection -server $SourceServer
	Try {
		$dbbk.SqlBackup($smo)
		$dbbk.Action = [Microsoft.SqlServer.Management.Smo.BackupActionType]::Log
		$dbbk.SqlBackup($smo)
		$smo.ConnectionContext.Disconnect()
	}
	Catch {
		$ex = $_.Exception
		Write-Output $ex.message
		$ex = $ex.InnerException
		while ($ex.InnerException)
		{
			Write-Output $ex.InnerException.message
			$ex = $ex.InnerException
		};
		continue
	}
	Finally {
		if ($smo.ConnectionContext.IsOpen -eq $true) {
			$smo.ConnectionContext.Disconnect()
		}
	}
}
Function Invoke-SqlRestore {
	Param([string]$filename)
	$restore = new-object Microsoft.SqlServer.Management.Smo.Restore
	$restore.Action = 'Database'
	$restore.Database = $database
	$device = &quot;$DestPath\$filename&quot;
	$restore.Devices.AddDevice($device, 'File')
    $restore.ReplaceDatabase = $true
    $restore.NoRecovery = $true
	$smo = New-SMOconnection -server $DestServer
	Try {
		$restore.SqlRestore($smo)
		$restore.Action = [Microsoft.SqlServer.Management.Smo.RestoreActionType]::Log
		$restore.FileNumber = 2
		$restore.SqlRestore($smo)
		$smo.ConnectionContext.Disconnect()
	}
	Catch {
		$ex = $_.Exception
		Write-Output $ex.message
		$ex = $ex.InnerException
		while ($ex.InnerException)
		{
			Write-Output $ex.InnerException.message
			$ex = $ex.InnerException
		};
		continue
	}
	Finally {
		if ($smo.ConnectionContext.IsOpen -eq $true) {
			$smo.ConnectionContext.Disconnect()
		}
	}
}
Function Set-Mirror {
	Param([string]$server,[string]$database,[string]$partner)
	$conn = &quot;Server=$server; Integrated Security=SSPI; Database=Master&quot;
	$cn = New-Object &quot;System.Data.SqlClient.SqlConnection&quot; $conn
	$cn.Open()
	$cmd = New-Object &quot;System.Data.SqlClient.SqlCommand&quot;
	$cmd.CommandType = [System.Data.CommandType]::Text

	$cmd.CommandText = &quot;ALTER DATABASE $database SET PARTNER = 'TCP://&quot; + $partner + &quot;:5022'&quot;
	$cmd.Connection = $cn
	$cmd.ExecuteNonQuery()
	$cn.Close()
	Trap {
		$ex = $_.Exception
		Write-Output $ex.message
		$ex = $ex.InnerException
		while ($ex.InnerException)
		{
			Write-Output $ex.InnerException.message
			$ex = $ex.InnerException
		};
		continue
	}
}
$srcUNC = Join-Path &quot;\\$($SourceServer.Split('\\')[0])&quot; $($SourcePath.Replace(':','$'))
if (-not(Test-Path $srcUNC)) { New-Item $srcUNC -ItemType directory | Out-Null}
$destUNC = Join-Path &quot;\\$($DestServer.Split('\\')[0])&quot; $($DestPath.Replace(':','$'))
if (-not(Test-Path $destUNC)) { New-Item $destUNC -ItemType directory | Out-Null}
$bkpfile = $($SourceServer.Replace(&quot;\&quot;, &quot;$&quot;)) + &quot;_&quot; + $database + &quot;_FULL_&quot; + $(get-date -format yyyyMMdd-HHmmss) + &quot;.bak&quot;
Invoke-SqlBackup
Copy-Item $(Join-Path $srcUNC $bkpfile) -Destination $destUNC -Verbose
Invoke-SqlRestore -filename $bkpfile
# Establish Mirroring from the mirrored database
Set-Mirror -server $DestServer -database $database -partner $($SourceServer.Split('\\')[0])
# Start the mirror
Set-Mirror -server $SourceServer -database $database -partner $($DestServer.Split('\\')[0])</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.webofwood.com/2010/07/29/powershell-sqlserver-mirroring/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Asynchronous Processing using Powershell Jobs</title>
		<link>http://www.webofwood.com/2010/03/17/asynchronous-powershell-jobs/</link>
		<comments>http://www.webofwood.com/2010/03/17/asynchronous-powershell-jobs/#comments</comments>
		<pubDate>Wed, 17 Mar 2010 14:48:57 +0000</pubDate>
		<dc:creator>John Wood</dc:creator>
				<category><![CDATA[Powershell]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[asynchronous]]></category>
		<category><![CDATA[job]]></category>
		<category><![CDATA[script]]></category>

		<guid isPermaLink="false">http://www.webofwood.com/?p=116</guid>
		<description><![CDATA[Powershell is a fantastic tool to use for management of multiple computers. I have been slowly converting many of our administrative functions from a hodge-podge mixture of CMD, BAT, VPS, Python, and Perl scripts. One daily administrative talks is copying a variety of backups from a variety of Windows servers to our data ’warehouse’ where [...]]]></description>
			<content:encoded><![CDATA[<p>Powershell is a fantastic tool to use for management of multiple computers. I have been slowly converting many of our administrative functions from a hodge-podge mixture of CMD, BAT, VPS, Python, and Perl scripts. One daily administrative talks is copying a variety of backups from a variety of Windows servers to our data ’warehouse’ where they are then copied to tape.</p>
<p>I recently found the “Jobs” cmdlets in Powershell V2.0. With “Jobs” you can asynchronously process multiple tasks (e.g. copying backups from many remote machines to data storage on the current local machine). In my case, running the copies synchronously results in the process spanning over to the next morning. Backups are stored daily. If a backup is taken on Wednesday, I can’t have it being stored in our warehouse under Thursday.</p>
<p><span id="more-116"></span></p>
<p>Using Powershell “Jobs”, I can accommodate copying all the backups within the daily timeframe. However, I did wrestle with using “Jobs” at first. Mainly because I couldn’t see what happened with a JOB on my console! The trick is to make sure you issue a Receive-Job cmdlet after a JOB has finished.</p>
<h3>Here a a couple of examples to try:</h3>
<p><span style="font-size: xx-small;">These example assume you are running Powershell V2.0 and you have enabled remoting on the machine your running this. Remoting does not have to be enabled on the remote servers but must be enabled on your local machine.</span></p>
<h5>Begin with a simple copy you know works.</h5>
<pre class="brush: ps"># Copies a directory and all files and sub-directories, I would
# suggest using something small to quickly see results
$source = "\\RemoteServer\d$\Backups # your remote path
$target = "W:\WoodyzTest"            # your local path
Copy-Item -Path $source -Destination $target -Recurse Verbose</pre>
<h5>Next, we’ll take the Copy-Item and put it in a Start-Job</h5>
<pre class="brush: ps">$source = "\\RemoteServer\d$\Backups # your remote path
$target = "W:\WoodyzTest"            # your local path
$job Start-Job -Scriptblock {
Copy-Item -Path $source -Destination $target -Recurse -Verbose
}
Wait-Job $job  # For this test, we’ll wait for the job to complete</pre>
<p>Run the above script, look at what is returned in the console, and then check to see of the copy worked.</p>
<p>Surprise! The directory was not copied! What happened? I have no idea because I did not see anything in the console. There were no error messages!</p>
<h5>OK, let’s now add a Receive-Job</h5>
<pre class="brush: ps">$source = "\\RemoteServer\d$\Backups # your remote path
$target = "W:\WoodyzTest"            # your local path
$job Start-Job -Scriptblock {Copy-Item -Path $source -Destination $target -Recurse -Verbose }
Wait-Job $job  # For this test, we’ll wait for the job to complete
Receive-Job $job  # will now display any results from the job</pre>
<p>Now what do you see on the console? We have yet another surprise! The console shows we have an error in our Copy-Item. But why? It worked before when we ran it outside of a JOB.</p>
<p>I took a SWAG at it and decided to try enclosing the entire original script inside the JOB Scriptblock:</p>
<h5>Here is the entire, final, working script:</h5>
<pre class="brush: ps">$job = Start-Job -ScriptBlock {
    $source = "\\Lcfltr01\d$\SQL Backups\lcfltr01"
    $target = "W:\WoodyzTest"
    Copy-Item -Path $source -Destination $target -Recurse -Verbose
}
Wait-Job $job
Receive-Job $job</pre>
<p>I have not read up on it yet, but deductive reasoning implies: because the JOB creates a new background process, the local variables are not available to the newly created thread. Makes sense to me.</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.webofwood.com/2010/03/17/asynchronous-powershell-jobs/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Easy Oracle Backup Deployment with Grid Control</title>
		<link>http://www.webofwood.com/2010/03/03/oracle-backup-deployment/</link>
		<comments>http://www.webofwood.com/2010/03/03/oracle-backup-deployment/#comments</comments>
		<pubDate>Wed, 03 Mar 2010 20:52:53 +0000</pubDate>
		<dc:creator>John Wood</dc:creator>
				<category><![CDATA[Oracle]]></category>
		<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://www.webofwood.com/?p=88</guid>
		<description><![CDATA[I recently installed GRID Control and while “playing around” with it, I discovered the fantastic capability to build a job once and deploy over many targets. I thought this is very cool after experiencing so many problems with Dbconsole. I found you can create a Job with minimal effort and deploy it to various targets with minimal [...]]]></description>
			<content:encoded><![CDATA[<p>I recently installed GRID Control and while “playing around” with it, I discovered the fantastic capability to build a job once and deploy over many targets. I thought this is very cool after experiencing so many problems with Dbconsole.</p>
<p>I found you can create a Job with minimal effort and deploy it to various targets with minimal effort. Database backups fit this mold exceptionally well. In my shop, all of our backups are rather routine and all share common properties: complete backup, daily at 6PM. All of our databases are small enough for complete backups rather than incremental.</p>
<p><span id="more-88"></span>If you want to quickly and easily build the backups for a dozen or more databases, you can try this process. I’m sure you will find it simple and effective. The basic steps involved are:</p>
<ol>
<li>Build a Job “template” and save it in the Job Library</li>
<li>Choose between submitting the Job for scheduling against multiple targets or submitting the Job for each target. <strong>This process</strong> submits the Job for each target. I chose this method because I believe it gives me more flexibility to accommodate future changes for individual target requirements. You can try both methods to see which best suits your needs.</li>
</ol>
<p>To start, bring up Oracle Grid Control and then choose the Jobs tab at the top. My screen is shown below. <strong>Now click on Job Library tab</strong> of that screen.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs000.jpg" target="_blank"><img class="aligncenter" style="display: inline; border-width: 0px;" title="jobs-000" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs000_thumb.jpg" border="0" alt="jobs-000" width="240" height="167" /></a></p>
<p>You should now be in the Job Library. Follow the numbered sequences on the next image below to <strong>create a new Library Job</strong></p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs001.jpg" target="_blank"><img class="aligncenter" style="display: inline; border-width: 0px;" title="jobs-001" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs001_thumb.jpg" border="0" alt="jobs-001" width="240" height="99" /></a></p>
<p>Fill in <strong>General</strong> information about the Job</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs002.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-002" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs002_thumb.jpg" border="0" alt="jobs-002" width="244" height="108" /></a></p>
<p>Key or paste in your RMAN script into the <strong>Parameters</strong> screen. I use a very generic script which uses all of the defaults I had previously established in Backup Settings for the target. A copy of my RMAN script is available here for cut &amp; paste.</p>
<pre class="brush: sql">run {
backup device type disk database;
backup device type disk archivelog all not backed up delete all input;
delete noprompt obsolete device type disk;
}</pre>
<p>After entering the script you’ll go on to specifying the Schedule. We won’t worry about the <em>Credentials</em> tab until we deploy to a target.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs004.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-004" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs004_thumb.jpg" border="0" alt="jobs-004" width="244" height="92" /></a></p>
<p>Set up your <strong>Schedule</strong>. Because we are deploying to individual targets, you will be able to change this later per target. In my case, all the targets have the same schedule so I can set it here and not worry about it when I deploy.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs007.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-007" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs007_thumb.jpg" border="0" alt="jobs-007" width="244" height="136" /></a></p>
<p><strong>Deploy</strong> your new Job by selecting it from the list and then clicking the <em>Submit</em> button.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs008.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-008" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs008_thumb.jpg" border="0" alt="jobs-008" width="244" height="142" /></a></p>
<p>Now you will see another Job creation screen with the General settings. However, this one is now in the Jobs category and not the Job Library. You may notice, the Job name has been filled in with the name from your Job Library along with a suffix (most likely .1).  This is the time to add a Target or Targets.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs010.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-010" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs010_thumb.jpg" border="0" alt="jobs-010" width="244" height="181" /></a></p>
<p>Select one or more from the <strong>Targets List.</strong> I chose to use one target for each deployment. However, you can deploy one Job to multiple targets at the same time. My preference is to run the deployment for each target thereby creating a Job for each.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs012.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-012" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs012_thumb.jpg" border="0" alt="jobs-012" width="244" height="185" /></a></p>
<p>We’re back to the <strong>General</strong> information screen of the Job creation. At this time I also change the suffix for the Job name to match the Instance name of my target.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs013.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-013" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs013_thumb.jpg" border="0" alt="jobs-013" width="244" height="112" /></a></p>
<p>The <strong>Credentials</strong> screen gives you the opportunity to choose which credentials you want to use. In my case I am using the preferred credentials which I had already set up for each target.</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs014.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-014" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs014_thumb.jpg" border="0" alt="jobs-014" width="244" height="122" /></a></p>
<p><strong>The final Job</strong> scheduled to run every day at 6PM according to the time of the target ( you could have targets in differing time-zones).</p>
<p style="text-align: center;"><a href="http://www.webofwood.com/wp-content/uploads/2010/03/jobs015.jpg"><img class="aligncenter" style="display: inline; border: 0px;" title="jobs-015" src="http://www.webofwood.com/wp-content/uploads/2010/03/jobs015_thumb.jpg" border="0" alt="jobs-015" width="244" height="125" /></a> </p>
<p style="text-align: left;">If you chose, as I did, to deploy to individual targets, you would now return to the Job Library, select your job, and click submit. This would be repeated for each target.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.webofwood.com/2010/03/03/oracle-backup-deployment/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Cycle Those SQL Server Logs</title>
		<link>http://www.webofwood.com/2010/02/15/cycle-those-sql-server-logs/</link>
		<comments>http://www.webofwood.com/2010/02/15/cycle-those-sql-server-logs/#comments</comments>
		<pubDate>Mon, 15 Feb 2010 21:21:04 +0000</pubDate>
		<dc:creator>John Wood</dc:creator>
				<category><![CDATA[.Net]]></category>
		<category><![CDATA[Powershell]]></category>
		<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[errorlog]]></category>
		<category><![CDATA[schedule]]></category>
		<category><![CDATA[script]]></category>

		<guid isPermaLink="false">http://www.webofwood.com/?p=62</guid>
		<description><![CDATA[Don’t you just hate it when you open one of your server logs in Management Studio and then you have to wait forever to review it because it never stops reading? I’ve done it enough times and decided to put an end to it or at least greatly reduce the incidence. Using Powershell and a [...]]]></description>
			<content:encoded><![CDATA[<p>Don’t you just hate it when you open one of your server logs in Management Studio and then you have to wait forever to review it because it never stops reading? I’ve done it enough times and decided to put an end to it or at least greatly reduce the incidence.</p>
<p>Using Powershell and a simple script to execute Sp_Cycle_Errorlog, I now have a weekly, Windows scheduled task which executes the sproc to cycle the logs for all my SQL Servers.</p>
<pre class="brush: ps">foreach ($svr in get-content D:\Scripts\Servers.TXT ){
    $svr
    Invoke-Expression 'SQLCMD -E -S $svr -Q "Exec Sp_Cycle_Errorlog"' | Out-Null
	}</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.webofwood.com/2010/02/15/cycle-those-sql-server-logs/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Linked Server 64bit Deficiency</title>
		<link>http://www.webofwood.com/2009/08/07/linked_server_64bit/</link>
		<comments>http://www.webofwood.com/2009/08/07/linked_server_64bit/#comments</comments>
		<pubDate>Fri, 07 Aug 2009 17:00:41 +0000</pubDate>
		<dc:creator>Woody</dc:creator>
				<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[Scripts]]></category>
		<category><![CDATA[2000]]></category>
		<category><![CDATA[2005]]></category>
		<category><![CDATA[32bit]]></category>
		<category><![CDATA[64bit]]></category>
		<category><![CDATA[linked server]]></category>
		<category><![CDATA[sproc]]></category>

		<guid isPermaLink="false">http://www.webofwood.com/2009/08/07/create-linked-server-view-of-sql-server-2000-32bit-on-64bit-sql-server-2005/</guid>
		<description><![CDATA[First off, I need to give recognition to Joel Mansford for his blog which gave me the answer to my problem. Connecting SQL Server 2005 x64 to SQL Server 7 (32bit) as a linked server!? After creating a linked server on a 64bit SQL Server 2005 instance, I then needed to create a view which [...]]]></description>
			<content:encoded><![CDATA[<p>First off, I need to give recognition to Joel Mansford for his blog which gave me the answer to my problem.<br />
<a href="http://joelmansford.wordpress.com/2007/08/10/connecting-sql-server-2005-x64-to-sql-server-7-32bit-as-a-linked-server/">Connecting SQL Server 2005 x64 to SQL Server 7 (32bit) as a linked server!? </a></p>
<p>After creating a linked server on a 64bit SQL Server 2005 instance, I then needed to create a view which referenced the linked server. The linked server is a SQL Server 2000 32bit instance. However, when I tried to create the view, I got this error:  <em>Cannot obtain the schema rowset &#8220;DBSCHEMA_TABLES_INFO&#8221; for OLE DB provider &#8220;SQLNCLI&#8221;.</em></p>
<p>This really proved to be a conundrum because I had just recently created the same linked server and view on another SQL 2005 instance. However, I had not yet connected the fact the 2005 instance was 32bit as opposed to the one I was now working on, which is 64bit.</p>
<p>I wrestled with it being a permissions issue for a while but ruled that out when I could not create the view even while using a domain admin account having authority of all the instances. A search on Google, using the above mentioned error message, turned up Joel&#8217;s blog. His specific problem was relative to SQL Server 7 but the answer applied to SQL Server 2000 also. He had found the original post of the ultimate solution and was good enough to include it in his blog which I have an excerpt here.</p>
<blockquote><p>I found an extremely helpful post by Marek Adamczuk at <a href="http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=62887&amp;SiteID=1">http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=62887&amp;SiteID=1</a>. Marek  explains the 32-bit editions are missing a stored procedure on the master database called <strong>sp_tables_info_rowset_64.</strong></p>
<p>Marek’s solution is to create a wrapper on the master database as follows (his code not mine):</p>
<pre class="brush: sql">create procedure sp_tables_info_rowset_64
    @table_name sysname,
    @table_schema sysname = null,
    @table_type nvarchar(255) = null
as
declare @Result int set @Result = 0
exec @Result = sp_tables_info_rowset
    @table_name,
    @table_schema,
    @table_type</pre>
</blockquote>
<p>It would appear the existing sproc does the same thing but just needs to be referenced using the 64bit name. Kudos to both Joel and to Marek for making this solution available!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.webofwood.com/2009/08/07/linked_server_64bit/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
