使用SqlDataReader将INT转换为ENUM时,指定的强制转换无效

本文关键字:转换 无效 SqlDataReader INT ENUM 使用 | 更新日期: 2023-09-27 18:11:49

编辑

删除assetItem上的对象初始值设定项似乎解决了我的问题,但为什么?

结束编辑

我似乎无法找到一种方法来从我的数据库中读取INT,就像将其转换为emun一样。

我试过这两个方面的建议将int强制转换为C中的枚举#以及如何(有效地(将SqlDataReader字段转换(强制转换?(为相应的c#类型?没有成功。

using (var connection = new SqlConnection(_sqlstring))
{
    using (var command = new SqlCommand("EXEC GetAllEncodedMedia", connection))
    {
        try
        {
            connection.Open();
            var reader = command.ExecuteReader();
            while (reader.Read())
            {
                if (reader.HasRows)
                {
                    var assetItem = new MediaServices.EncodedAssets
                    {
                        Id = reader.IsDBNull(0) ? 0 : reader.GetInt32(0),
                        PublishedName = reader.IsDBNull(1) ? null : reader.GetString(1),
                        PublishUri = reader.IsDBNull(2) ? new Uri("http://www.null.com") : new Uri(reader.GetString(2)),
                        EncodePreset = reader.IsDBNull(3) ? 0 : (MediaServices.EncodePresetsForSmoothStreaming)reader.GetInt32(3),
                        AssetId = reader.IsDBNull(4) ? null : reader.GetString(4),
                        EncoderJobId = reader.IsDBNull(5) ? 0 : reader.GetInt32(5),
                        //EncoderState = reader.IsDBNull(6) ? 0 : (JobState)reader.GetInt32(6),
                        //AssetState = reader.IsDBNull(7) ? 0 : (MediaServices.InternalAssetState)reader.GetInt32(7),
                        GroupId = reader.IsDBNull(8) ? 0 : reader.GetInt32(8),
                        Published = !reader.IsDBNull(2)
                    };
                    listReturn.Add(assetItem);
                }
            }
        }
        catch (Exception ex)
        {
            //error
        }
    }
}

[DataContract]
public enum EncodePresetsForSmoothStreaming
{
    [EnumMember]
    [Description("H264 Smooth Streaming 1080p")]
    H264SmoothStreaming1080P,
    [EnumMember]
    [Description("H264 Smooth Streaming 720p")]
    H264SmoothStreaming720P,
    [EnumMember]
    [Description("H264 Smooth Streaming 720p for 3G or 4G")]
    H264SmoothStreaming720Pfor3Gor4G,
    [EnumMember]
    [Description("H264 Smooth Streaming SD 16x9")]
    H264SmoothStreamingSd16X9,
    [EnumMember]
    [Description("H264 Smooth Streaming SD 4x3")]
    H264SmoothStreamingSd4X3
}

如何将序号3(int(强制转换为EncodePresetsForSmoothStreaming(enum(?

使用SqlDataReader将INT转换为ENUM时,指定的强制转换无效

尝试如下声明您的枚举,这将允许它正确地从整数转换为正确的枚举值。

public enum Test : int 
{ 
   TestValue1 = 1, 
   TestValue2 = 2, 
   TestValue3 = 3
}

您缺少读卡器。IsDBNull(3(,所以它可能试图将DbNull强制转换为int,这是无效的。

如果您确定该列中没有null,那么请确保从DB中获得的是int,您可以通过将内容作为字符串来实现;或者将其保留为对象,设置断点,并在IDE调用值中使用即时窗口。GetType((,它会告诉你到底在处理什么。

如果您将枚举存储为数据库中的字符串,那么您应该使用Enum.Passe((

这也是类似的:异常:指定的强制转换无效

将命令类型更改为存储过程,并从命令文本中删除"EXEC",使命令文本仅为存储过程名称:

using (var connection = new SqlConnection(_sqlstring))
{
    using (var command = new SqlCommand("GetAllEncodedMedia", connection))
    {
        try
        {
            connection.Open();
            command.CommandType = CommandType.StoredProcedure;
            var reader = command.ExecuteReader();
            while (reader.Read())
            {
                if (reader.HasRows)
                {
                    var assetItem = new MediaServices.EncodedAssets
                    {
                        Id = reader.IsDBNull(0) ? 0 : reader.GetInt32(0),
                        PublishedName = reader.IsDBNull(1) ? null : reader.GetString(1),
                        PublishUri = reader.IsDBNull(2) ? new Uri("http://www.null.com") : new Uri(reader.GetString(2)),
                        EncodePreset = reader.IsDBNull(3) ? 0 : (MediaServices.EncodePresetsForSmoothStreaming)reader.GetInt32(3),
                        AssetId = reader.IsDBNull(4) ? null : reader.GetString(4),
                        EncoderJobId = reader.IsDBNull(5) ? 0 : reader.GetInt32(5),
                        //EncoderState = reader.IsDBNull(6) ? 0 : (JobState)reader.GetInt32(6),
                        //AssetState = reader.IsDBNull(7) ? 0 : (MediaServices.InternalAssetState)reader.GetInt32(7),
                        GroupId = reader.IsDBNull(8) ? 0 : reader.GetInt32(8),
                        Published = !reader.IsDBNull(2)
                    };
                    listReturn.Add(assetItem);
                }
            }
        }
        catch (Exception ex)
        {
            //error
        }
    }
}

双击列的数据类型,枚举可能存储为tinyint。如何转换";tinyint";从t-sql到c#中的整数?

尝试在强制转换之前将值读取到变量中,以验证错误是否为读取错误。