- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有以下方法:
public static T ExecuteScalar<T>(
string query,
SqlConnection connection,
params SqlParameter[] parameters) where T : new()
{
// Create SqlCommand
SqlCommand command = CreateCommand(query, connection, parameters);
// Execute command using ExecuteScalar
object result = command.ExecuteScalar();
// Return value as expected type
if (result == null || result is DBNull) return default(T);
return (T)result;
}
我想将数据库的 MIN_ACTIVE_ROWVERSION
作为 ulong
。奇怪的是..下面的第一个方法调用会产生错误,但第二个方法调用可以正常工作。
方法调用 1 生成错误:
ulong minActiveRowversion =
SqlUtils.ExecuteScalar<ulong>(
"SELECT CAST(MIN_ACTIVE_ROWVERSION() AS BIGINT)"
, _connectionString);
错误:
System.InvalidCastException: Specified cast is not valid.
方法调用 2 工作正常:
ulong minActiveRowversion =
(ulong)SqlUtils.ExecuteScalar<long>(
"SELECT CAST(MIN_ACTIVE_ROWVERSION() AS BIGINT)"
, _connectionString);
我不明白这怎么可能,因为 command.ExecuteScalar()
方法的结果是这样的:
object result | 1955612
result.GetType() | {Name = "Int64" FullName = "System.Int64"}
最佳答案
为什么
您只能将值类型拆箱为其原始类型。在你的情况下, Actor 首先需要去 long
来自 object
然后然后到ulong
.
有关详细信息,请参阅此问题:
Why can't I unbox an int as a decimal?
它还链接了一个 blog post埃里克·利珀特 (Eric Lippert)。
如何
如您所知,一种方法是在转换为 T
之前转换为原始类型。 - 当然,除非原始类型是 T
.
如评论中所述,另一种方法是使用转换例程 ( Convert.ToUInt64
) 而不是显式转换。
这可以通过使用 Func<object, T>
来实现:
public static T ExecuteScalar<T>(
Func<object, T> conversionFunctor,
string query,
SqlConnection connection,
params SqlParameter[] parameters) where T : new()
{
// Create SqlCommand
SqlCommand command = CreateCommand(query, connection, parameters);
// Execute command using ExecuteScalar
object result = command.ExecuteScalar();
// Return value as expected type
if (result == null || result is DBNull)
return default(T);
return conversionFunctor(result);
}
打电话:
ulong minActiveRowversion =
SqlUtils.ExecuteScalar<ulong>(
Convert.ToUInt64,
"SELECT CAST(MIN_ACTIVE_ROWVERSION() AS BIGINT)"
, _connectionString);
关于c# - InvalidCastException 长到 ulong,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11226448/
所以我有一个名为 OutputInformation 的类,我想存储它然后在另一台计算机上读取以检索数据。 我正在使用二进制序列化。 [Serializable()] public class Out
我一直在使用 Visual Studio 2010、C#。 我从事这个项目已经将近一年了。在其中,我使用存储在单独的 XML 文件中的信息来构建图像。这个过程已经为我工作了数百次,没有任何问题。 我已
我得到一个 InvalidCastException我不明白为什么。 这是引发异常的代码: public static void AddToTriedList(string recipeID) {
我有一个执行数据转储的 exe。 exe 将根据配置动态获取 DLL,并将类对象传递给它。 DLL 有一个用它编译的此类的副本,并且可以在调试下看到数据,没有问题作为对象。但是,当我尝试将它转换到类里
我基本上想做的是将从 Web 服务获取的对象转换为与我的 Entity Framework 对象兼容的对象。我虽然通过创建一个同时应用于 Web 服务对象和 EF 对象的接口(interface)来做
我有一个查询,其结果如下所示 Blue OrangeRed Black Green Silver Red 我打算从这个结果集中创建一个 System.Drawing.Color 对象的列表。当我运行该
我有一个 GridView ,当双击一条记录时,我希望它为该特定记录打开一个新的详细 View 表单。 例如,我创建了一个 Customer 类: using System; using System
我目前对我遇到的问题感到非常困惑。我正在为另一个提供公共(public) .NET API 的应用程序编写插件。我创建了一个名为 Room 的类,我使用 PropertyGrid 允许用户查看和编辑
我在具有自定义类的字典和列表中遇到了该异常。示例: List dsa = (List)Session["Display"]; 当我使用 Session 时,转换工作了 10-20 次..然后它开始抛
我在 Entity Framework Core 1.1 中遇到此查询的问题: var leaves = _context.Proposal.OfType() .Inc
当我在 NET Framework 4.7.2 中创建新的 WPF 应用程序时,将菜单添加到 MainWindow 时,每当您单击菜单然后单击菜单以外的位置将其关闭时,我都会收到 InvalidCas
我的一个程序集包含以下“提供者”类型: 我还有一个 XML 文件,它使用 DeviceInfoProvider 基类保存提供者信息。简化版本如下所示: 在运行时,我将 XML 字段映射到我的变
我有一个扩展方法,我在 WinForms 中使用了多年,但自从我尝试在新的 WPF 项目中使用它后就没有了。方法: public static String GetDescription(this E
我在以下代码的运行时收到“InvalidCastException”: 我的 C# WinForm 代码包含一个组合框,它使用以下代码从数据库中填充: public void PopulateComp
下面的代码给了我一个 InvalidCastException,说明我不能在 foreach 循环中从源类型转换到目标类型。我尝试通过该方法传递多个不同的通用集合,但我总是收到此错误。我不知道为什么。
(问题的真正标题应该是“为什么我得到一个‘无法转换类型为‘System.Runtime.CompilerServices.TaskAwaiter`1[System.Runtime.CompilerSe
我在 C# 中有以下代码片段 List list = new List() { 1, 23, 5, 3, 423, 3 }; var query = list.Cast().S
这个特定问题更多的是试图找出编译器消息背后的原因,而不是解决问题,但我希望它没问题。 假设我们有: class Foo { public static explicit operator Fo
我想统计某个时间段之间的记录数。 我使用 Npgsql 准备查询,然后添加变量部分(出于安全原因): lCommand.CommandText = "select count(*) from
Closed. This question is off-topic。它当前不接受答案。
我是一名优秀的程序员,十分优秀!