• SQlserver 当输入参数为可选条件


    以前很懒,都是用拼接字符串的方式,加上if 语句,根据输入参数是否为空来判断是否需要在where 后加上对应字段的条件限制

    但是拼接字符串很烦,又总是被转义符搞得很烦  ''''

    所以想了其他办法

    分三种情况(varchar,int,date)都尝试了一下

    使用case when 和通配符当主角,而不是'''''''''

    不难理解,怕隔天忘记所以记一笔

    alter proc sp_testParam
    (
       @name varchar(50),
       @ID int,
       @sDate date,
       @eDate date
    )
    as
    begin

    --懒得要死,老是不乐意去记默认值,所以打印出来望自己长点脑子

    print @name+'--name'
    print cast(@ID as varchar(50))+'--ID'
    print cast(@sDate as varchar(50))+'--sDate'
    print cast(@eDate as varchar(50))+'--eDate'

    select * from benInfo
    where
    --varchar,使用'%%'表示包含任何字符串
    name like case when @name is null or @name='' then '%%' else '%'+@name+'%' end 
    --int,使用'[0-9]%'表示包含任何数字,因为该字段是ID,不需要模糊查询,则不需加通配符,完全匹配
    and cast(ID as varchar(50)) like case when @ID is null or @ID=0 then '[0-9]%' else cast(@ID as varchar(50)) end
    --date,该类型的默认值是'1900-01-01',因此起始日期不用理会,结束日期判断一下,未填则给无限大
    and currentDate between @sDate and case when @eDate is null or @eDate='1900-01-01'

     then '9999-12-31' else @eDate end


    end

    --exec sp_testParam '','','','2010-09-03'

    至此尝试了一下,在解决简单逻辑时,此方法是可行的

    /*
    PS.
    1.意外发现,当 like 后的字符串里不带有通配符时,其作用等同于等号 =

      

    */

  • 相关阅读:
    Dictionary-Guided Editing Networks for Paraphrase Generation解读
    CGMH:Constrained Sentence Generation by Metropolis-Hastings Sampling解读
    Text Infilling解读
    K-MEANS算法
    SVM-支持向量机算法
    003-文本分析
    002-贝叶斯拼写纠正实例
    001-贝叶斯算法简介
    【矩阵的乘积/复合变换】- 图解线性代数 05
    【行列式】- 图解线性代数 04
  • 原文地址:https://www.cnblogs.com/xcxcxcxc/p/5541183.html
Copyright © 2020-2023  润新知