Level Extreme platform
Subscription
Corporate profile
Products & Services
Support
Legal
Français
Stored Proc Problem
Message
General information
Forum:
Microsoft SQL Server
Category:
SQL syntax
Miscellaneous
Thread ID:
01394196
Message ID:
01394209
Views:
38
Same result. Passing only the client key returns 0 records.



>Try
>
>SELECT *
>		FROM bm_Clients
>		WHERE (CompanyKey = @CompanyKey OR @CompanyKey IS NULL)
>			AND
>			  (ClientKey = @ClientKey OR @ClientKey IS NULL)
>
>>This stored proc takes 2 optional params.
>>
>>
>>
>>CREATE PROCEDURE bm_GetClients
>>	@CompanyKey		INT = NULL,
>>	@ClientKey		INT = NULL
>>
>>AS
>>BEGIN
>>
>>	SELECT *
>>		FROM bm_Clients
>>		WHERE CompanyKey = ISNULL(@CompanyKey, CompanyKey) OR
>>			  ClientKey = ISNULL(@ClientKey, ClientKey)
>>
>>END
>>
>>
>>I want to pass either, both, or none. I'm running it like this:
>>
>>
>>DECLARE @CompanyKey	INT
>>DECLARE @ClientKey	INT
>>SET @CompanyKey = 2
>>SET @ClientKey = 5
>>
>>EXEC bm_GetClients
>>EXEC bm_GetClients @ClientKey
>>EXEC bm_GetClients @CompanyKey, @ClientKey 
>>EXEC bm_GetClients @CompanyKey
>>
>>
>>In all cases I'm getting back all records. If I change the OR to AND, then the second run returns no records.
Everything makes sense in someone's mind
public class SystemCrasher :ICrashable
In addition, an integer field is not for irrational people
Previous
Next
Reply
Map
View

Click here to load this message in the networking platform