NHibernate 맵 oracle 데이터베이스 CLOB, BLOB 형식 빅 데이터 필드
먼저 테스트 클래스 를 만 듭 니 다.
public class testClass
{
// CLOB
public string WKT{get;set;}
}
nhibernate 설정 파일 중:
<property column="WKT" type="StringClob" name="WKT" length="200000" />
구체 적 인 nhibernate 의 조제 방법 같은 것 은 여기 서 군말 하지 않 습 니 다. 본인 nhibernate 관련 블 로 그 를 보 세 요.
번 외: CLOB, BLOB 필드 의 최대 상한 선 은 4GB, 즉 4x1024x1024x1024 x1024 바이트 입 니 다. 특별히 필요 하지 않 으 면 length 가 너무 크 지 않 고 적당 하면 됩 니 다.제 가 뽑 은 20 만 바이트.
간단 한 방법 으로 데이터 테스트 삽입 하기:
var testClass = new testClass();
testClass.WKT = data; // data ,
ISession session = SessionFactory.OpenSession();
session.Save(testClass);
session.Flush();
이 때 Oacle 데이터베이스 WKT 필드 가 NCLOB 형식 임 을 알 수 있 습 니 다. 그러나 테스트 데이터 가 2000 바이트 이하 와 4000 바이트 이상 일 때 순조롭게 통과 되 었 고 2000 - 4000 바이트 일 때 오류 가 발생 했 습 니 다. [ORA - 01461: LONG 열 에 만 삽입 할 수 있 는 LONG 값 할당] 구체 적 인 원인 은 Oacle. client 의 문제 인 것 같 습 니 다. 자세 한 설명 은 하지 않 습 니 다.
구체 적 인 해결 방안 은 다음 과 같다.
nhibernate 맵 을 만 들 때 사용자 정의 유형 을 만 날 수 있 을 것 이 라 고 믿 습 니 다. 본인 과 관련 된 nhibernate 웨 이 보 를 참고 하지 않 으 시 면 됩 니 다.그러면 우 리 는 CLOB 에 정확 한 OacleType 을 설정 할 수 있 습 니 다.
먼저 LOB 필드 에 대한 패 치 클래스 를 추가 합 니 다.
PatchForOracleLobField.cs
using System;
using System.Collections.Generic;
using System.Data;
using System.Text;
using NHibernate;
using NHibernate.SqlTypes;
using NHibernate.UserTypes;
namespace Test.type
{
public abstract class PatchForOracleLobField : IUserType
{
public bool IsMutable
{
get { return false; }
}
public System.Type ReturnedType
{
get { return typeof(StringClobSqlType); } //
}
public SqlType[] SqlTypes
{
get
{
return new SqlType[] { NHibernateUtil.StringClob.SqlType }; //
}
}
public object DeepCopy(object value)
{
return value;
}
public new bool Equals(object x, object y)
{
return x == y;
}
public int GetHashCode(object x)
{
return x.GetHashCode();
}
public object Assemble(object cached, object owner)
{
return DeepCopy(cached);
}
public object Disassemble(object value)
{
return DeepCopy(value);
}
public object NullSafeGet(IDataReader rs, string[] names, object owner)
{
return NHibernate.NHibernateUtil.StringClob.NullSafeGet(rs, names[0]);
}
public abstract void NullSafeSet(IDbCommand cmd, object value, int index);
public object Replace(object original, object target, object owner)
{
return original;
}
}
}
CLOB 에 대한 클래스 추가:
OracleClobField.cs
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.OracleClient;
using System.Text;
namespace Test.type
{
public class OracleClobField : PatchForOracleLobField
{
public override void NullSafeSet(IDbCommand cmd, object value, int index)
{
if (cmd is OracleCommand)
{
OracleParameter param = cmd.Parameters[index] as OracleParameter;
if (param != null)
{
param.OracleType = OracleType.Clob; //
param.IsNullable = true;
}
}
NHibernate.NHibernateUtil.StringClob.NullSafeSet(cmd, value, index);
}
}
}
그리고 nhibernate 의 맵 파일 을 수정 합 니 다.
수정 전:
<property column="WKT" type="StringClob" name="WKT" length="200000" />
수정 후:
<property column="WKT" type=" +testClass, testClass " name="WKT" length="200000" />
다시 테스트 방법 을 호출 하여 테스트 를 진행, 문제 해결 발견!!
주: nhibernate 맵 이 존재 한 다 는 것 을 모두 가 알 고 있 을 때 표 가 존재 하면 수정 되 지 않 을 뿐 이 므 로 라 이브 러 리 를 삭제 한 후 재 구축 표 테스트 를 권장 합 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.