zoukankan      html  css  js  c++  java
  • SQL 语句where条件中分情况

    启发性案例一:

    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) 起作用。

          同理,不传参时,也能保证传参部分被过滤掉,默认显示部分剩下。

  • 相关阅读:
    RPA-UiPath视频教程2
    skywalking链路监控
    RPA-UiPath视频教程1
    Redis基础与性能调优
    tomcat调优
    DDos、CC攻击与防御
    UiPath官方视频Level2
    UiPath直播课程
    UiPath手把手教程
    【0】python核心编程,第二章
  • 原文地址:https://www.cnblogs.com/dyhao/p/10913018.html
Copyright © 2011-2022 走看看