簡體   English   中英

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

[英]How to define a CHAR (ORACLE) column in Nhibernate?

我開始與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:我在這里見過其他一些有同樣問題的人,但我找不到合適的答案。

更新

我正在閱讀一篇博客 ,這家伙與另一種數據類型有類似的問題。我試圖加入代碼

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>

這里有沒有人可以幫我理解發生了什么?

我的答案是更新問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM