gpt4 book ai didi

c# - 如何在 Nhibernate 中定义一个 CHAR (ORACLE) 列?

转载 作者:行者123 更新时间:2023-11-30 18:05:51 25 4
gpt4 key购买 nike

我开始在一个项目中使用 Nhibernate 和 Oracle。
数据库是 Oracle 9.2,我无法更改架构或任何内容。
我正在使用 NH3.0 和 Oracle.DataAccess.dll 版本 2.111.7.20。

到目前为止,我已经映射了几个表并进行了一些查询。一切都很好。我现在遇到了一个问题,我不知道如何解决它。
设计数据库的公司认为将所有字母数字字段创建为 CHAR 而不是 VARCHAR 或 VARCHAR2 是个好主意。

我已将所有这些列映射为字符串,并且我的类定义了字符串字段。后来我试图通过主键加载实体,在 Oracle 中定义为 CHAR(10)。我尝试加载的 key 只有 7 个字符长
例如:'CI00252'显然我的实体无法加载。使用 NHProf 分析查询我可以看到我的查询很好,如果我尝试在 Oracle Sql-Developer 中执行它,我会得到结果集。如果我像这样“CI00252”填充我的字符串,我只能设法让它工作。

考虑到数据库上定义的大部分字段都是CHAR,我不可能在执行查询之前填充所有内容。
我该怎么做才能解决这个问题?

PS:我在这里看到其他一些人也有同样的问题,但我找不到任何合适的答案。

更新:

我正在阅读 blog这个人对另一种数据类型也有类似的问题。我试着调整代码

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>

这里有没有人可以帮助我了解正在发生的事情?

最佳答案

我的答案在问题的更新中。

关于c# - 如何在 Nhibernate 中定义一个 CHAR (ORACLE) 列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5157387/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com