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失败。
请帮帮我,
真诚地
存储过程中存在错误,因为您没有为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();
你应该更改插入顺序。首先,你应该插入新的类型
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