当前位置: 首页 > 知识库问答 >
问题:

无法将值NULL插入列

虞正业
2023-03-14

Hy,

我为数据库创建了以下3个表:

CREATE TABLE [dbo].[Buyer] (
[Buyer_Id]   INT           IDENTITY (1, 1) NOT NULL,
[Last_Name]  NVARCHAR (50) NOT NULL,
[First_Name] NVARCHAR (50) NOT NULL,
[Social_No]  NVARCHAR (50) NOT NULL,
[Phone]      NVARCHAR (50) NOT NULL,
[User_Id]    INT           NOT NULL,
PRIMARY KEY CLUSTERED ([Buyer_Id] ASC),
CONSTRAINT [FK_User_Id] FOREIGN KEY ([User_Id]) REFERENCES [dbo].[User] ([User_Id])

);

CREATE TABLE [dbo].[Type] (
    [Type_Id]   INT        IDENTITY (1, 1) NOT NULL,
    [Type_Name] NCHAR (10) NULL,
    PRIMARY KEY CLUSTERED ([Type_Id] ASC)
);

CREATE TABLE [dbo].[User] (
    [User_Id] INT           IDENTITY (1, 1) NOT NULL,
    [User_Name]    NCHAR (10)    NOT NULL,
    [Pass]    NVARCHAR (50) NOT NULL,
    [Type_Id] INT           NOT NULL,
    PRIMARY KEY CLUSTERED ([User_Id] ASC),
    CONSTRAINT [FK__Type_Id] FOREIGN KEY ([Type_Id]) REFERENCES [dbo].[Type] ([Type_Id])
);

我有以下存储过程

    CREATE PROCEDURE [dbo].[InsertCustomer]
    @Buyer_Id int output,
    @Last_Name varchar(50),
    @First_Name varchar(50),
    @Social_No varchar(50),
    @Phone varchar(50),
    @User_Id int output,
    @User_Name nchar(10),
    @Pass varchar(50),
    @Type_id int output,
    @Type_Name nchar(10)

    AS
     BEGIN

    SET NOCOUNT ON;  

    insert into Buyer(Last_Name,First_Name,Social_No,Phone)
    values (@Last_Name,@First_Name,@Social_No,@Phone)
    set @Buyer_Id = SCOPE_IDENTITY();  

    insert into [User](User_Name,Pass)
    values(@User_Name,@Pass)
    set @User_Id = SCOPE_IDENTITY();  


    insert into [Type](Type_Name)
    values (@Type_Name)
    set @Type_id = SCOPE_IDENTITY();    

    RETURN 0

 END

C#代码:

SqlCommand cmd = new SqlCommand("InsertCustomer", conn);
            cmd.CommandType = CommandType.StoredProcedure;
            SqlParameter paramLastName = new SqlParameter("@Last_Name", customer.Last_Name);
            SqlParameter paramFirstName = new SqlParameter("@First_Name", customer.First_Name);
            SqlParameter paramSocialNo = new SqlParameter("@Social_No", customer.Social_No);
            SqlParameter paramPhone = new SqlParameter("@Phone", customer.Phone_No);
            SqlParameter paramUserName = new SqlParameter("User_name", user.User_Name);
            SqlParameter paramPass = new SqlParameter("@Pass", user.Pass);
            SqlParameter paramTypeName = new SqlParameter("@Type_Name", type.Type_Name);
            SqlParameter paramBuyerId = new SqlParameter("@Buyer_Id", SqlDbType.Int);
            paramBuyerId.Direction = ParameterDirection.Output;
            SqlParameter paramUserId = new SqlParameter("@User_Id", SqlDbType.Int);
            paramUserId.Direction = ParameterDirection.Output;
            SqlParameter paramTypeId = new SqlParameter("@Type_Id", SqlDbType.Int);
            paramTypeId.Direction = ParameterDirection.Output;
            cmd.Parameters.Add(paramLastName);
            cmd.Parameters.Add(paramFirstName);
            cmd.Parameters.Add(paramSocialNo);
            cmd.Parameters.Add(paramPhone);
            cmd.Parameters.Add(paramUserName);
            cmd.Parameters.Add(paramPass);
            cmd.Parameters.Add(paramTypeName);
            cmd.Parameters.Add(paramBuyerId);
            cmd.Parameters.Add(paramUserId);
            cmd.Parameters.Add(paramTypeId);

            conn.Open();
            cmd.ExecuteNonQuery();
            customer.Buyer_Id = (int)paramBuyerId.Value;
            type.Type_Id = (int)paramTypeId.Value;
            user.User_Id = (int)paramUserId.Value;

但在我将数据插入使用上述代码的表单后,我得到了以下错误:

无法将值NULL插入列User_Id...... PLATFORM. MDF. dbo. Buyer;列不允许空值。INSERT失败。

无法将值NULL插入列Type_Id,表... PLATFORM. MDF. dbo. User;列不允许空值。INSERT失败。

请帮帮我,

真诚地

共有2个答案

严扬
2023-03-14

存储过程中存在错误,因为您没有为User_Id或Type_Id列指定值,但这些列不允许空值。

您应该颠倒插入的顺序,并在以下插入中使用生成的标识值,如下所示:

insert into [Type](Type_Name)
values (@Type_Name)
set @Type_id = SCOPE_IDENTITY();    

insert into [User](User_Name,Pass,TypeId)
values(@User_Name,@Pass,@Type_id)
set @User_Id = SCOPE_IDENTITY();  

insert into Buyer(Last_Name,First_Name,Social_No,Phone,User_Id)
values (@Last_Name,@First_Name,@Social_No,@Phone,@User_Id)
set @Buyer_Id = SCOPE_IDENTITY();  
梁丘招
2023-03-14

你应该更改插入顺序。首先,你应该插入新的类型

insert into [Type](Type_Name)
values (@Type_Name)
set @Type_id = SCOPE_IDENTITY();  

之后,您应该插入新用户(使用@type_id)

insert into [User](User_Name,Pass,Type_id)
values(@User_Name,@Pass,@Type_id)
set @User_Id = SCOPE_IDENTITY();  

最后,使用@User_Id插入买家。依次使用@User_Id

insert into Buyer(Last_Name,First_Name,Social_No,Phone,User_id)
values (@Last_Name,@First_Name,@Social_No,@Phone,@User_Id)
set @Buyer_Id = SCOPE_IDENTITY();  
 类似资料:
  • 这是我的插入代码,后面是创建表的代码 我不想插入任何东西到列占用,我不知道为什么这是发生的或如何修复它。我只想在tblGrave(GraveName)中插入值。任何帮助都会很好。

  • 原因:com。微软sqlserver。jdbc。SQLServerException:无法将值NULL插入表ECM3的“白色列表”列中。dbo。白名单;列不允许空值。插入失败。 我已经为我的问题做了很多搜索,我尝试了所有可能的解决方案,但都不起作用。我试图使用关系为的父表(白名单)插入子表(白名单匹配),但它显示了前面的错误! 白名单。java(父级) WhiteListMatches.java(

  • 我有一个表,列:,,。我试图实现简单的插入功能,但当我提交表单时,我无法将NULL值插入“name”列、table“database_name”中。dbo。用户的;列不允许空值。插入失败。 我正在学习这个教程。 地点主人 请帮忙,提前谢谢!

  • 我有以下代码: 其中,是一个标识列,其中不允许有空值。在我的Excel文件中,该列是空的(除了标题) 我得到以下错误消息: 无法将值NULL插入列AmountId中,表AnalyticsV2P7. CapModel. LedgerAmountByECMAcCountByRptLOB;列不允许空值。INSERT失败。 我知道不允许有空值,因为我是这样设置的,但它不应该填充标识列,这样就没有空值了吗?

  • 我有一个使用存储过程填充的表。这个存储过程使用从另一个数据库调用属性的视图。 举例来说,它类似于: 视图的定义如下: 并正确插入值,但如果以这种方式使用视图: 显示此消息: 正在检查身份信息:当前身份值“1252” DBCC执行已完成。如果DBCC打印了错误消息,请与系统管理员联系。 Msg 515,第16级,状态2,过程TSP,第16行 无法将值NULL插入表db2的“金额”列中。dbo。表';

  • 使用flyway-core:4.1.2进行数据库迁移。 添加了一个新的DDL文件供flyway执行。Flyway会正确执行DDL并对表和列进行相应的更改。(我们在新的DDL中添加了一个表并更改了以前的一些列)。 但是,flyway无法将此尝试注册到schema_version表:我得到以下错误: 架构[dbo]的当前版本:2.1 无法在元数据表[dbo]中插入版本“3.0”的行。[schema_v