3

我对 LINQ 和 MS SQL Server 有一个非常烦人的问题。

我目前在 WPF C# 中制作一些软件,并使用 LINQ 从数据库中的数据生成类。

但是,当我从程序更新数据库中的 nvarchar 或 varchar 字段时,LINQ 会在字符串中添加尾随空格!

我在这样定义的表中有一个字段:

ProductName = NVARCHAR(10)

所以如果我这样做:

Product.Name = "Bike";
Product.Name = Product.Name.Trim();
repository.Add(Product);   // Runs an .InsertOnSubmit
repository.Save();         // Runs a .SubmitChanges

那么数据库中的结果数据是“Bike[SPACE][SPACE][SPACE][SPACE][SPACE][SPACE]”,其中 [SPACE] 只是一个空格(此处不能在此文本中写​​入多个空格)。

为什么它会这样做,我如何让它停止添加那些烦人的尾随空格?

提前致谢

4

3 回答 3

6

如果我没记错的话我有同样的问题......这不是因为 linq 而是因为列类型。请尝试将其更改为 VARCHAR。

于 2009-12-10T08:30:58.510 回答
2

自动生成的 LINQ 类以下列方式定义 NVarchar 字段:

[Column(Storage="_Text", DbType="NChar(20) NOT NULL", CanBeNull=false)]
public string Text
{
get
{
    return this._Text;
}
set
{
    if ((this._Text != value))
    {
        this.OnTextChanging(value);
        this.SendPropertyChanging();
        this._Text = value;
        this.SendPropertyChanged("Text");
        this.OnTextChanged();
    }
}
}

列设置应该在哪里:

[Column(Storage="_Text", DbType="NVarChar(20) NOT NULL", CanBeNull=false)]

出现问题是因为我在没有重新生成 LINQ 类的情况下更新了 SQL 数据库中的类型。

于 2010-01-05T12:50:00.340 回答
0

Nchar 也做同样的事情。

这些类型填补空白:Nchar 和 Nvarchar

我已经转换了我的数据库并更新了我的模型。都修好了。

检查...

SQL Server 中的 char、nchar、varchar 和 nvarchar 有什么区别?

如果您不想更改模型,可以使用 mssql 修剪功能。

于 2012-11-06T18:48:45.920 回答