Отображение двух Int на DateTime - PullRequest
1 голос
/ 23 января 2012

Helo,

Я пытался создать UserType, который отображает два int, хранящихся в базе данных, в Datetime.Мои int называли время и дату в базе данных таким образом, что я хотел получить желаемый эффект.Но я получил ошибку: указанное приведение неверно.

Мой код:

public class DateTimeUserType : ImmutableUserType
    {
        public override object NullSafeGet(IDataReader rs, string[] names, object owner)
        {
            var date = (int)NHibernateUtil.Int32.NullSafeGet(rs, names[0]);
            var time = (int)NHibernateUtil.Int32.NullSafeGet(rs, names[1]);
            return Converts.ConvertDateTimeFromInt(date, time);
        }

        public override void NullSafeSet(IDbCommand cmd, object value, int index)
        {
            var res = Converts.ConvertDateTimeToInt((DateTime)value);
            NHibernateUtil.Int32.NullSafeSet(cmd, res.Date.GetValueOrDefault(), index);
            NHibernateUtil.Int32.NullSafeSet(cmd, res.Time.GetValueOrDefault(), index + 1);
        }

        public override Type ReturnedType
        {
            get { return typeof(DateTime); }
        }

        public override SqlType[] SqlTypes
        {
            get { return new[] { SqlTypeFactory.Int32, SqlTypeFactory.Int32 }; }
        }
    }

public abstract class ImmutableUserType : IUserType
    {
        public new virtual bool Equals(object x, object y)
        {
            return object.Equals(x, y);
        }

        public virtual int GetHashCode(object x)
        {
            return (x == null) ? 0 : x.GetHashCode();
        }

        public bool IsMutable
        {
            get { return false; }
        }

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

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

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

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

        public abstract object NullSafeGet(System.Data.IDataReader rs, string[] names, object owner);

        public abstract void NullSafeSet(System.Data.IDbCommand cmd, object value, int index);
        public abstract Type ReturnedType { get; }

        public abstract SqlType[] SqlTypes { get; }
    }

1 Ответ

0 голосов
/ 25 января 2012

Кажется, проблема решена, например, после правильной отладки.

...