Nano Hash - криптовалюты, майнинг, программирование

Как получить значение из объекта OracleParameter

Как показано в коде ниже, я хочу получить значение из объекта OracleParameter. Его тип данных — datetime.

...

Dim cmd As New OracleCommand("stored_proc_name", cnObject)
cmd.Parameters.Add("tran_date_out", OracleDbType.Date, ParameterDirection.Output)

...

cmd.ExecuteNonQuery()

...

Dim tranDate As Date
tranDate = cmd.Parameters("tran_date_out").Value

Когда я присваиваю значение переменной tranDate, я получаю сообщение об ошибке. Но если я закодирую, как показано ниже, я получу только дату.

tranDate = CDate(cmd.Parameters("tran_date_out").Value.ToString)

Итак, как я могу получить значение даты и времени для переменной tranDate?

08.01.2009

Ответы:


1

с моей головы, OracleParameter.Value, когда выходной параметр назначается странному коробочному типу Oracle. Это кажется совершенно ужасным дизайном или частью Oracle... но вместо возврата String вы получите OracleString и т.д.

У каждого из типов Oracle есть .Value с системным типом, но, конечно, не все они реализуют общий интерфейс для раскрытия этого, поэтому я в основном написал метод для распаковки типов:

/// <summary>
/// The need for this method is highly annoying.
/// When Oracle sets its output parameters, the OracleParameter.Value property
/// is set to an internal Oracle type, not its equivelant System type.
/// For example, strings are returned as OracleString, DBNull is returned
/// as OracleNull, blobs are returned as OracleBinary, etc...
/// So these Oracle types need unboxed back to their normal system types.
/// </summary>
/// <param name="oracleType">Oracle type to unbox.</param>
/// <returns></returns>
internal static object UnBoxOracleType(object oracleType)
{
  if (oracleType == null)
    return null;

  Type T = oracleType.GetType();
  if (T == typeof(OracleString))
  {
    if (((OracleString)oracleType).IsNull)
      return null;
    return ((OracleString)oracleType).Value;
  }
  else if (T == typeof(OracleDecimal))
  {
    if (((OracleDecimal)oracleType).IsNull)
      return null;
    return ((OracleDecimal)oracleType).Value;
  }
  else if (T == typeof(OracleBinary))
  {
    if (((OracleBinary)oracleType).IsNull)
      return null;
    return ((OracleBinary)oracleType).Value;
  }
  else if (T == typeof(OracleBlob))
  {
    if (((OracleBlob)oracleType).IsNull)
      return null;
    return ((OracleBlob)oracleType).Value;
  }
  else if (T == typeof(OracleDate))
  {
    if (((OracleDate)oracleType).IsNull)
      return null;
    return ((OracleDate)oracleType).Value;
  }
  else if (T == typeof(OracleTimeStamp))
  {
    if (((OracleTimeStamp)oracleType).IsNull)
      return null;
    return ((OracleTimeStamp)oracleType).Value;
  }
  else // not sure how to handle these.
    return oracleType;
}

Это, вероятно, не самое чистое решение, но... оно было быстрым и грязным и действительно работает для меня.

Просто передайте OracleParameter.Value в этот метод.


На самом деле, я мог только 1/2 прочитать ваш вопрос, прежде чем ответить. Я думаю, что тип даты Oracle содержит только дату, а не время.

Тип оракула Timestamp содержит как дату, так и время.

Надеюсь, это поможет! :)

08.01.2009
  • Я действительно ненавижу, что спустя почти 7 лет это все еще лучший ответ, который я могу найти для этой проблемы... 08.12.2015
  • Когда у вас огромная доля рынка, кому нужен прогресс? :) 08.12.2015

  • 2

    Я не сильно тестировал, но вот менее подробная версия ответа CodingWithSpike с использованием отражения...

    public static object UnBoxOracleType(object oracleType) {
        if(oracleType==null) {
            return null;
        }
    
        if((bool)oracleType.GetType().GetProperty("IsNull").GetValue(oracleType)) {
            return null;
        }
        return oracleType.GetType().GetProperty("Value").GetValue(oracleType);
    }
    

    Вы снова передаете OracleParameter.Value в этот метод.

    Или для более безопасной версии вы можете сделать это:

    public static object GetValue(OracleParameter param) {
        if(param == null || param.Value==null) {
            return null;
        }
    
        var oracleType=param.Value;
    
        if((bool)oracleType.GetType().GetProperty("IsNull").GetValue(oracleType)) {
            return null;
        }
        return oracleType.GetType().GetProperty("Value").GetValue(oracleType);
    }
    

    В этом случае вы должны передать сам параметр оракула, чтобы вернуть значение. Это также может быть реализовано как метод расширения, если вы того пожелаете...

    08.12.2015
    Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..