Click here to Skip to main content
Rate this: bad
Please Sign up or sign in to vote.
See more: SQL Server
declare @vc_supplier_name varchar(200) =''
declare @in_supplier_type_id int =2
declare @bt_active bit =1
SELECT a.in_supplier_id, dbo.format_fnc_bit(1, a.bt_active) AS vc_active, b.vc_supplier_type_name, a.in_supplier_type_id, a.vc_supplier_name,
    dbo.admin_user_fnc_get_name(1, a.in_updatedby_user_id) AS vc_updated_by, a.dt_updated
    FROM dbo.supplier a
    INNER JOIN dbo.common_data_vw_supplier_type b ON a.in_supplier_type_id = b.in_supplier_type_id
    WHERE a.in_supplier_type_id = @in_supplier_type_id AND a.vc_supplier_name LIKE '%' + @vc_supplier_name + '%'
    AND  a.bt_active = case @in_supplier_type_id when 2 THEN @bt_active
    ORDER BY a.vc_supplier_name
Error comes :Incorrect syntax near the keyword 'ORDER'.
here i want to use bt_active only if @in_supplier_type_id=2
Posted 14-Feb-13 9:56am
Rate this: bad
Please Sign up or sign in to vote.

Solution 1

case @in_supplier_type_id when 2 THEN @bt_active

You missed the ending END ( Smile | :) ) here.
mrinal_kumar_jha at 14-Feb-13 15:13pm
Thanks CPallini It worked for @in_supplier_type_id =2
This query is not executing in case if @in_supplier_type_id is not 2..
What could be reason
Marcus Kramer at 14-Feb-13 15:47pm
Espen Harlinn at 15-Feb-13 9:04am
Rate this: bad
Please Sign up or sign in to vote.

Solution 2

You need to add an "End" to the end of your case statement.
AND  a.bt_active = case @in_supplier_type_id when 2 THEN @bt_active
should be this:
AND  a.bt_active = case @in_supplier_type_id when 2 THEN @bt_active End
You can also use an Else if need be.

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

  Print Answers RSS
0 George Jonsson 175
1 Kornfeld Eliyahu Peter 169
2 Zoltán Zörgő 139
3 PIEBALDconsult 130
4 OriginalGriff 120
0 OriginalGriff 6,165
1 DamithSL 4,658
2 Maciej Los 4,107
3 Kornfeld Eliyahu Peter 3,649
4 Sergey Alexandrovich Kryukov 3,342

Advertise | Privacy | Mobile
Web01 | 2.8.141220.1 | Last Updated 14 Feb 2013
Copyright © CodeProject, 1999-2014
All Rights Reserved. Terms of Service
Layout: fixed | fluid

CodeProject, 503-250 Ferrand Drive Toronto Ontario, M3C 3G8 Canada +1 416-849-8900 x 100