繁体   English   中英

使用.net core和Oracle.ManagedDataAccess.Core从Oracle查询中获取ID

[英]Getting IDs back from an Oracle query using .net core and Oracle.ManagedDataAccess.Core

我有以下代码:

List<foo> collection = getData();
using (OracleConnection conn = _client.GetConnection())
{
    await conn.OpenAsync();
    using (OracleTransaction transaction = conn.BeginTransaction(IsolationLevel.ReadCommitted))
    using (OracleCommand cmd = new OracleCommand())
    {
        cmd.Transaction = transaction;
        cmd.Connection = conn;
        cmd.CommandText = @"INSERT INTO SOME.TABLE
                           (A, B, C)
                           VALUES
                           (:A, :B, :C)";
        cmd.ArrayBindCount = collection.Count;
        cmd.Parameters.Add(":A", OracleDbType.Varchar2, collection.Select(c => c.A).ToArray(), ParameterDirection.Input);
        cmd.Parameters.Add(":B", OracleDbType.Varchar2, collection.Select(c => c.B).ToArray(), ParameterDirection.Input);
        cmd.Parameters.Add(":C", OracleDbType.Varchar2, collection.Select(c => c.C).ToArray(), ParameterDirection.Input);

        try
        {
            await cmd.ExecuteNonQueryAsync();
            transaction.Commit();
        }
        catch (Exception ex)
        {
            transaction.Rollback();
            throw new FailedTransactionException(ex.ToString());
        }
    }
}

在这里,我可以从我的集合中插入多行数据,但是我需要以某种方式返回插入行的ID。 有人可以为我指出正确的方向,还是有更好的方法插入对象数组并找回ID。

您可以通过执行以下操作来获取生成的ID:

@"INSERT INTO SOME.TABLE
  (A, B, C)
  VALUES
  (:A, :B, :C) 
  RETURNING <YOUR-ID-FIELD> INTO :resultId";

并像这样声明结果参数:

var resultParam = new OracleParameter(":resultId", OracleDbType.Decimal /* or whatever type of your identifier has */);
resultParam.Direction = ParameterDirection.ReturnValue;
cmd.Parameters.Add(resultParam);

然后,可以从其参数的Value属性执行查询后,从参数中读取结果:

var result = resultParam.Value

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM