web-dev-qa-db-ja.com

エンティティフレームワークでストアドプロシージャを使用する

私はasp.net mvc 5とEntity FrameworkでC#を使用しています...機能用のモデルクラスとドメインクラスがあります...今、ストアドプロシージャを使用する必要があります...これは動きに苦労しています。

私は最初に既存のデータベースのコードをフォローしており、そこに書かれたプロシージャを保存しています。私の質問は、Webアプリケーションでそのストアドプロシージャを呼び出す方法です。

ストアドプロシージャ:

ALTER PROCEDURE [dbo].[GetFunctionByID](
    @FunctionId INT
)
AS
BEGIN
    SELECT * 
    FROM Functions As Fun
    WHERE Function_ID = @FunctionId
END

ドメインクラス:

 public class Functions
 {
    public Functions()
    {
    }

    public int Function_ID { get; set; }
    public string Title { get; set; }
    public int Hierarchy_level { get; set; }
}

機能モデル:

[Table("Functions")]
public class App_Functions
{
    public App_Functions()
    {
    }

    [Key]
    public int Function_ID { get; set; }

    [StringLength(50)]
    [Required]
    public string Title { get; set; }

    public int Hierarchy_level { get; set; }
    //public virtual ICollection<App_Controllers> App_Controllers { get; set; }*/
}

BaseContext:

public class BaseContext<TContext> : DbContext where TContext : DbContext
{
    static BaseContext()
    {
        Database.SetInitializer<TContext>(null);
    }

    protected BaseContext()
        : base("name = ApplicationDbConnection")
    { }
}

関数コンテキスト:

public class FunctionsContext : BaseContext<FunctionsContext>
{
    public DbSet<App_Functions> Functions { get; set; }
}
34
Toxic

以下のようなすべてのストアドプロシージャプロパティを含むモデルクラスを作成する必要があります。また、Entity Frameworkモデルクラスには主キーが必要なので、Guidを使用して偽のキーを作成できます。

public class GetFunctionByID
{
    [Key]
    public Guid? GetFunctionByID { get; set; }

    // All the other properties.
}

次に、GetFunctionByIDモデルクラスをDbContextに登録します。

public class FunctionsContext : BaseContext<FunctionsContext>
{
    public DbSet<App_Functions> Functions { get; set; }
    public DbSet<GetFunctionByID> GetFunctionByIds {get;set;}
}

ストアドプロシージャを呼び出すときは、以下を参照してください。

var functionId = yourIdParameter;
var result =  db.Database.SqlQuery<GetFunctionByID>("GetFunctionByID @FunctionId", new SqlParameter("@FunctionId", functionId)).ToList());
40
Lin

SqlQueryを使用してストアドプロシージャを呼び出すことができます( here を参照)

// Prepare the query
var query = context.Functions.SqlQuery(
    "EXEC [dbo].[GetFunctionByID] @p1", 
    new SqlParameter("p1", 200));

// add NoTracking() if required

// Fetch the results
var result = query.ToList();
10
qujck

ストアドプロシージャをインポートした後、ストアドプロシージャのオブジェクトを作成して、関数のようなパラメータを渡します。

using (var entity = new FunctionsContext())
{
   var DBdata = entity.GetFunctionByID(5).ToList<Functions>();
}

または、SqlQueryを使用することもできます

using (var entity = new FunctionsContext())
{
    var Parameter = new SqlParameter {
                     ParameterName = "FunctionId",
                     Value = 5
            };

    var DBdata = entity.Database.SqlQuery<Course>("exec GetFunctionByID @FunctionId ", Parameter).ToList<Functions>();
}
9
user2854731

シンプル。エンティティをインスタンス化し、オブジェクトに設定して、コントローラーのビューに渡します。

enter image description here

エンティティ

VehicleInfoEntities db = new VehicleInfoEntities();

ストアドプロシージャ

dbo.prcGetMakes()

または

ストアドプロシージャのかっこ内のパラメータを追加できます()

dbo.prcGetMakes( "BMW")

コントローラー

public class HomeController : Controller
{
    VehicleInfoEntities db = new VehicleInfoEntities();

    public ActionResult Index()
    {
        var makes = db.prcGetMakes(null);

        return View(makes);
    }
}
0
Jason Ebersey

//コンテキストにテナントを追加して、プロシージャが返すものを用意します! AddTenentsToContext(Context);

    // ACT
    // Get the results by calling the stored procedure from the context extention method 
    var results = Context.ExecuteStoredProcedure(procedure);

    // ASSERT
    Assert.AreEqual(expectedCount, results.Count);
}
0
gsgsgs

Mindless passenger には、次のようなエンティティフレームワークからストアドプロシージャを呼び出すことができるプロジェクトがあります。

using (testentities te = new testentities())
{
    //-------------------------------------------------------------
    // Simple stored proc
    //-------------------------------------------------------------
    var parms1 = new testone() { inparm = "abcd" };
    var results1 = te.CallStoredProc<testone>(te.testoneproc, parms1);
    var r1 = results1.ToList<TestOneResultSet>();
}

...そして、私は ストアドプロシージャフレームワークhere )に取り組んでいます。これは、以下に示すテストメソッドのいずれかで呼び出すことができます...

[TestClass]
public class TenantDataBasedTests : BaseIntegrationTest
{
    [TestMethod]
    public void GetTenantForName_ReturnsOneRecord()
    {
        // ARRANGE
        const int expectedCount = 1;
        const string expectedName = "Me";

        // Build the paraemeters object
        var parameters = new GetTenantForTenantNameParameters
        {
            TenantName = expectedName
        };

        // get an instance of the stored procedure passing the parameters
        var procedure = new GetTenantForTenantNameProcedure(parameters);

        // Initialise the procedure name and schema from procedure attributes
        procedure.InitializeFromAttributes();

        // Add some tenants to context so we have something for the procedure to return!
        AddTenentsToContext(Context);

        // ACT
        // Get the results by calling the stored procedure from the context extention method 
        var results = Context.ExecuteStoredProcedure(procedure);

        // ASSERT
        Assert.AreEqual(expectedCount, results.Count);
    }
}

internal class GetTenantForTenantNameParameters
{
    [Name("TenantName")]
    [Size(100)]
    [ParameterDbType(SqlDbType.VarChar)]
    public string TenantName { get; set; }
}

[Schema("app")]
[Name("Tenant_GetForTenantName")]
internal class GetTenantForTenantNameProcedure
    : StoredProcedureBase<TenantResultRow, GetTenantForTenantNameParameters>
{
    public GetTenantForTenantNameProcedure(
        GetTenantForTenantNameParameters parameters)
        : base(parameters)
    {
    }
}

これらの2つのアプローチのいずれかが良い場合は?

0
Dib