Jam*_*mes 0 sql-server stored-procedures
我有这个存储过程
ALTER PROCEDURE [dbo].[usp_mySP]
-- Add the parameters for the stored procedure here
-- For inventory table check.
@DealerID VARCHAR(50),
@Certified VARCHAR(50) = NULL,
-- For fuel value.
@CityFeatureValue VARCHAR(50),
@HwyFeatureValue VARCHAR(50)
AS
BEGIN
BEGIN
SELECT InventoryID,
VIN
FROM Inventory
WHERE DealerID = @DealerID
AND Deleted = 'False'
AND (IsPending = '0' OR IsPending IS NULL)
--AND (Certified = @Certified OR @Certified IS NULL)
AND VIN IN
(
SELECT VIN
FROM FuelPerformance
WHERE (
FeatureTitle = 'Fuel Economy (City)'
AND FeatureValue = @CityFeatureValue
)
OR
(
FeatureTitle = 'Fuel Economy (Hwy)'
AND FeatureValue = @HwyFeatureValue
)
GROUP BY VIN
HAVING COUNT(VIN) > 1
)
END
END
Run Code Online (Sandbox Code Playgroud)
我称之为:
EXEC usp_ListOfVehiclesOnFuelCondition_ForSingleDealer
'09f5245d' , '', '18', '28'
Run Code Online (Sandbox Code Playgroud)
当我评论这条线时
AND (Certified = @Certified OR @Certified IS NULL)
Run Code Online (Sandbox Code Playgroud)
它给出了结果,但当这一行存在时,结果为空.
我做错了什么建议?
你传入一个空字符串(''
).那是非常不同的NULL
.
将参数作为命名参数传递(不带@Certified
),或测试空字符串,或传入NULL
.
命名参数:
EXEC usp_ListOfVehiclesOnFuelCondition_ForSingleDealer @DealerId = '09f5245d',
@CityFeatureValue = '18',
@HwyFeatureValue = '28'
Run Code Online (Sandbox Code Playgroud)
通过NULL
:
EXEC usp_ListOfVehiclesOnFuelCondition_ForSingleDealer '09f5245d',
NULL,
'18',
'28'
Run Code Online (Sandbox Code Playgroud)
检查''
:
AND (Certified = @Certified OR @Certified IS NULL OR @Certified = '')
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
841 次 |
最近记录: |