0

任何人都可以帮助将 C# 中的字符串值转换为 Sql 中的位等价物。我正在尝试将数据表的值批量复制到 Sql 表中。我在数据表中的所有值都是字符串格式。当我尝试批量复制到 SQL 表时,我收到位数据类型列的错误。任何人都可以在我批量复制到 SQL 表之前发布 C# 代码以将字符串转换为位类型。

谢谢,维克斯

4

4 回答 4

5

如果您的字符串是“真”和“假”(忽略大小写和空格),这将起作用:

bool bit = bool.Parse(str);

如果你的字符串是别的东西,你可以使用:

bool bit = !string.IsNullOrEmpty(str) &&
  (str[0]=='Y' || str[0]=='y' || str[0]=='T' || str[0]=='t' || str[0]=='1');

SQL 需要一个布尔值。

于 2009-11-08T05:24:39.153 回答
1

SQL Server 将识别位数据类型的“真”和“假”。此外,零存储零,非零存储为“1”。

你是发送"true"还是true

如果您在双打时遇到相同的错误(根据对其他答案的评论),那么我怀疑您正在发送引号。

于 2009-11-08T09:36:32.957 回答
0

bitSQL Server 中的数据bool类型与 C# 中的数据类型匹配。因此,只需将您的字符串转换为bools (使用bool.Parse()或您最喜欢的替代方案),您就应该设置好。

于 2009-11-08T05:22:44.583 回答
0
int a = Convert.ToInt32( row.ItemArray[5]);
bool b;
b = Convert.ToBoolean(a);
switch (a)
{
    case 1:
        b = true;
        break;
    case 0:
        b = false;
        break;
}
于 2011-01-19T08:04:46.503 回答