2016-12-14

Für "schöne" Reports: Umrechnung Pixel<->Inch<->cm

In Reporting Services (SSRS) rendert die Berichte in 96dpi (Dots per Inch). Um keinen Flatterrand oder ähnliches zu bekommen, müssen alle Größen und Positionsangaben alligned werden. Die Angaben müssen im Verhältnis von 96dpi in ganze Pixel umgerechnet werden können und die umgerechneten Pixel dürfen bei einer Division mit 3 keinen Rest ergeben.
Als eine kleine Hilfestellung anbei eine Excel-Datei für die Umrechnung von Pixel, Inch und CM.
SSRS Pixel-Inch-CM Umrechnen.xlsx

SQL-Logins zwischen zwei Servern kopieren

Folgender KB-Artikel beschreibt wie Logins von einem SQL-Server auf einen neuen SQL-Server samt Password und SID kopiert
 
http://support.microsoft.com/kb/918992

DB-Projekte in Visual Studio - DB-Objekte hinzufügen

Nur DB-Ob​jekte die in der Schemaansicht angezeigt werden, gehören zum Umfang der Datenbank und werden auch bei einem Deployment vorgesehen. Unabhängig davon ob ein vermeitliches DB-Objekt zwar als Datei im Projektmappen-Explorer angezeigt wird muss es deshalb nicht in der Schemaansicht sichtbar sein.
 
Wie kann das passieren? Es passiert häufig dann, wenn dem Projekt Objekte über den Projektmappen-Explorer als "vorhandenes Element" hinzugefügt werden. Die ausgewählte Datei ist dann im Projektmappen-Explorer sichtbar aber evtl. nicht in der Schemaansicht.
Wie behebt man den Fehler?
  1. Die entsprechende Datei aus dem Projekt in einen anderen Ordner kopieren, zum Beispiel C:\Temp zur Aufbewahrung
  2. Das DB-Projekt öffnen und die Datei im Projektmappen-Explorer finden und aus dem Projekt ausschließen und diese Änderung einchecken
  3. Die Datei im Quellcodeverwaltungs-Explorer finden und löschen
  4. Das Löschen der Datei einchecken
  5. Jetzt in der Schemaansicht das Objekt wieder hinzufügen.
  6. Zur Überprüfung einen fehlerfreien Build durchführen
Zum Schluss die Änderungen einchecken

Bufferpool leeren

DBCC DROPCLEANBUFFERS Verwenden Sie DBCC DROPCLEANBUFFERS, um Abfragen mit einem frischen Puffercache zu testen, ohne den Server herunterzufahren und neu zu starten.​

Plancache löschen

Löschen eines Abfrageplans im Plancache

USE AdventureWorks2008R2;

GO
 
 
SELECT * FROM Person.Address;

GO
 
 
SELECT plan_handle, st.text

FROM sys.dm_exec_cached_plans

CROSS APPLY sys.dm_exec_sql_text(plan_handle) AS st

WHERE text LIKE N'SELECT * FROM Person.Address%';

GO
  
Dies ist das Resultset.
plan_handle                                         text
--------------------------------------------------  -----------------------------
0x060006001ECA270EC0215D05000000000000000000000000 SELECT * FROM Person.Address;
(1 Zeile(n) betroffen)
 
 

-- Remove the specific plan from the cache.
DBCC FREEPROCCACHE (0x060006001ECA270EC0215D05000000000000000000000000);

GO

 
Löschen aller Pläne im Plancache
SELECT * FROM sys.dm_resource_governor_resource_pools;

GO
 
 
 
DBCC FREEPROCCACHE ('default');
GO

TOP 25 teuersten Abfragen

SELECT TOP (25)

qs.sql_handle,

qs.execution_count,

qs.total_worker_time AS Total_CPU,

total_CPU_inSeconds = --Converted from microseconds

qs.total_worker_time/1000000.00,

average_CPU_inSeconds = --Converted from microseconds

(qs.total_worker_time/1000000.00) / qs.execution_count,

qs.total_elapsed_time,

total_elapsed_time_inSeconds = --Converted from microseconds

qs.total_elapsed_time/1000000.00,

st.text,

qp.query_plan

FROM sys.dm_exec_query_stats AS qs

CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS st

CROSS apply sys.dm_exec_query_plan (qs.plan_handle) AS qp

ORDER BY qs.total_worker_time DESC OPTION (RECOMPILE);

TOP 25 teuersten Prozeduren

SELECT TOP (25)
p.name AS [SP Name],
qs.total_worker_time AS [TotalWorkerTime],
qs.total_worker_time/qs.execution_count AS [AvgWorkerTime],
qs.execution_count,
ISNULL(qs.execution_count/DATEDIFF(Second, qs.cached_time, GETDATE()), 0)
AS [Calls/Second],
qs.total_elapsed_time,
qs.total_elapsed_time/qs.execution_count AS [avg_elapsed_time],
qs.cached_time
FROM sys.procedures AS p WITH (NOLOCK)
INNER JOIN sys.dm_exec_procedure_stats AS qs WITH (NOLOCK)
ON p.[object_id] = qs.[object_id]
WHERE qs.database_id = DB_ID()
ORDER BY qs.total_worker_time DESC OPTION (RECOMPILE);