[英]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.