【问题标题】:C# convert bit to booleanC#将位转换为布尔值
【发布时间】:2010-05-04 17:07:01
【问题描述】:

我有一个 Microsoft SQL Server 数据库,其中包含 BIT 类型的数据字段。

此字段将具有 01 值来表示 false 和 true。

我希望在检索数据时将我得到的值转换为 falsetrue 而不使用 if-condition 将数据转换为 false 如果它是 0true 如果它是1.

我想知道 C# 中是否有一个函数可以通过将位值传递给它来直接执行此操作?

【问题讨论】:

    标签: c# ado.net


    【解决方案1】:
    DataReader.GetBoolean(x)
    

    Convert.ToBoolean(DataRow[x])
    

    【讨论】:

    • Convert.ToBoolean((byte)1); 返回true
    【解决方案2】:

    取决于您如何执行 SQL 查询,这可能取决于。例如,如果你有一个data reader,你可以直接read a boolean value

    using (var conn = new SqlConnection(ConnectionString))
    using (var cmd = conn.CreateCommand())
    {
        conn.Open();
        cmd.CommandText = "SELECT isset_field FROM sometable";
        using (var reader = cmd.ExecuteReader())
        {
            while (reader.Read())
            {
                bool isSet = reader.GetBoolean(0);
            }
        }
    }
    

    【讨论】:

    • 当执行一个只返回一个BIT的存储过程或UDF时,是否不需要Read(),即像这样:bool isSet = cmd.ExecuteReader().GetBoolean(0);
    【解决方案3】:

    你是如何从数据库中提取字段的?

    SqlDataReader 类有一个 GetBoolean 方法为您进行翻译:

    bool yourBoolean = reader.GetBoolean(reader.GetOrdinal("Your_Bit_Column"));
    

    【讨论】:

      【解决方案4】:

      GetBoolean 会自动执行此操作。

      【讨论】:

        【解决方案5】:

        来自 ASP.NET 2.0 的SqlDataSourceBIT 字段返回01

        来自 ASP.NET 4.0 的SqlDataSource 返回适当的字符串 - Boolean.TrueString ("True") 或 Boolean.FalseString ("False")。

        【讨论】:

        • @Guillaume:SQL 类型 BIT 还是 .NET 类型字节?
        猜你喜欢
        • 2011-03-22
        • 2011-12-26
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2016-04-27
        • 2012-02-25
        • 2015-02-20
        • 1970-01-01
        相关资源
        最近更新 更多