Fix database debugging tools
This commit is contained in:
@@ -5,6 +5,7 @@ using System.Data.SqlClient;
|
||||
using System.Data.SqlServerCe;
|
||||
using System.Linq;
|
||||
using MySql.Data.MySqlClient;
|
||||
using StackExchange.Profiling.Data;
|
||||
using Umbraco.Core.Composing;
|
||||
using Umbraco.Core.Logging;
|
||||
using Umbraco.Core.Persistence.FaultHandling;
|
||||
@@ -78,18 +79,13 @@ namespace Umbraco.Core.Persistence
|
||||
/// OnConnectionOpened); this unwraps and returns the original database connection.</remarks>
|
||||
internal static IDbConnection UnwrapUmbraco(this IDbConnection connection)
|
||||
{
|
||||
IDbConnection unwrapped;
|
||||
|
||||
var c = connection;
|
||||
var unwrapped = connection;
|
||||
IDbConnection c;
|
||||
do
|
||||
{
|
||||
unwrapped = c;
|
||||
|
||||
var profiled = unwrapped as StackExchange.Profiling.Data.ProfiledDbConnection;
|
||||
if (profiled != null) unwrapped = profiled.InnerConnection;
|
||||
|
||||
var retrying = unwrapped as RetryDbConnection;
|
||||
if (retrying != null) unwrapped = retrying.Inner;
|
||||
c = unwrapped;
|
||||
if (unwrapped is ProfiledDbConnection profiled) unwrapped = profiled.InnerConnection;
|
||||
if (unwrapped is RetryDbConnection retrying) unwrapped = retrying.Inner;
|
||||
|
||||
} while (c != unwrapped);
|
||||
|
||||
@@ -100,22 +96,23 @@ namespace Umbraco.Core.Persistence
|
||||
{
|
||||
try
|
||||
{
|
||||
if (connection is SqlConnection)
|
||||
switch (connection)
|
||||
{
|
||||
var builder = new SqlConnectionStringBuilder(connection.ConnectionString);
|
||||
return $"DataSource: {builder.DataSource}, InitialCatalog: {builder.InitialCatalog}";
|
||||
}
|
||||
|
||||
if (connection is SqlCeConnection)
|
||||
{
|
||||
var builder = new SqlCeConnectionStringBuilder(connection.ConnectionString);
|
||||
return $"DataSource: {builder.DataSource}";
|
||||
}
|
||||
|
||||
if (connection is MySqlConnection)
|
||||
{
|
||||
var builder = new MySqlConnectionStringBuilder(connection.ConnectionString);
|
||||
return $"Server: {builder.Server}, Database: {builder.Database}";
|
||||
case SqlConnection _:
|
||||
{
|
||||
var builder = new SqlConnectionStringBuilder(connection.ConnectionString);
|
||||
return $"DataSource: {builder.DataSource}, InitialCatalog: {builder.InitialCatalog}";
|
||||
}
|
||||
case SqlCeConnection _:
|
||||
{
|
||||
var builder = new SqlCeConnectionStringBuilder(connection.ConnectionString);
|
||||
return $"DataSource: {builder.DataSource}";
|
||||
}
|
||||
case MySqlConnection _:
|
||||
{
|
||||
var builder = new MySqlConnectionStringBuilder(connection.ConnectionString);
|
||||
return $"Server: {builder.Server}, Database: {builder.Database}";
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
|
||||
Reference in New Issue
Block a user