sql >> Database teknologi >  >> RDS >> Oracle

Kalder du Oracles lagrede procedure fra C#?

Besøg venligst dette ODP-websted, som er oprettet af oracle for Microsoft OracleClient-udviklere:http://www.oracle.com/technetwork/topics/dotnet/index-085703.html

Nedenfor er også en prøvekode, der kan få dig i gang med at kalde en lagret procedure fra C# til Oracle. PKG_COLLECTION.CSP_COLLECTION_HDR_SELECT er den lagrede procedure bygget på Oracle, der accepterer parametrene PUNIT, POFFICE, PRECEIPT_NBR og returnerer resultatet i T_CURSOR.

using Oracle.DataAccess;
using Oracle.DataAccess.Client;

public DataTable GetHeader_BySproc(string unit, string office, string receiptno)
{
    using (OracleConnection cn = new OracleConnection(DatabaseHelper.GetConnectionString()))
    {
        OracleDataAdapter da = new OracleDataAdapter();
        OracleCommand cmd = new OracleCommand();
        cmd.Connection = cn;
        cmd.InitialLONGFetchSize = 1000;
        cmd.CommandText = DatabaseHelper.GetDBOwner() + "PKG_COLLECTION.CSP_COLLECTION_HDR_SELECT";
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.Add("PUNIT", OracleDbType.Char).Value = unit;
        cmd.Parameters.Add("POFFICE", OracleDbType.Char).Value = office;
        cmd.Parameters.Add("PRECEIPT_NBR", OracleDbType.Int32).Value = receiptno;
        cmd.Parameters.Add("T_CURSOR", OracleDbType.RefCursor).Direction = ParameterDirection.Output;

        da.SelectCommand = cmd;
        DataTable dt = new DataTable();
        da.Fill(dt);
        return dt;
    }
}


  1. Beregn percentil i MySQL baseret på totaler

  2. Sådan tjekker du versionen af ​​oracle provider til ole-db. OraOLEDB.Oracle udbyder

  3. ActiveAndroid Forudfyld tabel ved hjælp af skemamigrering

  4. Brug af Dapper med Oracle lagrede procedurer, der returnerer markører