启发性案例一:
SELECT*FROM KC_GoodStandard WHERE ( CASE WHEN 'undefined'='{传入的参数}' THEN 1 ELSE 0 END )=1 OR GoodId='{传入的参数}' SELECT*FROM KC_GoodStandard WHERE ( CASE WHEN ''='{传入的参数}' THEN 1 ELSE 0 END )=1 OR GoodId='{传入的参数}'
启发性案例二:
SELECT*FROM dbo WHERE 1=1 AND -------传参时显示 ((CASE WHEN 'undefined'='$querystring&year&$' OR ''='$querystring&year&$' THEN 0 ELSE 1 END)=1 AND (id>1 AND id<10) )) ---- (id>1 AND id<10) 为此状态下真正想要起作用的条件 OR ------默认显示(即链接不传参时显示) ((CASE WHEN 'undefined'='$querystring&year&$' OR ''='$querystring&year&$' THEN 1 ELSE 0 END)=1 AND (id>10)) -----(id>10) 为此状态下真正想要起作用的条件
案例二的设计思想:
当传入参数时,传参部分CASE条件得到 1=1 即为true,它 AND后边的(id>1 AND id<10),则(id>1 AND id<10)起作用。 同时因为传入了参数,默认显示部分的CESE条件得到 0=1 即为false,它AND后边的便不气作用。
所以传入参数时,仅有(id>1 AND id<10) 起作用。
同理,不传参时,也能保证传参部分被过滤掉,默认显示部分剩下。