如何知道Entity Framework中数据库的物理大小?

时间:2012-08-20 01:35:35

标签: c# database entity-framework code-first

是否可以仅使用Entity Framework类的方法或属性来了解代码首先创建的数据库物理*.mdf文件大小(以字节为单位)?如果有可能,那该怎么做?

1 个答案:

答案 0 :(得分:4)

您可以通过执行sp_spaceused

来获取数据库大小
var ef = new EFContext();
var sqlConn = ef.Database.Connection as SqlConnection;
var cmd = new SqlCommand("sp_spaceused")
{
    CommandType = System.Data.CommandType.StoredProcedure,
    Connection = sqlConn as SqlConnection
};
var adp = new SqlDataAdapter(cmd);
var dataset = new DataSet();
sqlConn.Open();
adp.Fill(dataset);
sqlConn.Close();
//You will get:
//database_name database_size   unallocated space
//performance       1091.00 MB      456.00 MB
//
//reserved  data        index_size  unused
//557056 KB 540680 KB   10472 KB    5904 KB
Console.WriteLine(dataset.Tables[0].Rows[0][1]);