NServiceBus と nvarchar(max)
-
26-12-2019 - |
質問
私の佐賀クラスは次のとおりです。
public class SagaData : IContainSagaData
{
[Unique]
public virtual string SagaKey { get; set; }
public virtual string Data { get; set; }
#region IContainSagaData
public virtual Guid Id { get; set; }
public virtual string Originator { get; set; }
public virtual string OriginalMessageId { get; set; }
#endregion IContainSagaData
}
私はMSSQLでSagaを永続化しています。作成されたテーブルは次の構造になります。
CREATE TABLE [dbo].[SagaData](
[Id] [uniqueidentifier] NOT NULL,
[SagaKey] [nvarchar](255) NULL,
[Data] [nvarchar](255) NULL,
[Originator] [nvarchar](255) NULL,
[OriginalMessageId] [nvarchar](255) NULL,
PRIMARY KEY CLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY],
UNIQUE NONCLUSTERED
(
[SagaKey] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
Data
プロパティ (文字列の型) がマッピングされています nvarchar(255)
. 。明らかに、そのプロパティに 255 文字を超える文字を割り当てると、次のメッセージが表示されて失敗します。 String or binary data would be truncated
. 。どうすれば強制的に作れますか nvarchar(max)
?
NServiceBus 4.4.2を使用しています。
解決
解決策は非常に簡単です。そのクラスの HBM ファイルを追加し、それを埋め込みリソースとして設定すると、NHibernate がそれを自動的にロードしました。見た目はこんな感じです。
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="LuxMed.BackEnd.CRM.B2C.NSB.Host"
namespace="LuxMed.BackEnd.CRM.B2C.NSB.Host.Sagas">
<class name="SagaData">
<id name="Id" />
<property name="SagaKey" unique="true" />
<property name="Data" type="StringClob" />
<property name="Originator" />
<property name="OriginalMessageId" />
</class>
</hibernate-mapping>
type="StringClob"
それが作るものです nvarchar(max)
DBで。
所属していません StackOverflow