繁体   English   中英

实体框架无法连接Oracle中的Enum列

[英]Entity Framework cannot concat Enum column in Oracle

我将EntityFramework 6.1与Oracle一起使用时,我需要编写查询以在预测表达式的地方串联两列。

我用下面的代码:

/* t.Col1 : string , t.Col2: Enum */
db.Table1.Where(t => t.Col1 + " " + t.Col2 == "SomeValue");

但是我得到了OracleException:ORA-12704:字符集不匹配错误。 我想在从数据库中获取数据之前应用条件。 因此,有人知道我该如何处理这个问题?

我已经看到了这个主题 ,但是如果其中一个列是Enum,则该解决方案将不起作用。

我检查了命令文本,发现尝试将空字符转换为NCLOB

THEN N'' ELSE TO_NCLOB

所以我用以下解决方案更新了@solidau答案:

command.CommandText = command.CommandText.Replace("N''", "''").Replace("THEN '' ELSE TO_NCLOB", "THEN N'' ELSE TO_NCHAR");

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM