Server.ServiceMasterKey Server.ServiceMasterKey Server.ServiceMasterKey Property


Gets the service master key associated with the instance of SQL Server.

 property Microsoft::SqlServer::Management::Smo::ServiceMasterKey ^ ServiceMasterKey { Microsoft::SqlServer::Management::Smo::ServiceMasterKey ^ get(); };
[Microsoft.SqlServer.Management.Sdk.Sfc.Metadata.SfcObject(Microsoft.SqlServer.Management.Sdk.Sfc.Metadata.SfcObjectRelationship.Object, Microsoft.SqlServer.Management.Sdk.Sfc.Metadata.SfcObjectCardinality.One)]
public Microsoft.SqlServer.Management.Smo.ServiceMasterKey ServiceMasterKey { get; }
Public ReadOnly Property ServiceMasterKey As ServiceMasterKey
Property Value

A ServiceMasterKey object that specifies the service master key associated with the instance of SQL Server.


Visual Basic

'Connect to the local, default instance of SQL Server.  
Dim srv As Server  
srv = New Server  
'Reference the service master key.  
Dim smskey As ServiceMasterKey  
smskey = srv.ServiceMasterKey  
'Regenerate the encryption on the service master key.  


$srv = new-object Microsoft.SqlServer.Management.Smo.Server("(local)")  
$smskey = $srv.ServiceMasterKey  


The ServiceMasterKey property points to the ServiceMasterKey class. This represents the service master key, which is the top layer in the encryption hierarchy. The service master key is used to encrypt all the lower layers of the encryption hierarchy, such as database master keys, certificates, and asymmetric and symmetric keys.

The service master key is automatically generated the first time encryption is required on the instance of SQL Server. The service master key is generated by Windows and secured by the Windows data protection API. It can be decrypted only by the Windows service account under which it was created, or by a user who knows both the service account name and its password. Therefore, if you change the Windows account under which the SQL Server service runs, you must also enable decryption of the service master key by the new account.

Applies to