Khu*_*rif 2 sql t-sql sql-server stored-procedures sql-update
我在本地创建了一个存储过程(IF Exist Update Else Insert)
当我执行该过程时,它无法插入或更新任何数据,SQL Server显示查询已成功运行.
表:
CREATE TABLE Laptops
(
Brand varchar(50),
Series varchar(50),
Model varchar(50),
Gener int,
Ram int,
HDD int,
Processor varchar(50),
Clock float,
Graphic_Chip varchar(50),
Graphic_Memory int,
Qty int,
Price int
PRIMARY KEY (Brand,Series,Model,Gener,Ram,HDD,Processor,Clock,Graphic_Chip,Graphic_Memory)
)
Run Code Online (Sandbox Code Playgroud)
存储过程:
CREATE PROCEDURE Insert_Inventory
(
@Brand Varchar(50),
@Series Varchar(50),
@Model Varchar(50),
@Gener int,
@Ram int,
@HDD int,
@Processor Varchar(50),
@Clock float,
@Graphic_Chip Varchar(50),
@Graphic_Memory int,
@Qty int,
@Price int
)
AS
IF EXISTS (SELECT * FROM Laptops
WHERE Brand = @Brand
and Series = @Series
and Model = @Model
and Gener = @Gener
and ram = @Ram
and hdd = @HDD
and Processor = @Processor
and Clock = @Clock
and Graphic_Chip = @Graphic_Chip
and Graphic_Memory = @Graphic_Memory)
BEGIN
UPDATE Laptops
SET
Qty = Qty + @Qty,
Price = @Price
WHERE
Brand = @Brand
and Series = @Series
and Model = @Model
and Gener = @Gener
and ram = @Ram
and hdd = @HDD
and Processor = @Processor
and Clock = @Clock
and Graphic_Chip = @Graphic_Chip
and Graphic_Memory = @Graphic_Memory
END
ELSE
BEGIN
INSERT into Laptops
VALUES (@Brand, @Series, @Model, @Gener, @Ram, @HDD, @Processor, @Clock, @Graphic_Chip, @Graphic_Memory, @Qty, @Price)
END
Run Code Online (Sandbox Code Playgroud)
执行
exec Insert_Inventory 'Dell', 'Inspiron', '14', 3, 4, 500, 'Core_i_5', 2.7, 'NVIDIA', 512, 20, 42000
Run Code Online (Sandbox Code Playgroud)
你必须将你的SP包装成BEGIN&END,你就错过了.,还可以使用1当检查IF Exist中Select Statement.而且还要检查,有些交易是开放的,但不承诺.您也可以使用SQL MERGE更新和插入语句,而不是这样做.
CREATE PROCEDURE Insert_Inventory
(
@Brand Varchar(50),
@Series Varchar(50),
@Model Varchar(50),
@Gener int,
@Ram int,
@HDD int,
@Processor Varchar(50),
@Clock float,
@Graphic_Chip Varchar(50),
@Graphic_Memory int,
@Qty int,
@Price int
)
AS
BEGIN
IF EXISTS (SELECT 1 FROM Laptops
WHERE Brand=@Brand
and Series=@Series
and Model=@Model
and Gener=@Gener
and ram=@Ram
and hdd=@HDD
and Processor=@Processor
and Clock=@Clock
and Graphic_Chip=@Graphic_Chip
and Graphic_Memory=@Graphic_Memory
)
BEGIN
UPDATE Laptops set qty=qty+@Qty, Price=@Price
WHERE Brand=@Brand
and Series=@Series
and Model=@Model
and Gener=@Gener
and ram=@Ram
and hdd=@HDD
and Processor=@Processor
and Clock=@Clock
and Graphic_Chip=@Graphic_Chip
and Graphic_Memory=@Graphic_Memory
END
ELSE
BEGIN
INSERT into Laptops Values (@Brand,@Series,@Model,@Gener,@Ram,@HDD,@Processor,@Clock,@Graphic_Chip,@Graphic_Memory,@Qty,@Price)
END
END
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
17845 次 |
| 最近记录: |