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
Andy Löwen
2016-12-14
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
http://support.microsoft.com/kb/918992
DB-Projekte in Visual Studio - DB-Objekte hinzufügen
Nur DB-Objekte 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?
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?
- Die entsprechende Datei aus dem Projekt in einen anderen Ordner kopieren, zum Beispiel C:\Temp zur Aufbewahrung
- Das DB-Projekt öffnen und die Datei im Projektmappen-Explorer finden und aus dem Projekt ausschließen und diese Änderung einchecken
- Die Datei im Quellcodeverwaltungs-Explorer finden und löschen
- Das Löschen der Datei einchecken
- Jetzt in der Schemaansicht das Objekt wieder hinzufügen.
- Zur Überprüfung einen fehlerfreien Build durchführen
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
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);
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);
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);
Subscribe to:
Posts (Atom)