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

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

  • 相关阅读:
    Callable的Future模式
    并发队列
    并发工具类和线程池
    安全与死锁问题
    ConcurrentHashMap底层实现
    Map集合常见面试题
    List集合框架
    类加载器
    Activiti中个人任务分配
    流程定义
  • 原文地址:https://www.cnblogs.com/dyhao/p/10913018.html
Copyright © 2011-2022 走看看