Rumah > pembangunan bahagian belakang > C++ > Bagaimana untuk Meluluskan Parameter Bernilai Jadual kepada Prosedur Tersimpan dalam Rangka Kerja Entiti?

Bagaimana untuk Meluluskan Parameter Bernilai Jadual kepada Prosedur Tersimpan dalam Rangka Kerja Entiti?

Patricia Arquette
Lepaskan: 2025-01-12 22:06:43
asal
342 orang telah melayarinya

How to Pass Table-Valued Parameters to Stored Procedures in Entity Framework?

Rangka Kerja Entiti menyimpan parameter nilai jadual prosedur

Rangka Kerja Entiti itu sendiri tidak menyokong secara langsung menghantar parameter bernilai jadual kepada prosedur yang disimpan. Walau bagaimanapun, penyelesaian boleh dilaksanakan menggunakan kaedah ObjectContext ExecuteStoreQuery .

Dalam kod di atas, terdapat kaedah ExecuteStoredProcedure biasa dalam repositori:

<code class="language-csharp">public IEnumerable<T> ExecuteStoredProcedure<T>(string procedureName, params object[] parameters)
{
    StringBuilder command = new StringBuilder();
    command.Append("EXEC ");
    command.Append(procedureName);
    command.Append(" ");

    // 为每个传入的参数添加占位符
    for (int i = 0; i < parameters.Length; i++)
    {
        if (i > 0)
            command.Append(",");

        command.Append("{" + i + "}");
    }

    return this.context.ExecuteStoreQuery<T>(command.ToString(), parameters);
}</code>
Salin selepas log masuk

Apabila menghantar parameter bernilai jadual menggunakan kaedah ini, anda mungkin mendapat ralat seperti "Parameter jenis jadual p6 mesti mempunyai nama jenis yang sah". Untuk menyelesaikan isu ini, anda mesti menentukan SqlDbType sebagai Structured dan tetapkan SqlParameter.TypeName kepada nama jenis yang ditentukan pengguna (UDT) dalam pangkalan data.

Walau bagaimanapun, walaupun dengan pengubahsuaian ini, anda mungkin masih menghadapi ralat yang berkaitan dengan sintaks yang tidak sah.

Kaedah sambungan tersuai

Kaedah sambungan tersuai bagi kelas

ObjectContext boleh memudahkan proses ini:

<code class="language-csharp">public static void ExecuteStoredProcedure(this ObjectContext context, string storedProcName, params object[] parameters)
{
    string command = "EXEC " + storedProcName + " @caseid, @userid, @warnings";

    context.ExecuteStoreCommand(command, parameters);
}</code>
Salin selepas log masuk

Kaedah sambungan ini membolehkan anda memanggil prosedur tersimpan terus dengan parameter bernilai jadual. Contoh penggunaan adalah seperti berikut:

<code class="language-csharp">var entities = new NewBusinessEntities();

var dt = new DataTable();
dt.Columns.Add("WarningCode");
dt.Columns.Add("StatusID");
dt.Columns.Add("DecisionID");
dt.Columns.Add("Criticality");

dt.Rows.Add("EO01", 9, 4, 0);
dt.Rows.Add("EO00", 9, 4, 0);
dt.Rows.Add("EO02", 9, 4, 0);

var caseId = new SqlParameter("caseid", SqlDbType.Int);
caseId.Value = 1;

var userId = new SqlParameter("userid", SqlDbType.UniqueIdentifier);
userId.Value = Guid.Parse("846454D9-DE72-4EF4-ABE2-16EC3710EA0F");

var warnings = new SqlParameter("warnings", SqlDbType.Structured);
warnings.Value = dt;
warnings.TypeName = "dbo.udt_Warnings";

entities.ExecuteStoredProcedure("usp_RaiseWarnings_rs", userId, warnings, caseId);</code>
Salin selepas log masuk

Sekatan

Apabila menggunakan kaedah sambungan ini atau kaedah tersuai yang serupa, sila pertimbangkan pengehadan berikut:

  • Parameter prosedur tersimpan mestilah teratur dan sepadan dengan parameter yang dihantar kepada kaedah sambungan.
  • Semua lajur dalam UDT mesti dinyatakan, walaupun ia mempunyai nilai lalai.

Atas ialah kandungan terperinci Bagaimana untuk Meluluskan Parameter Bernilai Jadual kepada Prosedur Tersimpan dalam Rangka Kerja Entiti?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan