Quando un client si connette a un'istanza di SQL Server senza specificare un contesto di database, viene usato il database predefinito per il relativo account di accesso. Se questo database non è disponibile, viene visualizzato il messaggio precedente.
Quando un client si connette a un'istanza di SQL Server senza specificare un contesto di database, viene usato il database predefinito per il relativo account di accesso. Se questo database non è disponibile, viene visualizzato il messaggio precedente.
Nota: se l'account di accesso è un membro di uno o più gruppi Windows definiti anche come account di accesso in SQL Server, è possibile che per uno di questi gruppi venga utilizzato il database predefinito. Non esiste un metodo affidabile per stabilire quale dei database predefiniti verrà scelto durante un tentativo di accesso. È pertanto importante controllare l'appartenenza ai gruppi per l'account di accesso, quindi verificare che tutti i database predefiniti impostati per i gruppi siano disponibili.
È necessario rendere accessibile il database predefinito o evitare di usare tale database. Alcune delle opzioni possibili sono:
Per altre informazioni sui database predefiniti, vedere "sp_defaultdb" nella documentazione online e l'articolo 307864 della Microsoft Knowledge Base.
Cambiare la stringa di connessione in modo da specificare sempre un determinato database.
Verificare che il database predefinito per ogni account di accesso esista e sia accessibile. Esaminare il log degli errori di SQL Server per stabilire perché un determinato database non è accessibile.
Usare uno strumento come OSQL per specificare un determinato database durante la connessione iniziale. Una volta connessi, eseguire sp_defaultdb per cambiare il database predefinito per l'account di accesso e impostare un database accessibile.
Accedere con un account membro del ruolo predefinito del server sysadmin o securityadmin ed eseguire sp_defaultdb per impostare un database accessibile come database predefinito per l'account di accesso. Per altre informazioni sui database predefiniti, vedere "sp_defaultdb" nella documentazione online e l'articolo 307864 della Microsoft Knowledge Base.
Nome | Descrizione | Valore predefinito |
Abilitato | Abilita o disabilita il flusso di lavoro. | Sì |
Priorità | Definisce la priorità dell'avviso. | 1 |
Gravità | Definisce la gravità dell'avviso. | 2 |
Target | Microsoft.SQLServer.2016.DBEngine | ||
Category | EventCollection | ||
Enabled | True | ||
Event_ID | 4064 | ||
Event Source | $Target/Property[Type="SQL2016Core!Microsoft.SQLServer.2016.DBEngine"]/ServiceName$ | ||
Alert Generate | True | ||
Alert Severity | Error | ||
Alert Priority | Normal | ||
Remotable | True | ||
Alert Message |
| ||
Event Log | Application | ||
Comment | Mom2016ID='{4FFA6A6A-3E49-468E-8C4A-DF5029908802}';MOM2016GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74} |
ID | Module Type | TypeId | RunAs |
---|---|---|---|
_F6DA1507_12AF_11D3_AB21_00A0C98620CE_ | DataSource | Microsoft.Windows.EventProvider | Default |
GenerateAlert | WriteAction | System.Health.GenerateAlert | Default |
<Rule ID="Microsoft.SQLServer.2016.Cannot_open_user_default_database._Login_failed_1_5_Rule" Target="SQL2016Core!Microsoft.SQLServer.2016.DBEngine" Enabled="true" ConfirmDelivery="true" Remotable="true" Comment="Mom2016ID='{4FFA6A6A-3E49-468E-8C4A-DF5029908802}';MOM2016GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74}">
<Category>EventCollection</Category>
<DataSources>
<DataSource ID="_F6DA1507_12AF_11D3_AB21_00A0C98620CE_" Comment="{F6DA1507-12AF-11D3-AB21-00A0C98620CE}" TypeID="Windows!Microsoft.Windows.EventProvider">
<ComputerName>$Target/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ComputerName>
<LogName>Application</LogName>
<Expression>
<And>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>PublisherName</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>$Target/Property[Type="SQL2016Core!Microsoft.SQLServer.2016.DBEngine"]/ServiceName$</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>EventDisplayNumber</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>4064</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
</And>
</Expression>
</DataSource>
</DataSources>
<WriteActions>
<WriteAction ID="GenerateAlert" TypeID="SystemHealth!System.Health.GenerateAlert">
<Priority>1</Priority>
<Severity>2</Severity>
<AlertMessageId>$MPElement[Name="Microsoft.SQLServer.2016.Cannot_open_user_default_database._Login_failed_1_5_Rule.AlertMessage"]$</AlertMessageId>
<AlertParameters>
<AlertParameter1>$Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue/>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>