Как сопоставить uint в NHibernate с SQL Server 2005
-
11-07-2019 - |
Вопрос
У меня есть свойство типа uint для моей сущности.Что -то вроде:
public class Enity
{
public uint Count {get;set;}
}
Когда я пытаюсь сохранить это в базе данных SQL Server 2005, я получаю исключение
Диалект не поддерживает DbType.UInt32
Какой был бы самый простой способ обойти это?Я мог бы, например, хранить его как можно дольше в базе данных.Я только не знаю, как сказать это NHibernate.
Решение
Самое чистое, наиболее официальное решение - написать тип пользователя.
Возьмите пример, например, этот и адаптируйте его. Если у вас много uint
, стоит указать тип пользователя.
<property name="Prop" type="UIntUserType"/>
Другие советы
Не пробовал этого, поэтому не уверен, сработает ли это для вас, но вы могли бы попробовать создать свой собственный диалект и зарегистрировать его в web.config/ app.config
Класс диалекта:
public class MyDialect:MsSql2005Dialect
{
public MyDialect()
{
RegisterColumnType(System.Data.DbType.UInt32, "bigint");
}
}
Web.config:
configuration>
<configSections>
<section name="hibernate-configuration" type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate" />
</configSections>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
<session-factory>
<property name="connection.provider">NHibernate.Connection.DriverConnectionProvider, NHibernate</property>
<property name="connection.connection_string">
Server=127.0.0.1; Initial Catalog=thedatabase; Integrated Security=SSPI
</property>
<property name="dialect">MyDialect</property>
<property name="current_session_context_class">managed_web</property>
</session-factory>
</hibernate-configuration>
<!-- other app specific config follows -->
</configuration>
<property name="Prop" type="long"/>
Вы можете попытаться добавить еще одно частное свойство "mirror".
public class Enity
{
public uint Count {get;set;}
private long CountAsLong
{
get { return Convert.ToInt64(Count); }
set { Count = Convert.ToUInt(value); }
}
}
<property name="CountAsLong" type="long"/>
Конечно, вы должны делать это только , если это не может быть решено сопоставлением.