我编写了一个函数,使用模式名称和表名称作为输入参数来检查表中是否存在特定的ID。
我创建要在数据库上执行的查询,如果找不到具有给定ID的记录,将返回-2,如果找到item,则返回其ID。
private long isThisNodeAlreadyInsertedInDatabaseByHeadquarter(
string schemaName
string tableName,
string primaryNodeId,
string primaryKeyFieldName){
string targetTableName = $"{schemaName}.{tableName}";
string sqlCommandString2 = $"select COALESCE(MAX({primaryKeyFieldName}),-2)" + " " + Environment.NewLine +
$"from {targetTableName}" + " " + Environment.NewLine +
"WHERE " + " " + Environment.NewLine +
$"{primaryKeyFieldName}={foundID}";
//will return -2 if not found otherwise return its id
DbRawSqlQuery<Int64> result2 = rawDbContext.Database.SqlQuery<Int64>(sqlCommandString2);
long foundID = result2.Single();
return foundID;
}
我的问题是,在我的数据库中的某些主键类型的Int,有些是类型的BigInt,其等效于Int32和Int64 分别(或在C#int和long分别地)。
当我读取BigInt类型的表的主键时,不会发生任何错误,但是当我想要读取Int类型的表的主键时,会导致异常:
{“从实例化的“ System.Int32”类型到“ System.Int64”类型的指定强制转换无效。”}
尽管可以将int存储在长变量中,但强制转换Int32为Int64in Database.SqlQuery会导致此异常。我想知道是否有针对这种情况的解决方法,或者我只需要使用读取值SqlDataReader.ExecuteReader?
将PK转换为BIGINTin查询,并读取为Int64:
"select CONVERT(BIGINT,COALESCE(MAX({primaryKeyFieldName}),-2))"
另外,您可以COALESCE用ISNULL函数替换:
"select CONVERT(BIGINT,ISNULL(MAX({primaryKeyFieldName}),-2))"
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。