将 int 值添加到数据库给出错误,但字符串值有效

Adding int value to database giving error, yet string value works

我目前正在开发 MVC 项目,使用 Entity framework 和 SQL Express 服务器。

我正在尝试将用户添加到用户 table。用户当前受到以下威胁:

CREATE TABLE [dbo].[Users] (
    [UserID] INT NOT NULL PRIMARY KEY,
    [Admin]  BIT NOT NULL,
);

当我通过下面的函数添加到上面的函数时table:

[HttpPost]
public String AddUser(List<String> values)
{
    using (DataBASE db = new DataBASE())
    {
        Users newUser = new Users();
        newUser.UserID = Int32.Parse(values[0]); //There is correct data stored here as an int value
        newUser.Admin = Boolean.Parse(values[1]); //There is correct data stored here as an bool value
        db.Users.Add(newUser); //The newUser object is correct
        db.SaveChanges(); //The error occurs here
    }
    return "success";
}

编辑,这是用户 class 请求的(无论何时存储到数据库中都会更改为字符串):

[Table("Users")]
public class Users
{
    [Key]
    public int UserID { get; set;}
    public bool Admin { get; set; }
}

我收到以下错误:

"Cannot insert the value NULL into column UserID, table ‘…\DATABASE.MDF.dbo.Users';
 column does not allow nulls. INSERT fails.\r\nThe statement has been terminated."}

该值不为 NULL 并且数据库连接正确(因为删除功能正常工作,当我进入该功能时,数据库连接正确并且该功能在通过添加新的更新之前提供正确的数据用户。

当我将数据库更改为以下内容时:

CREATE TABLE [dbo].[Users] (
    [UserID] NVARCHAR(50) NOT NULL PRIMARY KEY,
    [Admin]  BIT NOT NULL,
);

然后我使用以下函数添加了一个用户(将上面的函数更改为不传递 int 而是保留字符串值的地方):

[HttpPost]
public String AddUser(List<String> values)
{
    using (DataBASE db = new DataBASE())
    {
        Users newUser = new Users();
        newUser.UserID = values[0]; //There is correct data stored here as an string value
        newUser.Admin = Boolean.Parse(values[1]); //There is correct data stored here as an bool value
        db.Users.Add(newUser); //The newUser object is correct
        db.SaveChanges(); //NO error occurs here
    }
    return "success";
}

这是Usersclass改成字符串工作的字符串解决方案:

[Table("Users")]
public class Users
{
    [Key]
    public string UserID { get; set;}
    public bool Admin { get; set; }
}

是否存在我不知道的反对在数据库中使用 INT 值的问题?

 Users newUser = new Users();
        newUser.UserID = Int32.Parse(values[0]); //There is correct data stored here as an int value
        newUser.Admin = Boolean.Parse(values[1]); //There is correct data stored here as an bool value


        db.Users.Attach(newUser);


        db.Users.Add(newUser); //The newUser object is correct
        db.SaveChanges();

最后的尝试,我不确定,只是想到

如果数据库中已有相同的 ID,可能会遇到问题

老实说,这不是什么好回答的问题。但我能做的最好的事情就是解决我的问题,即编写原始查询并在下面执行它,它与数据库和整个应用程序中的 int 值一起使用。我仍然不知道,而且可能永远不会知道,为什么上述函数对 int 值不起作用。

        using (DataBASE db = new DataBASE())
        {
            try
            {
                db.Database.ExecuteSqlCommand("INSERT INTO Users VALUES({0},{1})", Int32.Parse(values[0]), Boolean.Parse(values[1]));
                db.SaveChanges();
            }
            catch (Exception e)
            {
                var exception = e;
            }
        }

您可以尝试将 UserID 列重命名为 Id 或 UsersId,删除 [Key] 符号,遵循 EF 约定,但仅用于测试。

您应该添加属性

[DatabaseGenerated(DatabaseGeneratedOption.None)]

给你的 UserId 属性。它说 EF 应该从 属性 获取值,而不是在数据库级别默认。