<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki.wingeav.de/index.php?action=history&amp;feed=atom&amp;title=SQL_Stored_Procedure_mit_Zertifikat</id>
	<title>SQL Stored Procedure mit Zertifikat - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.wingeav.de/index.php?action=history&amp;feed=atom&amp;title=SQL_Stored_Procedure_mit_Zertifikat"/>
	<link rel="alternate" type="text/html" href="https://wiki.wingeav.de/index.php?title=SQL_Stored_Procedure_mit_Zertifikat&amp;action=history"/>
	<updated>2026-04-17T16:22:58Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in MyWiki</subtitle>
	<generator>MediaWiki 1.45.3</generator>
	<entry>
		<id>https://wiki.wingeav.de/index.php?title=SQL_Stored_Procedure_mit_Zertifikat&amp;diff=221&amp;oldid=prev</id>
		<title>Rueling am 7. November 2018 um 12:00 Uhr</title>
		<link rel="alternate" type="text/html" href="https://wiki.wingeav.de/index.php?title=SQL_Stored_Procedure_mit_Zertifikat&amp;diff=221&amp;oldid=prev"/>
		<updated>2018-11-07T12:00:29Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Benötigt ein Benutzer Rechte auf System Views oder System Tabellen kann man ihm den Zugriff darauf über eine Stored Procedure gewähren. &amp;lt;br&amp;gt;&lt;br /&gt;
Damit hat der Benutzer nur das spezifische Recht, das in der Stored Procedure verwendet wird und benötigt keine SA oder &amp;quot;VIEW SERVER STATE&amp;quot; Rechte&lt;br /&gt;
Die Stored Procedure bekommt ein CERTIFICATE LOGIN und dieser Login bekommt das SA oder VIEW SERVER STATE Recht&lt;br /&gt;
Der Benutzer bekommt nur das Recht, die Stored Procedure auszuführen und diese wird dann als der CERTIFICATE LOGIN ausgeführt&lt;br /&gt;
&lt;br /&gt;
Um das einzurichten, wechselt man in die master Datenbank:&lt;br /&gt;
 USE master&lt;br /&gt;
 GO&lt;br /&gt;
&lt;br /&gt;
Erstellt die Stored Procedure - in diesem Fall wird eine System View verwendet, die nur mit VIEW SERVER STATE Rechten funktioniert&lt;br /&gt;
 CREATE PROC [sp_dm_tran_session_transactions] AS&lt;br /&gt;
 BEGIN&lt;br /&gt;
    SELECT COUNT(*) &lt;br /&gt;
      FROM SYS.DM_TRAN_SESSION_TRANSACTIONS&lt;br /&gt;
      WHERE IS_USER_TRANSACTION = 1&lt;br /&gt;
 END;&lt;br /&gt;
 GO&lt;br /&gt;
&lt;br /&gt;
Erstellt das Zertifikat und sichert es mit einem Passwort&lt;br /&gt;
 CREATE CERTIFICATE crt_dm_tran_session_transactions&lt;br /&gt;
     ENCRYPTION BY PASSWORD= &amp;#039;&amp;lt;PASSWORT&amp;gt;&amp;#039;&lt;br /&gt;
     WITH SUBJECT =&amp;#039;Certificate zum Abrufen von SYS.DM_TRAN_SESSION_TRANSACTIONS&amp;#039;,&lt;br /&gt;
     START_DATE = &amp;#039;20181104&amp;#039;,EXPIRY_DATE = &amp;#039;20501105&amp;#039;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Jetzt wird der LOGIN mit dem Zertifikat erstellt. Es wird kein User in der master Datenbank erstellt, sondern nur der LOGIN&lt;br /&gt;
 CREATE LOGIN user_dm_tran_session_transactions FROM CERTIFICATE crt_dm_tran_session_transactions&lt;br /&gt;
&lt;br /&gt;
Nun bekommt der CERTIFICATE LOGIN das Recht für VIEW SERVER STATE&lt;br /&gt;
 GRANT VIEW SERVER STATE TO user_dm_tran_session_transactions&lt;br /&gt;
&lt;br /&gt;
Die Signatur wird der Stored Proecdure zugewiesen&lt;br /&gt;
 ADD SIGNATURE TO [sp_dm_tran_session_transactions] BY CERTIFICATE crt_dm_tran_session_transactions&lt;br /&gt;
        WITH PASSWORD =&amp;#039;&amp;lt;PASSWORT&amp;gt;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Als letztes gibt man dem Benutzer das EXECUTE Rechte für die Stored Procedure&lt;br /&gt;
 GRANT EXECUTE ON sp_dm_tran_session_transactions TO meinUser&lt;/div&gt;</summary>
		<author><name>Rueling</name></author>
	</entry>
</feed>