7

我已经下载了 Glimpse 和 Glimpse.ADO 扩展并将其安装在我的测试实例上。

我以为我会捕获任何已执行的 sql,但它似乎没有以我们编写代码的方式捕获命令。

        using (var conn = new SqlConnection(cString))
        {
            conn.Open();
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = conn;
            cmd.CommandText = "Select count(*) from table";
            cmd.CommandType = CommandType.Text;

            txtResult2.Text = cmd.ExecuteScalar().ToString();
            conn.Close();
        }

我可以让它从测试页面提供信息,其中的 sql 代码编写如下:

        var factory =DbProviderFactories.GetFactory(cString.ProviderName);
        using (var connection = factory.CreateConnection())
        {
            connection.ConnectionString = connectionString.ConnectionString;
            connection.Open();

            using (var command = connection.CreateCommand())
            {
                command.CommandText = "SELECT COUNT(*) FROM table";
                command.CommandType = CommandType.Text;
                txtResult1.Text = command.ExecuteScalar().ToString();
            }
        }

但是,如果我只能使用此 dbProviderFactories 方法捕获数据,我的代码中有太多地方需要更改。

有没有办法让 Glimpse.ADO 与 System.Data.SqlClient.SqlConnection 类一起工作?是否有另一个适用于此命名空间的 Glimpse 扩展?

有没有另一种方法来解决这个问题?

4

2 回答 2

6

我同意@StriplingWarrior,利用提供者工厂将使您的代码更加干燥并遵循最佳实践。DbProviderFactories确实是执行此操作的最佳方法,并且您的代码不会显式依赖 Glimpse。

但是,如果您真的想继续使用现有的应用程序代码,Glimpse 将通过以下更改为您提供支持:

using (var conn = new GlimpseDbConnection(new SqlConnection(cString))
{
    conn.Open();
    DbCommand cmd = conn.CreateCommand();
    cmd.CommandText = "Select count(*) from table";
    cmd.CommandType = CommandType.Text;

    txtResult2.Text = cmd.ExecuteScalar().ToString();
    conn.Close();
}

在上面的示例中,命令是使用CreateCommand()方法创建的,这消除了将命令与连接关联的需要。

或者,您也可以像这样显式创建命令:

conn.Open();
DbCommand cmd = new GlimpseDbCommand(new SqlCommand());
cmd.Connection = conn;
cmd.CommandText = "Select count(*) from table";
cmd.CommandType = CommandType.Text;

最后,?当您选择选项卡时,单击 Glimpse UI 中的图标,或访问我们在getGlimpse.com上的SQL 文档,可以获得有关 SQL 选项卡的更多文档。(我会将此信息添加到该页面以供将来参考。

于 2013-04-30T09:52:22.453 回答
1

在 Glimpse 网站的问题部分...

让 Glimpse 使用手动创建的 SQL 连接/命令

http://getglimpse.com/Docs/Manual-ADO-Integration

于 2015-09-07T13:08:10.353 回答