Как определить столбец CHAR (ORACLE) в Nhibernate? - PullRequest
3 голосов
/ 01 марта 2011

Я начинаю работать с Nhibernate и Oracle для проекта.
База данных - Oracle 9.2, и я не могу изменить схему или что-либо еще.
Я использую NH3.0 и Oracle.DataAccess.dll ver 2.111.7.20.

Пока что я сопоставил пару таблиц и сделал несколько запросов.Все работает довольно хорошо.Я столкнулся с проблемой сейчас и не знаю, как ее исправить.
Компания, которая разработала базу данных, решила, что было бы неплохо создать все буквенно-цифровые поля как CHAR вместо VARCHAR или VARCHAR2.

Я сопоставил все эти столбцы как String, и в моих классах определены поля String.Позже я пытался загрузить сущность по ее первичному ключу, определенному в Oracle как CHAR (10).Ключ, который я пытался загрузить, длиной всего 7 символов
EG: 'CI00252' Очевидно, моя сущность не может быть загружена.Профилируя запрос с помощью NHProf, я вижу, что мой запрос в порядке, и если я пытаюсь выполнить его в Oracle Sql-Developer, я получаю набор результатов.Мне удастся заставить его работать, только если я дополню свою строку следующим образом: CI00252.

Учитывая, что большинство полей, определенных в базе данных, являются CHAR, я не могу заполнить все перед выполнением запроса.
Что я могу сделать, чтобы решить эту проблему?

PS: я видел других людей с такой же проблемой здесь, но я не мог найти подходящий ответ.

ОБНОВЛЕНИЕ :

Я читал blog и у этого парня была похожая проблема с другим типом данных. Я попытался adpapt-код

public SqlType[] SqlTypes
    {
        get
        {
                SqlType[] types = new SqlType[1];
                types[0] = new SqlType(DbType.StringFixedLength);
                return types;
                }
    }

**

и, видимо, все работаетно ... я не знаю почему.

using System;
using System.Data;
using NHibernate;
using NHibernate.SqlTypes;
using NHibernate.UserTypes;

namespace ConsoleOracleNhibernate.OracleTypes
{
    public class CharUserType : IUserType
    {
        public object NullSafeGet(IDataReader rs, string[] names, object owner)
        {
            string resultString = (string)NHibernateUtil.String.NullSafeGet(rs, names[0]);
            if (resultString != null)
                return resultString.Trim();
            return null;
        }

        public void NullSafeSet(IDbCommand cmd, object value, int index)
        {
            if (value == null)
            {
                NHibernateUtil.String.NullSafeSet(cmd, null, index);
                return;
            }

            value = ((String)value).Trim();

            NHibernateUtil.String.NullSafeSet(cmd, value, index);
        }

        public object DeepCopy(object value)
        {
            if (value == null) return null;
            return string.Copy((String)value);
        }

        public object Replace(object original, object target, object owner)
        {
            return original;
        }

        public object Assemble(object cached, object owner)
        {
            return DeepCopy(cached);
        }

        public object Disassemble(object value)
        {
            return DeepCopy(value);
        }

        public SqlType[] SqlTypes
        {
            get
            {
                SqlType[] types = new SqlType[1];
                types[0] = new SqlType(DbType.StringFixedLength);
                return types;
            }
        }

        public Type ReturnedType
        {
            get { return typeof(String); }
        }

        public bool IsMutable
        {
            get { return false; }
        }

        public new bool Equals(object x, object y)
        {
            if (x == null || y == null) return false;
            return x.Equals(y);
        }

        public int GetHashCode(object x)
        {
            return x.GetHashCode();
        }
    }
}

и мое отображение:

<key-property name="CustomerCode" column="ANCOCO" type="ConsoleOracleNhibernate.OracleTypes.CharUserType, ConsoleOracleNhibernate" length="10"></key-property>

Есть здесь кто-нибудь, кто может попытаться помочь мне понять, что происходит?

1 Ответ

1 голос
/ 07 марта 2011

Мой ответ в обновлении вопроса.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...