2

我正在尝试使用以下查询注册用户:

"INSERT INTO Users (Username, Password, FirstName, Surname, Age, HouseNumber, 
                    StreetName, Town, County, Postcode, TelephoneNumber, 
                   isBanned, isAdmin) 
 VALUES ('" + textboxUsername.Text + "','" + textboxPassword.Text + "','" + 
             textboxFirstName.Text + "','" + textboxSurname.Text + "','" + textboxAge.Text + "','" + textboxHouseNumber.Text + 
     "','" + textboxStreetName.Text + "','" + 
              textboxTown.Text + "','" + textboxCounty.Text + "','" + 
             textboxPostcode.Text + "','" + textboxTelephoneNumber.Text + 
          "', 'false', 'false')", con);

数据库按照您的预期设置,只有上述值和用户 ID,它应该是使用身份规范的自动增量值。但是,我收到以下错误:

Cannot insert the value NULL into column 'UserID', table 'myFilePath'; column does not allow nulls. INSERT fails.

为什么是这样?我不能告诉它为 UserID 插入任何内容,因为数据库需要处理它,目前 UserID 是主键,因此不能不为空。我究竟做错了什么?这曾经在几个月前工作

4

4 回答 4

2

确保您的列上有一个序列,如果没有添加一个:

CREATE SEQUENCE yourschemaname.Users
    START WITH 1
    INCREMENT BY 1;
GO
于 2012-08-14T09:44:37.020 回答
2

您也可以idNULL查询中提及。它将使用以下方式填充auto-increment

INSERT INTO Users 
(UserID, Username, Password, FirstName, Surname, Age, HouseNumber, StreetName, 
 Town, County, Postcode, TelephoneNumber, isBanned, isAdmin
) 
VALUES 
(NULL,'" + textboxUsername.Text + "','" + 
 textboxPassword.Text + "','" + textboxFirstName.Text + "','" + 
 textboxSurname.Text + "','" + textboxAge.Text + "','" + textboxHouseNumber.Text + "','" +
 textboxStreetName.Text + "','" + textboxTown.Text + "','" + textboxCounty.Text + "','" +
 textboxPostcode.Text + "','" + textboxTelephoneNumber.Text + "', 'false', 'false')", 
 con);

还要检查字段的数据类型UserID它应该是这样的:

UserID INT unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY;
于 2012-08-14T09:45:27.100 回答
1

您可以使用 SQL 自动增量:

用 AUTO_INCREMENT 定义你的表:

CREATE TABLE Users
(
UserID int NOT NULL AUTO_INCREMENT,
Username varchar(255) NOT NULL,
Password varchar(255) ,
.....
PRIMARY KEY (UserID)
)

然后插入:

INSERT INTO Users (Username, Password, FirstName, Surname, Age, HouseNumber, 
                    StreetName, Town, County, Postcode, TelephoneNumber, 
                   isBanned, isAdmin)

http://www.w3schools.com/sql/sql_autoincrement.asp

于 2012-08-14T09:42:15.293 回答
1

不敢相信我必须这样做,但数据库连接路径是错误的。对不起,伙计们,我丢失了一封信。我会投票给每个人,并“回答”自己,以便人们看到。

于 2012-08-14T10:54:44.517 回答