<?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>heckelmann.info &#187; T-SQL</title>
	<atom:link href="http://www.heckelmann.info/tag/t-sql/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.heckelmann.info</link>
	<description>Der tägliche Wahnsinn</description>
	<lastBuildDate>Wed, 21 Apr 2010 14:05:22 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Collation von Tabellenspalten</title>
		<link>http://www.heckelmann.info/2009/09/collation-von-tabellenspalten/</link>
		<comments>http://www.heckelmann.info/2009/09/collation-von-tabellenspalten/#comments</comments>
		<pubDate>Tue, 22 Sep 2009 13:44:57 +0000</pubDate>
		<dc:creator>Chris</dc:creator>
				<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[T-SQL]]></category>
		<category><![CDATA[Collation]]></category>

		<guid isPermaLink="false">http://www.heckelmann.info/?p=132</guid>
		<description><![CDATA[Hi,
nach langer Abwesendheit, hier nur ein kurzes Script zum auflisten der Collation aller Tabellen-Spalten in einer Datenbank.

SELECT name, collation_name
FROM sys.columns
WHERE OBJECT_ID IN (SELECT OBJECT_ID
FROM sys.objects WHERE type = 'U')

Gruß,
Chris
]]></description>
			<content:encoded><![CDATA[<p>Hi,</p>
<p>nach langer Abwesendheit, hier nur ein kurzes Script zum auflisten der Collation aller Tabellen-Spalten in einer Datenbank.</p>
<pre name="code" class="SQL">
SELECT name, collation_name
FROM sys.columns
WHERE OBJECT_ID IN (SELECT OBJECT_ID
FROM sys.objects WHERE type = 'U')
</pre>
<p>Gruß,</p>
<p>Chris</p>
]]></content:encoded>
			<wfw:commentRss>http://www.heckelmann.info/2009/09/collation-von-tabellenspalten/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>SQL Server Logins synchronisieren</title>
		<link>http://www.heckelmann.info/2009/06/sql-server-logins-synchronisieren/</link>
		<comments>http://www.heckelmann.info/2009/06/sql-server-logins-synchronisieren/#comments</comments>
		<pubDate>Wed, 03 Jun 2009 08:06:15 +0000</pubDate>
		<dc:creator>Chris</dc:creator>
				<category><![CDATA[Allgemein]]></category>
		<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[T-SQL]]></category>
		<category><![CDATA[Logins]]></category>
		<category><![CDATA[Sync]]></category>

		<guid isPermaLink="false">http://www.heckelmann.info/?p=98</guid>
		<description><![CDATA[Nachdem ich schon seit ein paar Wochen nichts geschrieben habe, wird es mal wieder Zeit.
Vor einigen Monaten haben wir auf der Arbeit unsere altes Cluster neu aufgesetzt, und den SQL Server auf neuer Hardware installiert. Nachdem wir massig SQL Logins und Windows Gruppen berechtigt hatten, stellte sich die Frage, wie wir diese Logins wieder auf <a href="http://www.heckelmann.info/2009/06/sql-server-logins-synchronisieren/" class="more-link">Mehr &#62;</a>]]></description>
			<content:encoded><![CDATA[<p>Nachdem ich schon seit ein paar Wochen nichts geschrieben habe, wird es mal wieder Zeit.</p>
<p>Vor einigen Monaten haben wir auf der Arbeit unsere altes Cluster neu aufgesetzt, und den SQL Server auf neuer Hardware installiert. Nachdem wir massig SQL Logins und Windows Gruppen berechtigt hatten, stellte sich die Frage, wie wir diese Logins wieder auf den Datenbanken berechtigen können, ohne uns durch jede Datenbank zu klickern.</p>
<p>Um die Logins anzulegen hatte ich bereits ein Script zur Hand, jedoch mußten die neuen Logins (neue SID) mit den Datenbanken synchronisiert werden. Hier habe ich auf der SQLServerCenteral zwei kleine aber sehr gute Helferscripte gefunden, welche jedem DBA das Leben erleichtern.</p>
<p>Zunächst das erste Script, welches alle nicht synchronen Logins auf dem Server ausliest:</p>
<pre name="code" class="SQL">
DECLARE @Collation varchar(100)
DECLARE @SQL VARCHAR(2000)

CREATE TABLE ##TempSync
(
DB_NME Varchar(50),
DBUserName varchar(50),
SysLoginName varchar(50)
)

SELECT @Collation = CONVERT(SYSNAME,DatabasePropertyEx('master','Collation'))

SET @SQL = 'USE [?]
SELECT ''?'' DB_NME,
       A.name DBUserName,
       B.loginname SysLoginName
 FROM sysusers A
      JOIN master.dbo.syslogins B
      ON A.name Collate ' + @Collation + ' = B.Name
      JOIN master.dbo.sysdatabases C
      ON C.Name = ''?''
 WHERE issqluser = 1
       AND (A.sid IS NOT NULL
       AND A.sid <> 0x0)
       AND suser_sname(A.sid) IS NULL
       AND (C.status &#038; 32) =0 --loading
       AND (C.status &#038; 64) =0 --pre recovery
       AND (C.status &#038; 128) =0 --recovering
       AND (C.status &#038; 256) =0 --not recovered
       AND (C.status &#038; 512) =0 --offline
       AND (C.status &#038; 1024) =0 --read only
 ORDER BY A.name'

INSERT into ##TempSync
EXEC sp_msforeachdb @SQL

SELECT * FROM ##TempSync

DROP TABLE ##TempSync
</pre>
<p>Und nun das Script, was alle Logins wieder synchronisiert</p>
<pre name="code" class="SQL">
DECLARE @Collation VARCHAR (100)
DECLARE @SQL VARCHAR(2000)

SELECT @Collation =CONVERT(SYSNAME,DatabasePropertyEx('master','Collation'))

SET @SQL = 'USE [?]
DECLARE @DBUserName varchar(50)
DECLARE @SysLoginName varchar(50)
DECLARE SyncDBLogins CURSOR FOR
 SELECT A.name DBUserName,
        B.loginname SysLoginName
 FROM sysusers A
      JOIN master.dbo.syslogins B
      ON A.name Collate ' + @Collation + ' = B.Name
      JOIN master.dbo.sysdatabases C
      ON C.Name = ''?''
 WHERE issqluser = 1
       AND (A.sid IS NOT NULL
       AND A.sid <> 0x0)
       AND suser_sname(A.sid) IS NULL
       AND (C.status &#038; 32) =0 --Loading
       AND (C.status &#038; 64) =0 --pre recovery
       AND (C.status &#038; 128) =0 --recovering
       AND (C.status &#038; 256) =0 --not recovered
       AND (C.status &#038; 512) =0 --offline
       AND (C.status &#038; 1024) =0 --read only
 ORDER BY A.name

OPEN SyncDBLogins
FETCH NEXT FROM SyncDBLogins
 INTO @DBUserName, @SysLoginName

WHILE @@FETCH_STATUS = 0
 BEGIN
    EXEC sp_change_users_login ''update_one'', @DBUserName, @SysLoginName

    FETCH NEXT FROM SyncDBLogins
    INTO @DBUserName, @SysLoginName
 END
CLOSE SyncDBLogins
DEALLOCATE SyncDBLogins
'
EXEC sp_msforeachdb @SQL
</pre>
<p>Orginal Artikel: <a href="http://go.xinox.net/52sceq">http://go.xinox.net/52sceq</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.heckelmann.info/2009/06/sql-server-logins-synchronisieren/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Logfile shrink Part II</title>
		<link>http://www.heckelmann.info/2009/04/logfile-shrink-part-ii/</link>
		<comments>http://www.heckelmann.info/2009/04/logfile-shrink-part-ii/#comments</comments>
		<pubDate>Wed, 01 Apr 2009 06:49:43 +0000</pubDate>
		<dc:creator>Chris</dc:creator>
				<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[T-SQL]]></category>
		<category><![CDATA[Logfile]]></category>
		<category><![CDATA[Schrink]]></category>

		<guid isPermaLink="false">http://www.heckelmann.info/?p=95</guid>
		<description><![CDATA[Ich habe mein kleines Script zum shrinken der Logfiles aktualisiert. Der Logische Filename des Logfiles wird nun nicht hart angegeben ([DBNAME]_Log) sondern aus der sys.database_files gelesen.
Hier der aktualisierte Code:

USE [DBNAME]
GO
DECLARE @LDF NVARCHAR(255)
SELECT @LDF=[name] FROM sys.database_files WHERE [type_desc]='LOG'
DBCC SHRINKFILE(@LDF, 1)
BACKUP LOG [DBNAME] WITH TRUNCATE_ONLY
DBCC SHRINKFILE(@LDF, 1)

]]></description>
			<content:encoded><![CDATA[<p>Ich habe mein kleines Script zum shrinken der Logfiles aktualisiert. Der Logische Filename des Logfiles wird nun nicht hart angegeben ([DBNAME]_Log) sondern aus der sys.database_files gelesen.</p>
<p>Hier der aktualisierte Code:</p>
<pre name="code" class="SQL">
USE [DBNAME]
GO
DECLARE @LDF NVARCHAR(255)
SELECT @LDF=[name] FROM sys.database_files WHERE [type_desc]='LOG'
DBCC SHRINKFILE(@LDF, 1)
BACKUP LOG [DBNAME] WITH TRUNCATE_ONLY
DBCC SHRINKFILE(@LDF, 1)
</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.heckelmann.info/2009/04/logfile-shrink-part-ii/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Thank God it&#8217;s Friday!</title>
		<link>http://www.heckelmann.info/2009/01/thank-god-its-friday/</link>
		<comments>http://www.heckelmann.info/2009/01/thank-god-its-friday/#comments</comments>
		<pubDate>Fri, 16 Jan 2009 12:08:21 +0000</pubDate>
		<dc:creator>Chris</dc:creator>
				<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[T-SQL]]></category>
		<category><![CDATA[Tools]]></category>

		<guid isPermaLink="false">http://www.heckelmann.info/?p=83</guid>
		<description><![CDATA[Und wieder einmal haben wir es geschafft, endlich Freitag! Ich wünsche allen Lesern ein schönes Wochenende!
Wenn ich so auf die Woche zurückblicke, ist das beste das eintreffen unserer Idera Lizenzen gewesen. Jetzt habe ich eine Version des SQL Admin Toolsets, welches ich jedem DBA nur empfehlen kann, da es für den Preis von 495 USD <a href="http://www.heckelmann.info/2009/01/thank-god-its-friday/" class="more-link">Mehr &#62;</a>]]></description>
			<content:encoded><![CDATA[<p>Und wieder einmal haben wir es geschafft, endlich Freitag! Ich wünsche allen Lesern ein schönes Wochenende!</p>
<div id="attachment_84" class="wp-caption alignright" style="width: 310px"><img class="size-medium wp-image-84" title="SQLAdminToolset" src="http://www.heckelmann.info/wp-content/uploads/2009/01/sqladmintoolset-300x184.jpg" alt="SQLAdminToolset" width="300" height="184" /><p class="wp-caption-text">SQLAdminToolset</p></div>
<p>Wenn ich so auf die Woche zurückblicke, ist das beste das eintreffen unserer Idera Lizenzen gewesen. Jetzt habe ich eine Version des <a href="http://www.idera.com/products/sqladmintoolset/default.aspx" target="_blank">SQL Admin Toolsets</a>, welches ich jedem DBA nur empfehlen kann, da es für den Preis von 495 USD auch für kleinere Betriebe erschwinglich ist und eine menge Arbeit einen abnimmt.</p>
<p>Hier ein kleiner Auszug der Funktionen:</p>
<ul>
<li>Abfragen über mehrere SQL Server</li>
<li>Clonen und Kopieren von Logins</li>
<li>Datenbanken über Server kopieren</li>
<li>Server inventarisieren</li>
<li>Patchlevel auslesen</li>
<li>u.v.m&#8230;</li>
</ul>
<p>Ich will jetzt nicht weiter darauf eingehen, da der Feierabend langsam näher rückt, aber wer mag kann sich auf der <a href="http://www.idera.com/products/sqladmintoolset/default.aspx" target="_blank">Herstellerseite</a> eine 14-Tage Testversion herunterladen und selbst ausgiebig testen.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.heckelmann.info/2009/01/thank-god-its-friday/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Ausgabe von sp_help_job in Temptable speichern</title>
		<link>http://www.heckelmann.info/2009/01/ausgabe-von-sp_help_job-in-temptable-speichern/</link>
		<comments>http://www.heckelmann.info/2009/01/ausgabe-von-sp_help_job-in-temptable-speichern/#comments</comments>
		<pubDate>Thu, 15 Jan 2009 08:02:05 +0000</pubDate>
		<dc:creator>Chris</dc:creator>
				<category><![CDATA[Allgemein]]></category>
		<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[T-SQL]]></category>
		<category><![CDATA[Openrowset]]></category>
		<category><![CDATA[sp_help_job]]></category>

		<guid isPermaLink="false">http://www.heckelmann.info/?p=76</guid>
		<description><![CDATA[Ich brauchte eine Übersicht von SQL Agent Jobs (Name, LastRunDate, Current Execution Status und LastRunOutcome), doch da die Job Hisorty auf 10 Tage auf diesem Server begrenzt ist, fällt der Ansatz über die Tabellen msdb.dbo.sysjobs  und msdb.dbo.sysjobhistory aus (siehe Beispiel).

select distinct [name] as 'Job Name',
	case [enabled] when 1 then 'Enabled' else 'Disabled' end as <a href="http://www.heckelmann.info/2009/01/ausgabe-von-sp_help_job-in-temptable-speichern/" class="more-link">Mehr &#62;</a>]]></description>
			<content:encoded><![CDATA[<p>Ich brauchte eine Übersicht von SQL Agent Jobs (Name, LastRunDate, Current Execution Status und LastRunOutcome), doch da die Job Hisorty auf 10 Tage auf diesem Server begrenzt ist, fällt der Ansatz über die Tabellen msdb.dbo.sysjobs  und msdb.dbo.sysjobhistory aus (siehe Beispiel).</p>
<pre name="code" class="SQL">
select distinct [name] as 'Job Name',
	case [enabled] when 1 then 'Enabled' else 'Disabled' end as 'Enabled',
	cast (ltrim(str(run_date))+' '+stuff(stuff(right('000000'+ltrim(str(run_time)), 6) , 3, 0, ':'), 6, 0, ':') as datetime) as 'Last Run',
	step_id as Step,
	case [h].[run_status]
		when 0 then 'Failed' else 'Success'
		end as 'Status'
from msdb.dbo.sysjobs         j
left join msdb.dbo.sysjobschedules s
	on j.job_id = s.job_id
LEFT join msdb.dbo.sysjobhistory h
	on j.job_id = h.job_id
where step_id = 0
     and h.instance_id in (select max(sh.instance_id)
				from msdb.dbo.sysjobs sj
				join msdb.dbo.sysjobhistory sh
					on sj.job_id = sh.job_id
				where h.step_id = 0
				group by sj.[name])
</pre>
<p>Die einzigste Möglichkeit von allen Jobs diese Werte zu ermitteln, ist über die Prozedur sp_help_job. Leider ist es nicht möglich das Ergebnis in eine TempTable umzuleiten (siehe Beispiel)</p>
<pre name="code" class="SQL">
insert into #TempJobTable
   execute sp_help_job
</pre>
<p>Dies Endet dann meist in folgender Fehlermeldung:</p>
<blockquote><p>Server: Msg 8164, Level 16, State 1, Procedure sp_get_composite_job_info, Line 67<br />
An INSERT EXEC statement cannot be nested.</p></blockquote>
<p>Nun bleibt nur noch der Weg über OPENROWSET (siehe Beispiel) was wunderbar funktioniert.</p>
<pre name="code" class="SQL">
SELECT * INTO #JobInfo
FROM OPENROWSET('sqloledb', 'server=(local);trusted_connection=yes', 'set fmtonly off exec msdb.dbo.sp_help_job')
Select
[name],
cast(ltrim(str(last_run_date))+' '+stuff(stuff(right('000000'+ltrim(str(last_run_time)), 6) , 3, 0, ':'), 6, 0, ':') as NVARCHAR(255)) as 'Last Run',
CASE [current_execution_status]
	WHEN 1 THEN 'Executing'
	WHEN 2 THEN 'Waiting For Thread'
	WHEN 3 THEN 'Between Retries'
	WHEN 4 THEN 'Idle'
	WHEN 5 THEN 'Suspended'
	WHEN 7 THEN 'PerformingCompletion'
	ELSE 'Unknown'
	END AS Status
, CASE [last_run_outcome]
	WHEN 0 THEN 'Failed'
	WHEN 1 THEN 'Success'
	ELSE 'Unknown'
	END AS Result
from #JobInfo
ORDER BY [name]
DROP TABLE #JobInfo
</pre>
]]></content:encoded>
			<wfw:commentRss>http://www.heckelmann.info/2009/01/ausgabe-von-sp_help_job-in-temptable-speichern/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>T-SQL Script zum shrinken des Logfiles</title>
		<link>http://www.heckelmann.info/2009/01/t-sql-script-zum-shrinken-des-logfiles/</link>
		<comments>http://www.heckelmann.info/2009/01/t-sql-script-zum-shrinken-des-logfiles/#comments</comments>
		<pubDate>Wed, 07 Jan 2009 08:15:09 +0000</pubDate>
		<dc:creator>Chris</dc:creator>
				<category><![CDATA[SQL Server]]></category>
		<category><![CDATA[T-SQL]]></category>
		<category><![CDATA[Logfile]]></category>

		<guid isPermaLink="false">http://www.heckelmann.info/?p=65</guid>
		<description><![CDATA[Hier ein kleines T-SQL Script, welches ich verwende, um Logfiles zu shrinken.

USE [DBName]
GO
DBCC SHRINKFILE([DBName]_log, 1)
BACKUP LOG [DBName] WITH TRUNCATE_ONLY
DBCC SHRINKFILE([DBName]_log, 1)

Einfach [DBName] in den gewünschen Datenbanknamen ersetzen.
]]></description>
			<content:encoded><![CDATA[<p>Hier ein kleines T-SQL Script, welches ich verwende, um Logfiles zu shrinken.</p>
<pre name="code" class="SQL">
USE [DBName]
GO
DBCC SHRINKFILE([DBName]_log, 1)
BACKUP LOG [DBName] WITH TRUNCATE_ONLY
DBCC SHRINKFILE([DBName]_log, 1)
</pre>
<p>Einfach [DBName] in den gewünschen Datenbanknamen ersetzen.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.heckelmann.info/2009/01/t-sql-script-zum-shrinken-des-logfiles/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
