如何在Nhibernate中定义CHAR(ORACLE)列?

时间:2011-03-01 16:35:26

标签: c# oracle nhibernate oracle11g

我开始与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这个人与另一个数据类型有类似问题。我试图加入代码

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 个答案:

答案 0 :(得分:1)

我的回答是更新问题。